mysqlinnodb_deadlock_detect檢測和處理方法是什么

本篇內(nèi)容主要講解“MySQL innodb_deadlock_detect檢測和處理方法是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學(xué)習(xí)“mysql innodb_deadlock_detect檢測和處理方法是什么”吧!

創(chuàng)新互聯(lián)建站專注于重慶網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗。 熱誠為您提供重慶營銷型網(wǎng)站建設(shè),重慶網(wǎng)站制作、重慶網(wǎng)頁設(shè)計、重慶網(wǎng)站官網(wǎng)定制、小程序設(shè)計服務(wù),打造重慶網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供重慶網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。

innodb_deadlock_detect是MySQL的一個系統(tǒng)變量。
版本: 5.7.15
命令行格式:–innodb-deadlock-detect
影響范圍:Global
參數(shù)類型:boolean
默認值:ON
作用:該選項使用了禁用MySQL的死鎖檢測功能的。在高并發(fā)系統(tǒng)上,當許多線程等待同一個鎖時,死鎖檢測可能導(dǎo)致速度減慢。 有時,當發(fā)生死鎖時,如果禁用了死鎖檢測則可能會更有效,這樣可以依賴innodb_lock_wait_timeout的設(shè)置進行事務(wù)回滾。
MySQL默認情況下是開啟了死鎖檢測的,InnoDB自動檢測發(fā)送死鎖的事務(wù),并回滾其中的一個事務(wù)或所有導(dǎo)致死鎖的事務(wù)。InnoDB會在導(dǎo)致死鎖的十五中選擇一個權(quán)重比較小的事務(wù)來回滾,這個權(quán)重值可能是由該事務(wù)insert, updated, deleted的行數(shù)決定的。
如果innodb_table_locks = 1(默認值)并且autocommit = 0,則InnoDB能感知到表鎖的存在,并且上層的MySQL層知道行級鎖。 否則,InnoDB無法檢測到由MySQL LOCK TABLES語句設(shè)置的表鎖或由除InnoDB之外的存儲引擎設(shè)置的鎖定的死鎖。 通過設(shè)置innodb_lock_wait_timeout系統(tǒng)變量的值來解決這些情況。
當InnoDB執(zhí)行事務(wù)的完全回滾時,將釋放由事務(wù)設(shè)置的所有鎖。 但是,如果單個SQL語句由于錯誤而回滾,則語句設(shè)置的某些鎖可能會被保留。 這是因為InnoDB以一種格式存儲行鎖,以致之后不能知道哪個鎖由哪個語句設(shè)置。
如果SELECT調(diào)用事務(wù)中存儲的函數(shù),并且函數(shù)中的語句失敗,則該語句將回滾。 此外,如果在此之后執(zhí)行ROLLBACK,整個事務(wù)將回滾。
如果InnoDB監(jiān)控器輸出的最近死鎖檢測部分包含一條消息,指出TOO DEEP OR LONG SEARCH IN THE LOCK TABLE WAITS-FOR GRAPH, WE WILL ROLL BACK FOLLOWING TRANSACTION,這表示處于等待的事務(wù)列表長度已達到限制200。超過200個事務(wù)的等待列表被視為死鎖,并且將回滾嘗試檢查等待列表的事務(wù)。 如果鎖定線程必須查看等待列表上的事務(wù)擁有的超過1,000,000個鎖,則也可能發(fā)生相同的錯誤。
禁用死鎖檢測
可以通過選項:innodb_deadlock_detect來關(guān)閉死鎖檢測。

到此,相信大家對“mysql innodb_deadlock_detect檢測和處理方法是什么”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

網(wǎng)站題目:mysqlinnodb_deadlock_detect檢測和處理方法是什么
轉(zhuǎn)載來于:http://muchs.cn/article4/ijdioe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護、商城網(wǎng)站小程序開發(fā)、網(wǎng)站設(shè)計、全網(wǎng)營銷推廣、域名注冊

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作