首頁 > Java > 主體

是否有任何解決方案可以透過多個執行緒同時執行相同/相似的資料庫操作?

WBOY
發布: 2024-02-22 12:31:06
轉載
633 人瀏覽過

php小編子墨帶來的java問答:是否有解決方案可實現多個執行緒同時執行相同/相似資料庫操作?在開發過程中,如何有效處理多執行緒同時操作資料庫的問題一直備受關注。本文將介紹幾種解決方案,包括使用資料庫連接池、加鎖機制、事務處理等方法,幫助開發者解決這個難題。讓我們一起探討如何實現多執行緒並發執行資料庫操作,提升系統效能和穩定性。

問題內容

使用 Java、Spring Boot 和 Hibernate,有沒有辦法允許多個執行緒同時執行給定的操作,而不會導致死鎖或陳舊資料異常。

例如,假設自動化工具同時登入兩次,這會導致以下情況之一:

  1. 死鎖,因為兩個執行緒(請求)同時更新使用者記錄,例如儲存使用者上次登入的日期/時間。
  2. 陳舊資料異常,因為一個執行緒在另一個執行緒的事務完成之前更新使用者。

這可以透過在使用者 ID 上添加同步來解決,但是這種事情必須在所有地方進行,從而導致潛在的效能損失,並使程式碼庫更加臃腫且難以維護關注。

或者,我們可以調整隔離等級(也許我們可以全域設定預設等級)。這是更好的解決方案,還是有其他解決方案?

解決方法

悲觀鎖定。

在交易中儘早鎖定可能需要更新的所有行。您可以使用 locking read 來完成此操作。

select ... from users where user_id = ? for update;
登入後複製

只有一個執行緒會取得它。其他執行緒將等待該執行緒釋放鎖。

同時,持有鎖的執行緒可以在準備好時更新該行。

update users set last_login = now() where user_id = ?;
登入後複製

然後,為了對其他線程有禮貌,請在 update 之後儘快提交。這會自動釋放鎖。

COMMIT;
登入後複製

這允許下一個排隊執行緒取得它正在等待的鎖。

您可以使用鎖定讀取來鎖定多行,甚至可以鎖定多個表中的多行。 select 查詢檢查的任何行都會被鎖定。如果需要鎖定多個表中的行,可以執行 join 等操作。

鎖定獲取是原子的,因此給定的鎖定語句必須取得所有請求的鎖,否則它必須等待。

以上是是否有任何解決方案可以透過多個執行緒同時執行相同/相似的資料庫操作?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:stackoverflow.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!