成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識庫 > mysql自增id超大問題的排查與解決

mysql自增id超大問題的排查與解決

熱門標簽:外呼系統(tǒng)防封號違法嗎 湘潭電銷機器人咨詢電話 高德地圖標注中心個人注冊 電銷機器人針對的 寶應電信400電話辦理費用 高德地圖標注模式 如何在高德地圖標注新地址 400電話辦理都選易號網(wǎng) 外呼系統(tǒng)服務

引言

小A正在balabala寫代碼呢,DBA小B突然發(fā)來了一條消息,“快看看你的用戶特定信息表T,里面的主鍵,也就是自增id,都到16億了,這才多久,在這樣下去過不了多久主鍵就要超出范圍了,插入就會失敗,balabala......”

我記得沒有這么多,最多1k多萬,count了下,果然是1100萬。原來運維是通過auto_increment那個值看的,就是說,表中有大量的刪除插入操作,但是我大部分情況都是更新的,怎么會這樣?

下面話不多說了,來一起看看詳細的介紹吧

問題排查

這張表是一個簡單的接口服務在使用,每天大數(shù)據(jù)會統(tǒng)計一大批信息,然后推送給小A,小A將信息更新到數(shù)據(jù)庫中,如果是新數(shù)據(jù)就插入,舊數(shù)據(jù)就更新之前的數(shù)據(jù),對外接口就只有查詢了。

很快,小A就排查了一遍自己的代碼,沒有刪除的地方,也沒有主動插入、更新id的地方,怎么會這樣呢?難道是小B的原因,也不太可能,DBA那邊兒管理很多表,有問題的話早爆出來了,但問題在我這里哪里也沒頭緒。

小A又仔細觀察了這1000多萬已有的數(shù)據(jù),將插入時間、id作為主要觀察字段,很快,發(fā)現(xiàn)了個問題,每天第一條插入的數(shù)據(jù)總是比前一天多1000多萬,有時候遞增的多,有時候遞增的少,小A又將矛頭指向了DBA小B,將問題又給小B描述了一遍。

小B問了小A,“你是是不是用了REPLACE INTO ...語句”,這是怎么回事呢,原來REPLACE INTO ...會對主鍵有影響。

REPLACE INTO ...對主鍵的影響

假設有一張表t1:

CREATE TABLE `t1` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT 'ID,自增',
`uid` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '用戶uid',
`name` varchar(20) NOT NULL DEFAULT '' COMMENT '用戶昵稱',
PRIMARY KEY (`id`),
UNIQUE KEY `u_idx_uid` (`uid`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='測試replace into';

如果新建這張表,執(zhí)行下面的語句,最后的數(shù)據(jù)記錄如何呢?

insert into t1 values(NULL, 100, "test1"),(NULL, 101, "test2");
replace into t1 values(NULL, 100, "test3");

原來,REPLACE INTO ...每次插入的時候如果唯一索引對應的數(shù)據(jù)已經(jīng)存在,會刪除原數(shù)據(jù),然后重新插入新的數(shù)據(jù),這也就導致id會增大,但實際預期可能是更新那條數(shù)據(jù)。

小A說:“我知道replace是這樣,所有既沒有用它”,但還是又排查了一遍,確實不是自己的問題,沒有使用REPLACE INTO ...,

小A又雙叒叕仔細的排查了一遍,還是沒發(fā)現(xiàn)問題,就讓小B查下binlog日志,看看是不是有什么奇怪的地方,查了之后還是沒發(fā)現(xiàn)問題,確實存在跳躍的情況,但并沒有實質(zhì)性的問題。

下圖中@1的值對應的是自增主鍵id,用(@2, @3)作為唯一索引

后來過了很久,小B給小A指了個方向,小A開始懷疑自己的插入更新語句INSERT ... ON DUPLICATE KEY UPDATE ...了,查了許久,果然是這里除了問題。

INSERT ... ON DUPLICATE KEY UPDATE ...對主鍵的影響

這個語句跟REPLACE INTO ...類似,不過他并不會變更該條記錄的主鍵,還是上面t1這張表,我們執(zhí)行下面的語句,執(zhí)行完結(jié)果是什么呢?

insert into t1 values(NULL, 100, "test4") on duplicate key update name = values(name);

沒錯,跟小A預想的一樣,主鍵并沒有增加,而且name字段已經(jīng)更新為想要的了,但是執(zhí)行結(jié)果有條提示,引起了小A的注意

No errors; 2 rows affected, taking 10.7ms

明明更新了一條數(shù)據(jù),為什么這里的影響記錄條數(shù)是2呢?小A,又看了下目前表中的auto_increment

CREATE TABLE `t1` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT 'ID,自增',
`uid` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '用戶uid',
`name` varchar(20) NOT NULL DEFAULT '' COMMENT '用戶昵稱',
PRIMARY KEY (`id`),
UNIQUE KEY `u_idx_uid` (`uid`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8 COMMENT='測試replace into';

竟然是5`,這里本應該是4的。

也就是說,上面的語句,會跟REPLACE INTO ...類似的會將自增ID加1,但實際記錄沒有加,這是為什么呢?

查了資料之后,小A得知,原來,mysql主鍵自增有個參數(shù)innodb_autoinc_lock_mode,他有三種可能只0,1,2,mysql5.1之后加入的,默認值是1,之前的版本可以看做都是0。

可以使用下面的語句看當前是哪種模式

select @@innodb_autoinc_lock_mode;

小A使用的數(shù)據(jù)庫默認值也是1,當做簡單插入(可以確定插入行數(shù))的時候,直接將auto_increment加1,而不會去鎖表,這也就提高了性能。當插入的語句類似insert into select ...這種復雜語句的時候,提前不知道插入的行數(shù),這個時候就要要鎖表(一個名為AUTO_INC的特殊表鎖)了,這樣auto_increment才是準確的,等待語句結(jié)束的時候才釋放鎖。還有一種稱為Mixed-mode inserts的插入,比如INSERT INTO t1 (c1,c2) VALUES (1,'a'), (NULL,'b'), (5,'c'), (NULL,'d'),其中一部分明確指定了自增主鍵值,一部分未指定,還有我們這里討論的INSERT ... ON DUPLICATE KEY UPDATE ...也屬于這種,這個時候會分析語句,然后按盡可能多的情況去分配auto_incrementid,這個要怎么理解呢,我看下面這個例子:

truncate table t1;
insert into t1 values(NULL, 100, "test1"),(NULL, 101, "test2"),(NULL, 102, "test2"),(NULL, 103, "test2"),(NULL, 104, "test2"),(NULL, 105, "test2");

-- 此時數(shù)據(jù)表下一個自增id是7

delete from t1 where id in (2,3,4);

-- 此時數(shù)據(jù)表只剩1,5,6了,自增id還是7

insert into t1 values(2, 106, "test1"),(NULL, 107, "test2"),(3, 108, "test2");

-- 這里的自增id是多少呢?

上面的例子執(zhí)行完之后表的下一個自增id是10,你理解對了嗎,因為最后一條執(zhí)行的是一個Mixed-mode inserts語句,innoDB會分析語句,然后分配三個id,此時下一個id就是10了,但分配的三個id并不一定都使用。此處 @總是遲到 多謝指出,看官方文檔理解錯了

模式0的話就是不管什么情況都是加上表鎖,等語句執(zhí)行完成的時候在釋放,如果真的添加了記錄,將auto_increment加1。

至于模式2,什么情況都不加AUTO_INC鎖,存在安全問題,當binlog格式設置為Statement模式的時候,從庫同步的時候,執(zhí)行結(jié)果可能跟主庫不一致,問題很大。因為可能有一個復雜插入,還在執(zhí)行呢,另外一個插入就來了,恢復的時候是一條條來執(zhí)行的,就不能重現(xiàn)這種并發(fā)問題,導致記錄id可能對不上。

至此,id跳躍的問題算是分析完了,由于innodb_autoinc_lock_mode值是1,INSERT ... ON DUPLICATE KEY UPDATE ...是簡單的語句,預先就可以計算出影響的行數(shù),所以不管是否更新,這里都將auto_increment加1(多行的話大于1)。

如果將innodb_autoinc_lock_mode值改為0,再次執(zhí)行INSERT ... ON DUPLICATE KEY UPDATE ...的話,你會發(fā)現(xiàn)auto_increment并沒有增加,因為這種模式直接加了AUTO_INC鎖,執(zhí)行完語句的時候釋放,發(fā)現(xiàn)沒有增加行數(shù)的話,不會增加自增id的。

INSERT ... ON DUPLICATE KEY UPDATE ...影響的行數(shù)是1為什么返回2?

為什么會這樣呢,按理說影響行數(shù)就是1啊,看看官方文檔的說明

With ON DUPLICATE KEY UPDATE, the affected-rows value per row is 1 if the row is inserted as a new row, 2 if an existing row is updated, and 0 if an existing row is set to its current values

官方明確說明了,插入影響1行,更新影響2行,0的話就是存在且更新前后值一樣。是不是很不好理解?

其實,你要這樣想就好了,這是為了區(qū)分到底是插入了還是更新了,返回1表示插入成功,2表示更新成功。

解決方案

將innodb_autoinc_lock_mode設置為0肯定可以解決問題,但這樣的話,插入的并發(fā)性可能會受很大影響,因此小A自己想著DBA也不會同意。經(jīng)過考慮,目前準備了兩種較為可能的解決方案:

修改業(yè)務邏輯

修改業(yè)務邏輯,將INSERT ... ON DUPLICATE KEY UPDATE ...語句拆開,先去查詢,然后去更新,這樣就可以保證主鍵不會不受控制的增大,但增加了復雜性,原來的一次請求可能變?yōu)閮纱?,先查詢有沒有,然后去更新。

刪除表的自增主鍵

刪除自增主鍵,讓唯一索引來做主鍵,這樣子基本不用做什么變動,只要確定目前的自增主鍵沒有實際的用處即可,這樣的話,插入刪除的時候可能會影響效率,但對于查詢多的情況來說,小A比較兩種之后更愿意選擇后者。

結(jié)語

其實INSERT ... ON DUPLICATE KEY UPDATE ...這個影響行數(shù)是2的,小A很早就發(fā)現(xiàn)了,只是沒有保持好奇心,不以為然罷了,沒有深究其中的問題,這深究就起來會帶出來一大串新知識,挺好,看來小A還是要對外界保持好奇心,保持敏感,這樣才會有進步。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • MySQL的自增ID(主鍵) 用完了的解決方法
  • 關于mysql自增id,你需要知道的
  • MySQL表自增id溢出的故障復盤解決
  • 關于MySQL自增ID的一些小問題總結(jié)
  • 關于Mysql自增id的這些你可能還不知道
  • MySQL分表自增ID問題的解決方法
  • 線上MySQL的自增id用盡怎么辦

標簽:南充 賀州 蘭州 宿遷 佛山 黃山 馬鞍山 黔南

巨人網(wǎng)絡通訊聲明:本文標題《mysql自增id超大問題的排查與解決》,本文關鍵詞  mysql,自增,超大,問,題的,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《mysql自增id超大問題的排查與解決》相關的同類信息!
  • 本頁收集關于mysql自增id超大問題的排查與解決的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    eeuss影院网站免费观看| 污视频在线看网站| 中文字幕亚洲综合久久| 亚洲国产精品久久久久久6q| 久久久久久久久久久久久久久99| 久久久久久久国产| 精品999日本| 污网站在线免费看| 在线观看视频免费一区二区三区| 日韩av一区二区在线影视| 国产精品视频精品| 精品免费视频一卡2卡三卡4卡不卡| 国产视频一区二| 国产乱码精品一区二区三区不卡| 免费看成人哺乳视频网站| 国产精品亲子乱子伦xxxx裸| 精品自拍偷拍视频| 日本一区二区三区电影免费观看| 一个人看的www久久| 国产精品99久久久久久久女警| 国产精品一区电影| 免费看日本黄色| 国产美女性感在线观看懂色av| 亚洲av人人澡人人爽人人夜夜| 91麻豆国产香蕉久久精品| 国产精品探花在线播放| 久久久久国产精品一区三寸| 日韩欧美aⅴ综合网站发布| 久久97精品久久久久久久不卡| 中文天堂在线一区| 免费成人在线观看av| 玖草视频在线| 欧美激情精品久久久久| 先锋影音av中文字幕| 一区二区在线中文字幕电影视频| 黄色网在线免费看| 日韩精品一区二区三区丰满| 在线精品视频在线观看高清| 性欧美18—19sex性高清| 欧美国产日韩精品免费观看| 大奶一区二区三区| 九九精品视频在线观看| 亚洲一区精品视频| 欧美日韩综合另类| 欧美激情一区二区三区| www.噜噜色.com| 超碰成人福利网| 亚洲一区二区三区四区不卡| 2022国产麻豆剧果冻传媒剧情| 久久久久国产一区二区三区| 久久99精品久久久野外观看| 综合网在线观看| 精品国产乱码一区二区| 中文字幕第10页| 色婷婷综合激情| 成人黄色免费看| 欧美激情一区二区三区久久久| 破处女黄色一级片| 日韩欧美国产成人一区二区| 国产精品久久久久久久久妇女| 国产一区二区免费在线| 成人免费在线观看入口| 日产中文字幕在线精品一区| 盗摄系列偷拍视频精品tp| 久久99精品久久久久久欧洲站| 亚洲成人免费av| 国产精品边吃奶边做爽| 2023国产精华国产精品| 色噜噜狠狠色综合网图区| 亚洲成人动漫精品| 网曝门事件国产精品二区| 欧美激情欧美| 男生操女生视频在线观看| 免费福利视频一区| 国产精品超碰97尤物18| 老司机午夜免费精品视频| 日本一区二区不卡| 黄色一级视频免费看| 欧美黄色片视频| 日韩女同一区二区三区| 你懂的视频网| 宅男深夜免费观看视频| 日皮视频在线免费观看| 亚洲欧美日韩免费| 久激情内射婷内射蜜桃| 波多野结衣在线高清| 成人在线观看亚洲| 国产美女一区视频| 亚洲婷婷久久综合| 无遮挡动作视频在线观看免费入口| 鲁鲁视频www一区二区| 日韩欧美中文在线| 懂色av成人一区二区三区| www免费在线观看| 韩国三级与黑人| 中文字幕在线视频日韩| 4438亚洲最大| 国产精品入口麻豆九色| 三级网站免费看| 九九综合在线| 国产伦子伦对白视频| 717影院理论午夜伦不卡久久| 亚洲国产成人精品激情在线| 亚洲乱码中文字幕久久孕妇黑人| 日韩不卡一二三| 久久久一本二本三本| 99精品视频在线观看| 欧美精选在线播放| av成人资源| 久久这里只有精品99| 日韩一区二区三区精品视频第3页| 国产小视频在线高清播放| 亚洲伊人伊成久久人综合网| 尤物在线观看一区| 国产欧美一区二区三区网站| 一区二区三区在线免费播放| 操人视频在线观看欧美| 成人一二三区视频| 国产在线精品一区二区夜色| 天天操天天干天天插| 嗯啊主人调教在线播放视频| 99在线看视频| 午夜精品一区二区三区三上悠亚| 色婷婷亚洲综合| 日韩资源av在线| 久久久久久久久久免费视频| 欧美精品免费播放| 久久精品亚洲乱码伦伦中文| a级免费观看| 国产一区二区三区中文| 成人国产精品免费观看视频| 国产日产精品一区二区三区的介绍| 全网国产福利在线播放| 国产成人免费观看视频| 国产夫绿帽单男3p精品视频| 8x8x最新地址| 色成人在线视频| 精品一区二区男人吃奶| 在线影音av| 亚洲国产精一区二区三区性色| 久久天天躁夜夜躁狠狠躁2022| 蜜臀av免费一区二区三区| 欧美亚州一区二区三区| 九九99九九精彩| 一本色道综合久久欧美日韩精品| 亚洲乱码日产精品bd在线观看| 免费 成 人 黄 色| 国产成人三级在线播放| 欧美日韩一区二区三区在线视频| 日韩在线视频网站| 91欧美精品午夜性色福利在线| 日韩av在线资源| 九色porny91| 日韩免费黄色av| 亚洲一区二区三区四区不卡| 99久久久无码国产精品性色戒| 久久综合另类图片小说| 韩国av网站在线| 国产精品毛片一区视频播| 无码精品a∨在线观看中文| 男女av免费观看| 在线精品国产欧美| 青青在线视频一区二区三区| 国产手机在线视频| 日本在线视频中文有码| 欧美二区乱c少妇| 久久婷婷国产麻豆91天堂| 特级西西444www大精品视频免费看| 拍拍拍999自拍偷| 亚洲欧洲中文日韩久久av乱码| 国产精品外围在线观看| 国产精品伦理久久久久久| 蜜桃免费在线视频| 亚洲免费伊人电影在线观看av| 国产91|九色| 黄网站欧美内射| 国产噜噜噜噜久久久久久久久| chinese国产精品| 黄色三级电影网| mm1313亚洲国产精品美女| 亚洲精品国产精品乱码不99| 亚洲最大成人免费视频| 国产精品视频麻豆| 中文字幕亚洲欧洲| 91黄色在线视频| 国产伦精品一区二区三区视频我| 日本一区二区高清视频| 成人啊v在线| 欧美xxxx做受欧美88bbw| 午夜大尺度福利视频| 一代武则天秘史| 国内精久久久久久久久久人| 国产精品私拍pans大尺度在线| 国产精品综合网| 国产乱码精品一区二三赶尸艳谈| 国产精品一区在线播放| 三级视频中文字幕| 日韩黄色三级| aa一级黄色片| 国产成人在线观看免费网站| 日韩午夜黄色| 国产精品大片| 国产成人精品午夜| 亚洲片区在线| 99re热久久这里只有精品34| 成年网站免费在线观看| 久久99热这里只有精品| 国产7777777| 99亚洲伊人久久精品影院| 在线播放一区二区三区| 爽爽视频在线观看| 午夜精彩国产免费不卡不顿大片| 精品第一国产综合精品aⅴ| 欧美日韩1区2区3区| 国产第一页在线视频| 欧美精品少妇videofree| 国产成人av网站| 国产美女精彩久久| 日韩欧美在线网址| 亚洲欧洲美洲国产香蕉| 国产精品白丝av| 欧美精品小视频| 亚洲已满18点击进入在线看片| 亚洲第一区中文字幕| 战狼4完整免费观看在线播放版| 久久爱av电影| 日韩欧美在线视频一区二区| 黄频视频在线观看| 免费在线你懂的| 国产探花一区在线观看| 青青草av网站| 中文在线视频| 国产精品chinese在线观看| 操她视频在线观看| 国产精品一区二区免费福利视频| 国产一区二区三区四区在线观看| 国产a√精品区二区三区四区| 在线中文字幕一区二区| av剧情在线观看| 大胆av不用播放器在线播放| 免费成人深夜天涯网站| 午夜精品国产精品大乳美女| 久久免费视频2| 丁香婷婷久久久综合精品国产| 亚洲另类春色国产| 国产精品激情电影| 在线观看高清免费视频| 中文字幕第99页| 日本一区二区网站| 免费不卡在线视频| 国产精彩视频在线观看免费蜜芽| 欧美老女人第四色| 国产99午夜精品一区二区三区| 国产视频久久久久| 久久久久久久久久久久久久久久久久久久| 久久久久国内| 欧洲vodafone精品| 久久99九九99精品| 日韩成人免费在线观看| jizzjizzjizz欧美| 99久久99久久精品国产片| av永久不卡| 国语精品一区| 精品区在线观看| 久久婷婷开心| 色琪琪丁香婷婷综合久久| 五月天丁香激情| 欧美三级在线| se视频在线观看| mm131丰满少妇人体欣赏图| 欧美高清性猛交| 国产精品久久毛片| 外国一级黄色片| 国产精品扒开腿做爽爽爽视频| 国产精品女同一区二区三区| 后进极品白嫩翘臀在线播放| 国产精品久久久久久亚洲毛片| 国产91精品免费| 波多野结衣国产精品| 亚洲亚洲一区二区三区| 国产精品不卡在线| 欧美图片欧美激情欧美精品| 国产日韩欧美视频在线观看| 久久只精品国产| 美女精品一区最新中文字幕一区二区三区| 粉嫩一区二区三区| 日韩免费观看高清| 国外成人在线播放| 国产人与禽zoz0性伦| 日韩一级片免费看| 国产av无码专区亚洲a∨毛片| 久久久久99精品久久久久| 狂野欧美性猛交xxxx| 96sao精品视频在线观看| 国产又粗又猛又爽又黄的视频四季| 欧美激情精品久久久久久变态| 日韩最新中文字幕电影免费看| 欧美日韩色图| 亚洲色婷婷久久精品av蜜桃| 亚洲国产综合人成综合网站| 99国产在线| 五月天国产一区| 欧美高清在线视频| 国产视频不卡一区| 国产少妇在线观看| 久久久国产视频| 粉嫩嫩av羞羞动漫久久久| 亚洲一区二区三区四区的| 成人在线免费播放视频| 国产精品麻豆网站| 97人妻一区二区精品视频| 91短视频版在线观看www免费| 国产日韩一区二区三区在线播放| 男女黄床上色视频| 无码国产精品一区二区免费式直播| 国产日韩在线免费| 青青草国产精品亚洲专区无| 国产青青草在线| 涩涩视频在线观看免费| 97se亚洲国产综合自在线观| 国产成人在线播放| 色中色综合影院手机版在线观看| 国产一区二区自拍视频| 欧美色手机在线观看| 亚洲成人av一区二区三区| 久久精品噜噜噜成人av农村| 亚洲第一福利在线观看| 97精品视频在线播放|