死鎖I


死鎖產(chǎn)生的條件有四個
1.互斥(mutual exclusion): 訪問的資源必須是非共享的觉阅,A與B的訪問要是互斥的,其他訪問要等待
2.占有并等待(hold and wait):A占有一個資源并等待B占有的另一個資源
3.非搶占(no preemption):A占有的資源只有A自己去釋放称龙,不能被奪走
4.循環(huán)等待(circular wait):類似于哲學(xué)家就餐問題(A等待B占有的資源留拾,B等待C占有的資源,C等待A占有的資源)- 必要條件(比如B占有的資源有多個實例鲫尊,那么另一個需要相同的資源的就不會因為B占有了而出現(xiàn)死鎖問題)

最終就是表現(xiàn)為資源的互相等待的循環(huán)


我們知道死鎖產(chǎn)生了有一些方法去避免痴柔,下面這個問題就是通過加鎖的順序來避免死鎖

指定加鎖的順序并不能真正的避免死鎖因為調(diào)用的資源可能是通過外界傳入進來的順序,比如銀行賬戶的每個賬戶都有一個鎖疫向,下面的方式通過鎖的順序是會出現(xiàn)死鎖的


// 這些是偽代碼
type Account struct {
    sync.Mutex
    nMoney     uint64
    nAccountID uint64
}

// one to one
func TranToHashCode(account Account) int {
    return 0
}

// 取款
func WithDraw(account Account, nAmount uint64) {

}

// 存款
func Deposit(account Account, nAmount uint64) {

}

// 產(chǎn)生死鎖的方式
// 如果有兩個攜程調(diào)用的話咳蔚,并且調(diào)用順序為
// Transaction(from, to,10)
// Transaction(to, from,10)
// 由于并發(fā)導(dǎo)致的交叉執(zhí)行會產(chǎn)生死鎖的可能
func Transaction(from Account, to Account, aMount uint64) {
    from.Lock()
    to.Lock()

    WithDraw(from, aMount)
    Deposit(to, aMount)

    to.Unlock()
    from.Unlock()
}

一種解決方案是認為的控制調(diào)用鎖的順序


// 解決死鎖的方式
// 我們 通過給每個賬號求一個hash值人為的改變順序
func Transaction2(from Account, to Account, aMount uint64) {
    var fromHashCode int = TranToHashCode(from)
    var toHashCode int = TranToHashCode(to)

    if fromHashCode < toHashCode {
        from.Lock()
        to.Lock()

        WithDraw(from, aMount)
        Deposit(to, aMount)

        to.Unlock()
        from.Unlock()
        return
    }

    to.Lock()
    from.Lock()

    WithDraw(from, aMount)
    Deposit(to, aMount)

    from.Unlock()
    to.Unlock()
}

上面這些都是偽代碼,作為示例只是說明


舉個mysql的例子
mysql也會有死鎖的問題搔驼,當(dāng)然原因肯定也是這四個條件滿足才會出現(xiàn)谈火,比如存儲引擎innob批量更新數(shù)據(jù)庫會有行鎖磕洪,如果有兩個更新任務(wù)里面有交叉的更新任務(wù)比如A[1,2,3,4] B[6,5,2,1]就有可能出現(xiàn)死鎖問題 滿足上面四個條件
第一逐虚、行鎖 有相同的行會有互斥
第二休玩、如果交叉執(zhí)行A執(zhí)行了1然后B去執(zhí)行了6,5,2 緊接著又A開始執(zhí)行就就先占有等待的問題
第三巨柒、因為A任務(wù)不會自己釋放任務(wù),就是等待執(zhí)行完才會釋放
第四捌显、因為第二條的占有等待 A等待B B等待A 一直循環(huán)等待也就思索了

如果我們的update處理把更新序列排序也就是A[1,2,3,4] B[1,2,5,6]死鎖就可以解決



因此預(yù)防可以從這四個必要條件去著手-----缺點是或?qū)е滦阅軉栴}


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末欢摄,一起剝皮案震驚了整個濱河市廊移,隨后出現(xiàn)的幾起案子扭粱,更是在濱河造成了極大的恐慌舵鳞,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,884評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件琢蛤,死亡現(xiàn)場離奇詭異蜓堕,居然都是意外死亡,警方通過查閱死者的電腦和手機博其,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,347評論 3 385
  • 文/潘曉璐 我一進店門套才,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人慕淡,你說我怎么就攤上這事霜旧。” “怎么了?”我有些...
    開封第一講書人閱讀 157,435評論 0 348
  • 文/不壞的土叔 我叫張陵挂据,是天一觀的道長。 經(jīng)常有香客問我儿普,道長崎逃,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,509評論 1 284
  • 正文 為了忘掉前任眉孩,我火速辦了婚禮个绍,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘浪汪。我一直安慰自己巴柿,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,611評論 6 386
  • 文/花漫 我一把揭開白布死遭。 她就那樣靜靜地躺著广恢,像睡著了一般。 火紅的嫁衣襯著肌膚如雪呀潭。 梳的紋絲不亂的頭發(fā)上钉迷,一...
    開封第一講書人閱讀 49,837評論 1 290
  • 那天,我揣著相機與錄音钠署,去河邊找鬼糠聪。 笑死,一個胖子當(dāng)著我的面吹牛谐鼎,可吹牛的內(nèi)容都是我干的舰蟆。 我是一名探鬼主播,決...
    沈念sama閱讀 38,987評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼狸棍,長吁一口氣:“原來是場噩夢啊……” “哼身害!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起隔缀,我...
    開封第一講書人閱讀 37,730評論 0 267
  • 序言:老撾萬榮一對情侶失蹤题造,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后猾瘸,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體界赔,經(jīng)...
    沈念sama閱讀 44,194評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,525評論 2 327
  • 正文 我和宋清朗相戀三年牵触,在試婚紗的時候發(fā)現(xiàn)自己被綠了淮悼。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,664評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡揽思,死狀恐怖袜腥,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情钉汗,我是刑警寧澤羹令,帶...
    沈念sama閱讀 34,334評論 4 330
  • 正文 年R本政府宣布鲤屡,位于F島的核電站,受9級特大地震影響福侈,放射性物質(zhì)發(fā)生泄漏酒来。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,944評論 3 313
  • 文/蒙蒙 一肪凛、第九天 我趴在偏房一處隱蔽的房頂上張望堰汉。 院中可真熱鬧,春花似錦伟墙、人聲如沸翘鸭。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,764評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽就乓。三九已至,卻和暖如春譬淳,著一層夾襖步出監(jiān)牢的瞬間档址,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,997評論 1 266
  • 我被黑心中介騙來泰國打工邻梆, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留守伸,地道東北人。 一個月前我還...
    沈念sama閱讀 46,389評論 2 360
  • 正文 我出身青樓浦妄,卻偏偏與公主長得像尼摹,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子剂娄,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,554評論 2 349