亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MongoDB > 正文

MongoDB詭異問題之sh.stopBalancer卡住的解決方法

2020-10-29 18:44:09
字體:
來源:轉載
供稿:網友

背景

Part1:寫在最前

我們在使用MongoDB sharding集群時,會使用如下命令來管理啟停Balancer:

>sh.stopBalancer() 停止Balancer>sh.startBalancer() 開啟Balancer

Part2:背景

開啟balancer后,客戶反饋前端應用寫入緩慢,查詢超時。因此我們嘗試關閉balancer,來避免chunk遷移對集群性能帶來的影響。

但是在調用sh.stopBalancer的時候,發現卻停不下來,sh.stopBalancer會處于卡住的狀態:

mongos>sh.stopBalancer()Waiting for active hosts...Waiting for the balancer lock...assert.soon failed,msg:Waited too long for lock balancer to unlockdoassert@src/mongo/shell/assert.js:18:14assert.soon@src/mongo/shell/assert.js:202:13sh.waitForDLock@src/mongo/shell/utils_sh.js:198:1sh.waitForBalancerOff@src/mongo/shell/utils_sh.js:264:9sh.waitForBalancer@src/mongo/shell/utils_sh.js:294:9sh.stopBalancer@src/mongo/shell/utils_sh.js:161:5@(shell):1:1Balancer still may be active, you must manually verify this is not the case using theconfig.changelog collection.2018-02-11T16:28:29.753+0800E QUERY [thread1] Error: Error:assert.soon failed, msg:Waited too long for lock balancer to unlock :sh.waitForBalancerOff@src/mongo/shell/utils_sh.js:268:15sh.waitForBalancer@src/mongo/shell/utils_sh.js:294:9sh.stopBalancer@src/mongo/shell/utils_sh.js:161:5@(shell):1:1

從上述報錯能夠看出,是由于目前balancer正在運行導致的,

Warning:警告 在3.4版本中,balancer運行在config server 的主節點上,在早期的版本中,balancer是運行在mongos上的。 當balancer進程處于活動狀態時,config server副本集的主服務器通過修改config數據庫的lock集合中的文檔,來獲取“平衡器鎖”。 這個“平衡器鎖”只能自己主動釋放。

Part3:排查方法

我們調用sh.status()命令能夠看到當前balancer已經關閉了,但是running還是yes,這說明有遷移正在運行。 

 balancer:Currently enabled: noCurrently running: yes

我們查看發現migrations集合下為空,說明沒有集合在遷移

mongos> db.migrations.find()

我們查看locks集合下的信息,處于2狀態的說明正持有鎖

mongos> db.locks.find(){ "_id" : "balancer", "state" : 2, "ts" : ObjectId("5a324c42329457086086da07"), "who" : "ConfigServer:Balancer", "process" : "ConfigServer", "when" : ISODate("2018-01-31T08:33:43.346Z"), "why" : "CSRS Balancer" }

Warning:警告

locks集合中的why列告訴我們持有鎖的原因,如果有正在遷移的文檔,其狀態應該是2,why中的原因會顯示Migrating chunk(s) in collection db.collationname.

從3.4版本起,balancer的狀態字段將始終為值2,以防止老版本的mongos實例執行平衡操作。 when字段指config server 成員成為主節點的時間。

解決辦法

Part1:寫在最前

sh.stopBalancer停不下來,常見的可能原因有以下幾個:

  • 正在做chunk遷移,必須等待chunk遷移完成后,才能夠正常停止;
  • 后端的server時間不同步;
  • mongo客戶端版本低于server端,本文就是第3種情況。mongo客戶端的版本是3.2版本,config server和mongod都是3.4版本的mongo。

Part2:解決辦法

替換老版本的mongo客戶端,使用3.4版本的客戶端

mongos> sh.stopBalancer(){ "ok" : 1 } config:PRIMARY> db.version()3.4.9-2.9

Part3:原因分析

卡住的原因是由于客戶端mongo是3.2版本,而config節點是3.4版本,3.2版本的mongos在執行stopBalancer()時,stopBalancer代碼假定如果balancerStop命令沒有找到,那么它會使用舊版本的邏輯,等待鎖被釋放。從3.4版本起,Balance進程從mongos移動之configer server的primary節點上。

總結

通過這個案例,我們能夠了解到mongo客戶端版本帶來的問題,以及有哪些常見原因導致sh.stopBalancer停不下來。由于筆者的水平有限,編寫時間也很倉促,文中難免會出現一些錯誤或者不準確的地方,不妥之處懇請讀者批評指正。

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
少妇激情综合网| 欧美精品videos另类日本| 久久99精品久久久久久琪琪| 91精品国产91久久| 欧美www视频在线观看| 中文字幕亚洲一区二区三区五十路| 亚洲国产精品中文| 4438全国亚洲精品在线观看视频| 亚洲国产成人精品女人久久久| 在线中文字幕日韩| 亚洲天堂男人天堂| 国产视频久久久久| 欧洲永久精品大片ww免费漫画| 亚洲午夜精品视频| 精品久久久久久国产91| 人妖精品videosex性欧美| 中文字幕综合一区| 色偷偷88888欧美精品久久久| 国产精品av网站| 亚洲视频一区二区三区| 欧美日韩国产黄| 日韩av电影在线播放| 亚洲欧美在线一区| 国产国语刺激对白av不卡| 日韩经典中文字幕在线观看| 在线播放日韩av| 日本精品性网站在线观看| 中文字幕日韩av| 久久中国妇女中文字幕| 国产在线一区二区三区| 亚洲伦理中文字幕| 97超级碰在线看视频免费在线看| 日韩av在线网页| 欧美黄色片视频| 亚洲精品久久久一区二区三区| 538国产精品一区二区免费视频| 91中文字幕一区| 国产精品视频导航| 国产一区二区三区毛片| 亚洲老头老太hd| 欧美激情免费看| 精品国产一区久久久| 最近中文字幕2019免费| 亚洲综合小说区| 国产在线视频2019最新视频| 欧美激情综合色| 欧美成人精品在线观看| 日本精品视频在线观看| 在线视频一区二区| 日韩中文字幕欧美| 亚洲自拍另类欧美丝袜| 日韩欧美福利视频| 亚洲free性xxxx护士白浆| 日韩性生活视频| 国产男女猛烈无遮挡91| 精品福利在线视频| 精品偷拍一区二区三区在线看| 国产999精品| 国产91成人在在线播放| 亚洲毛片在线观看.| 国产精品久久久久久久电影| 一区二区三区精品99久久| 亚洲第一页在线| 久久久精品一区二区三区| 久久全球大尺度高清视频| 国产精品 欧美在线| 欧美日韩国产精品专区| 久久亚洲精品成人| 97在线视频免费| 久久久精品免费| 日本一区二三区好的精华液| 精品亚洲一区二区三区在线播放| 自拍偷拍亚洲区| 国产日本欧美一区二区三区在线| 欧美尤物巨大精品爽| 欧美日韩国产精品一区| 日韩免费观看网站| 成人激情在线播放| 日本免费久久高清视频| 国产精品久久久久91| 精品国产一区二区三区四区在线观看| 91久久精品国产91久久| 欧美大学生性色视频| 久久99亚洲热视| 91在线视频免费| 国产精品久久久久久久久免费| 日本中文字幕成人| 91视频免费在线| 日韩精品免费看| 精品久久久中文| 日韩av在线一区| 亚洲jizzjizz日本少妇| 久久久久久高潮国产精品视| 九九视频这里只有精品| 国产一区二区三区四区福利| 国产精品丝袜视频| 亚洲аv电影天堂网| 国产不卡视频在线| 日韩成人av一区| 精品久久久久久亚洲国产300| 91精品国产综合久久香蕉的用户体验| 韩国精品美女www爽爽爽视频| 国产视频欧美视频| 欧美精品videossex性护士| 欧美亚洲第一页| 日本精品视频在线观看| 国产精品久久77777| 欧美福利小视频| 97国产成人精品视频| 国产成人精品免费视频| 国产亚洲精品久久久久久牛牛| 国产视频福利一区| 国产亚洲一区二区在线| 久久精品视频播放| 欧美在线一级va免费观看| 国产精品久久激情| 欧美国产中文字幕| 久久久久五月天| 国产日产欧美a一级在线| 久久久久久久影院| 少妇精69xxtheporn| 欧美性猛交xxxxx免费看| 国产手机视频精品| 麻豆乱码国产一区二区三区| 日韩欧美国产高清91| 成人性生交大片免费看视频直播| 欧美性猛交xxxx免费看漫画| 国产日韩欧美中文| 亚洲xxxx18| 久久久久久久91| 久久成人精品一区二区三区| 成人免费观看49www在线观看| 国产精品久久久久久久久久东京| 欧美亚洲另类激情另类| 精品无人区乱码1区2区3区在线| 亚洲欧美日韩国产中文| 欧美激情一二区| 国产精品美女久久久久av超清| 国产伦精品一区二区三区精品视频| 国产精品免费久久久久久| 久久综合久中文字幕青草| 国产精品久久久久久久久久99| 国产欧美一区二区| 91视频8mav| 精品亚洲va在线va天堂资源站| 亚洲免费av片| 亚洲福利在线播放| 日韩电影视频免费| 日韩精品中文字幕有码专区| 日韩视频免费在线| 久久久久久久成人| 日韩av123| 欧美日韩精品在线观看| 91麻豆国产精品| 性金发美女69hd大尺寸| 亚洲激情视频在线播放| 国产xxx69麻豆国语对白| 最近2019年日本中文免费字幕| 国产免费亚洲高清| 精品美女久久久久久免费| 国产自摸综合网| 伊人伊成久久人综合网站| 日韩视频免费看| 91精品久久久久久久久久久|