mysql保障數據一致性:鎖與解(一)

因項目需要有鎖單業務,所以,涉及到兩個技術點:分佈式鎖和數據庫鎖。

項目前期(qps<3000)可以考慮數據庫鎖,涉及到的概念:樂觀鎖、悲觀鎖。

悲觀鎖(Pessimistic Lock), 顧名思義,就是很悲觀,每次去拿數據的時候都認爲別人會修改,所以每次在拿數據的時候都會上鎖,這樣別人想拿這個數據就會block直到它拿到鎖。傳統的關係型數據庫裏邊就用到了很多這種鎖機制,比如行鎖,表鎖等,讀鎖,寫鎖等,都是在做操作之前先上鎖。

樂觀鎖(Optimistic Lock), 顧名思義,就是很樂觀,每次去拿數據的時候都認爲別人不會修改,所以不會上鎖,但是在更新的時候會判斷一下在此期間別人有沒有去更新這個數據,可以使用版本號等機制。樂觀鎖適用於多讀的應用類型,這樣可以提高吞吐量,像數據庫如果提供類似於write_condition機制的其實都是提供的樂觀鎖。

兩種鎖各有優缺點,不可認爲一種好於另一種,像樂觀鎖適用於寫比較少的情況下,即衝突真的很少發生的時候,這樣可以省去了鎖的開銷,加大了系統的整個吞吐量。但如果經常產生衝突,上層應用會不斷的進行retry,這樣反倒是降低了性能,所以這種情況下用悲觀鎖就比較合適。


1.查看當前會話隔離級別
 
select @@tx_isolation;
 
2.查看系統當前隔離級別
 
select @@global.tx_isolation;
 
3.設置當前會話隔離級別
 
set session transaction isolation level Read Uncommitted;
 
4.設置系統當前隔離級別
 
set global transaction isolation level repeatable read;
 
5.命令行,開始事務時
 
set autocommit=off 或者 start transaction


MySQL 加鎖處理分析

http://hedengcheng.com/?p=771


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章