精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

攜程一次Redis遷移容器后的Slowlog“異?!狈治?/h1>

數據庫 其他數據庫 Redis
容器化對于Redis自動化運維效率、資源利用率方面都有巨大提升,攜程在對Redis在容器上性能和穩定性進行充分驗證后,啟動了生產Redis遷移容器化的項目。希望本次結論能給遇到同樣問題的小伙伴以啟發,另外本次分析問題的思路對于分析其他疑難雜癥也有一定借鑒作用。

攜程一次Redis遷移容器后Slowlog“異常”分析

容器化對于Redis自動化運維效率、資源利用率方面都有巨大提升,攜程在對Redis在容器上性能和穩定性進行充分驗證后,啟動了生產Redis遷移容器化的項目。其中第一批次兩臺宿主機,第二批次五臺宿主機。

本次“異常”是第二批次遷移過程中發現的,排查過程一波三折,最終得出讓人吃驚的結論。

希望本次結論能給遇到同樣問題的小伙伴以啟發,另外本次分析問題的思路對于分析其他疑難雜癥也有一定借鑒作用。

一、問題描述 

在某次Redis遷移容器后,DBA發來告警郵件,slowlog>500ms,同時在DBA的慢日志查詢里可以看到有1800ms左右的日志,如下圖1所示:  

圖 1

二、分析過程 

2.1 什么是Slowlog

在分析問題之前,先簡單解釋下Redis的slowlog。閱讀Redis源碼(圖2)不難發現,當某次Redis的操作大于配置中slowlog-log-slower-than設置的值時,Redis就會將該值記錄到內存中,通過slowlog get可以獲取該次slowlog發生的時間和耗時,圖1的監控數據也是從此獲得。 

圖 2 

也就是說,slowlog只是單純的計算Redis執行的耗時時間,與其他因素如網絡之類的都沒關系。

2.2 矛盾的日志

每次slowlog都是1800+ms并且都隨機出現,在第一批次Redis容器化的宿主機上完全沒有這種現象,而QPS遠小于第一批次遷移的某些集群,按常理很難解釋,這時候翻看CAT記錄,更加加重了我們的疑惑,見圖3: 

圖 3 

CAT是攜程根據開源軟件(https://github.com/dianping/cat)的定制版本,用于客戶端記錄打點的耗時,從圖中可以很清晰的看到,Redis打點的最大值367ms也遠小于1800ms,它等于是說下面這張自相矛盾圖,見圖4: 

圖 4 

2.3 求助社區

所以說,slowlog問題要么是CAT誤報,要么是Redis誤報,但Redis使用如此廣泛,并且經過詢問CAT的維護者說CAT有一定的消息丟棄率,而Redis在官方github issue中并沒有發現類似的slowlog情形,因此我們第一感覺是CAT誤報,并在官方Redis issue中提問,試圖獲取社區的幫助。

很快社區有人回復,可能是NUMA架構導致的問題,但也同時表示NUMA導致slowlog高達1800ms很不可思議。關于NUMA的資料網上有很多,這里不再贅述,我們在查閱相關NUMA資料后也發現,NUMA架構導致如此大的slowlog不太可能,因此放棄了這條路徑的嘗試。

2.4 豁然開朗

看上去每個方面好像都沒有問題,而且找不到突破口,排障至此陷入了僵局。

重新閱讀Redis源代碼,直覺發現gettimeofday()可能有問題,模仿Redis獲取slowlog的代碼,寫了一個簡答的死循環,每次Sleep一秒,看看打印出來的差值是否正好1秒多點,如圖5所示: 

 

圖 5 

圖5的程序大概運行了20分鐘后,奇跡出現了,gettimeofday果然有問題,下面是上面程序測試時間打印出來的LOG,如圖6: 

 

圖 6 

圖6中標紅的時間減去1秒等于1813ms,與slowlog時間如此相近!在容器所在的物理機上也測試一遍,發現有同樣的現象,排除因容器導致slowlog,希望的曙光似乎就在眼前了,那么問題又來了:

  1. 到底為什么會相差1800ms+呢?
  2. 為什么第一批機器沒有這種現象呢?
  3. 為什么之前跑在物理機上的Redis沒有這種現象呢?

帶著這三個問題,重新審視系統調用gettimeofday獲取當前時間背后的原理,發現一番新天地。

三、系統時鐘 

系統時鐘的實現非常復雜,并且參考資料非常多。

簡單來說 我們可以通過命令:

  1. cat /sys/devices/system/clocksource/clocksource0/current_clocksource 

來獲取當前系統的時鐘源,攜程的宿主機上都是統一Time Stamp Counter(TSC):80x86微處理器包括一個時鐘輸入插口,用來接收來自外部振蕩器的時鐘信號,從奔騰80x86微處理器開始,增加了一個計數器。

隨著每增加一個時鐘信號而加一,通過rdtsc匯編指令也可以去讀TSC寄存器,這樣如果CPU的頻率是1GHz,TSC寄存器就能提供納秒級別的計時精度,并且現代CPU通過FLAG constant_tsc來保證即使CPU休眠也不影響TSC的頻率。

當選定TSC為時鐘源后,gettimeofday獲取墻上時鐘(wall-clock)正是從TSC寄存器讀出來的值轉換而來,所謂墻上時鐘主要是參照現實世界人們通過墻上時鐘獲取當前時間,但是用來計時并不準確,可能會被NTP或者管理員修改。

那么問題又來了,宿主機的時間沒有被管理員修改,難道是被NTP修改?即使是NTP來同步,每次相差也不該有1800ms這么久,它的意思是說難道宿主機的時鐘每次都在變慢然后被NTP拉回到正常時間?我們手工執行了下NTP同步,發現的確是有很大偏差,如圖7所示:  

 

圖 7

按常識時鐘正常的物理機與NTP服務器時鐘差異都在1ms以內,相差1s+絕對有問題,而且還是那個老問題,為什么第一批次的機器上沒有問題?

四、內核BUG 

兩個批次宿主機一樣的內核版本,第一批沒問題而第二批有問題,差異只可能在硬件上,非常有可能在計時上,翻看內核的commit log終于讓我們發現了這樣的commit,如圖8所示: 

 

圖 8

該commit非常清楚指出,在4.9以后添加了一個宏定義INTEL_FAM6_SKYLAKE_X,但因為搞錯了該類型CPU的crystal frequency會導致該類型的CPU每10分鐘慢1秒鐘。

這時再看看我們的出問題的第二批宿主機xeon bronze 3104正好是skylake-x的服務器,影響4.9-4.13的內核版本,宿主機內核4.10正好中招。

并且NTP每次同步間隔1024秒約慢1700ms,與slowlog異常完全吻合,而第一批次的機器CPU都不是SKYLAKE-X平臺的,避開了這個BUG,遷移之前Redis所在的物理機內核是3.10版本,自然也不存在這個問題。至此,終于解開上面三個疑惑。

五、總結 

5.1 問題根因

通過上面的分析可以看出,問題根因在于內核4.9-4.13之間skylake-x平臺TSC晶振頻率的代碼BUG,也就是說同時觸發這兩個因素都會導致系統時鐘變慢,疊加上Redis計時使用的gettimeofday會容易被NTP修改導致了本文開頭詭異的slowlog“異常”。有問題的宿主機內核升級到4.14版本后,時鐘變慢的BUG得到了修復。

5.2 怎么獲取時鐘

對于應用需要打點記錄當前時間的場景,也就是說獲取Wall-Clock,可以使用clock_gettime傳入CLOCK_REALTIME參數,雖然gettimeofday也可以實現同樣的功能,但不建議繼續使用,因為在新的POSIX標準中該函數已經被廢棄。

對于應用需要記錄某個方法耗時的場景,必須使用clock_gettime傳入CLOCK_MONOTONIC參數,該參數獲得的是自系統開機起單調遞增的納秒級別精度時鐘,相比gettimeofday精度提高不少,并且不受NTP等外部服務影響,能更準確來統計耗時(Java中對應的是System.nanoTime),也就是說所有使用gettimeofday來統計耗時(Java中是System.currenttimemillis)的做法本質上都是錯誤的。

責任編輯:龐桂玉 來源: Docker
相關推薦

2023-02-08 16:34:05

數據庫工具

2013-09-13 09:27:42

服務器LinuxApache

2014-11-12 11:17:32

網站遷移運維

2011-04-07 11:20:21

SQLServer

2020-10-22 13:49:37

Docker容器僵死進程

2014-12-25 17:51:07

2015-07-14 09:40:57

攜程面試前端面試官

2020-01-06 09:43:14

賠償TSB遷移

2024-09-26 10:41:31

2010-07-30 16:10:45

UPS設備燒毀故障分析

2011-06-28 10:41:50

DBA

2023-08-04 09:35:18

2023-11-17 10:03:45

攜程開源

2023-04-06 07:53:56

Redis連接問題K8s

2023-05-08 08:25:52

2014-08-01 14:06:45

2019-03-20 09:44:09

威脅情報病毒網絡安全

2021-03-18 23:47:18

MySQLselect索引

2021-12-06 17:21:05

異常報錯故障

2023-10-20 09:17:08

攜程實踐
點贊
收藏

51CTO技術棧公眾號

成人在线视频www| av小片在线| 国产精品综合| 日韩亚洲综合在线| 色噜噜狠狠一区二区三区狼国成人| gogo在线观看| 久久蜜桃av一区二区天堂| 国产在线视频91| 精品亚洲永久免费| 欧美精品乱码| 亚洲成在人线av| 在线黄色免费观看| 草美女在线观看| 亚洲国产精品t66y| 精品久久一区二区三区蜜桃| 中文字幕无码乱码人妻日韩精品| 国产主播精品| 中文字幕亚洲欧美日韩高清| 成人免费看片载| 看片一区二区| 色狠狠一区二区| 人人妻人人澡人人爽欧美一区双 | 日韩午夜黄色| 久久最新资源网| 一区二区三区四区免费| 99a精品视频在线观看| 欧美少妇xxx| 免费无遮挡无码永久视频| 蜜芽在线免费观看| 国产女主播一区| 免费影院在线观看一区 | 精品少妇一区二区三区在线播放| 精品久久久久久久无码| 欧美hdxxxxx| 亚洲天堂网中文字| 亚洲欧美日韩综合一区| 天天综合在线视频| 国产sm精品调教视频网站| 国产综合久久久久| 成人免费一区二区三区| 免费看黄裸体一级大秀欧美| 久久久噜久噜久久综合| 青青草免费av| 一区二区中文| 日韩亚洲欧美中文在线| 国产又黄又粗又猛又爽的| 国产在线观看91一区二区三区| 亚洲精品国产美女| 精品一区二区三区四区五区六区| 4438全国亚洲精品观看视频| 制服丝袜激情欧洲亚洲| 亚洲天堂av一区二区| h1515四虎成人| 欧美亚洲国产bt| www.天天射.com| 99久久伊人| 欧美日韩免费在线视频| 男女视频在线看| 欧美一区=区三区| 欧美高清hd18日本| 在线播放av中文字幕| 五月天色综合| 欧美一二三四在线| 美国黄色一级视频| 牛牛影视久久网| 亚洲人成网站免费播放| 国产综合精品在线| 图片区亚洲欧美小说区| 欧美大胆在线视频| 日本在线小视频| 在线综合亚洲| 国产成人综合久久| 一级aaaa毛片| 国产乱码字幕精品高清av | 日韩理论电影中文字幕| 亚洲欧美日韩第一区| 四虎成人免费影院| 一本一本久久a久久综合精品| 久久99国产精品久久久久久久久| 日本熟妇成熟毛茸茸| 亚洲免费综合| 国产日韩中文字幕在线| 精品欧美一区二区精品少妇| 成人18精品视频| 欧美三级网色| 麻豆系列在线观看| 午夜成人免费电影| 中文字幕av不卡在线| 精品国模一区二区三区欧美 | 女人色偷偷aa久久天堂| 97国产suv精品一区二区62| 日日夜夜狠狠操| 国产一区二区免费在线| 精品国产乱码久久久久久久软件| 大乳在线免费观看| 亚洲精品欧美二区三区中文字幕| 欧美日韩视频免费| 波多视频一区| 日韩欧美激情在线| 亚洲自拍偷拍图| 欧美一区不卡| 日韩免费在线看| 国产福利视频导航| 国产欧美一区二区精品性色| 免费网站在线观看视频| 色猫猫成人app| 亚洲国产日韩一区| 欧美激情图片小说| 日韩激情一区二区| 国产精品美女黄网| 免费a级在线播放| 色综合久久88色综合天天| 涩多多在线观看| 精品午夜久久| 2019中文字幕在线| 丰满人妻一区二区| 中文字幕一区二区三中文字幕| 日韩中文字幕三区| 日韩在线亚洲| 久久精品国产69国产精品亚洲 | 蜜桃av在线免费观看| 欧美日韩国产精品一区| 国产精品19p| 欧美激情理论| 国产99视频在线观看| 日本激情一区二区| 亚洲欧美日本在线| 国产福利精品一区二区三区| 精品一区二区三| 欧美一区三区三区高中清蜜桃| www.天堂av.com| 亚洲视频一二区| 999在线观看| 日韩精品免费一区二区三区| 日韩免费av在线| 天天干,天天操,天天射| 亚洲一区电影777| 老司机av网站| 午夜欧美精品| 99国产视频在线| 亚洲第一图区| 日韩欧美国产高清| 欧美黑吊大战白妞| 国产精品一区二区三区乱码| 亚洲第一综合网站| 96sao精品免费视频观看| 中文字幕在线看视频国产欧美在线看完整 | www.成人黄色| 欧美一区免费| 国产成人精品一区二区三区福利 | 人人妻人人玩人人澡人人爽| 伊人一区二区三区| 蜜桃色一区二区三区| 欧美精品国产| 国产视频精品网| 麻豆国产在线| 亚洲剧情一区二区| 波多野结衣影片| 欧美国产日韩亚洲一区| 男女污污的视频| 不卡在线一区| 成人欧美一区二区三区在线| 亚洲婷婷噜噜| 亚洲国产精品va在线看黑人 | 国产综合精品一区二区三区| aa视频在线观看| 亚洲精品黄网在线观看| 69视频免费在线观看| 国产日韩精品久久久| 嫩草视频免费在线观看| 国产精品国码视频| 久久国产精品一区二区三区| 成人在线视频播放| 久久精品青青大伊人av| 亚洲精品久久久久久久久久 | 中文综合在线观看| 国内老熟妇对白xxxxhd| 同产精品九九九| 黄色片网站免费| 国产一区二区三区在线观看精品| 亚洲乱码日产精品bd在线观看| 国产精品国产| 国产成人黄色av| 麻豆传媒在线观看| 亚洲国产99精品国自产| 五月婷婷丁香在线| 樱桃国产成人精品视频| 韩国无码一区二区三区精品| 欧美a级理论片| 福利在线一区二区| 欧美先锋资源| 国产99在线免费| 91亚洲视频| 7777免费精品视频| 日本在线视频站| 亚洲精品国产电影| 97caocao| 色视频欧美一区二区三区| 国产精品三区在线观看| 久久精品欧美日韩精品 | 玖玖玖视频精品| 国产91亚洲精品| 久久香蕉av| 日韩网站在线观看| 水莓100国产免费av在线播放| 欧美日本在线视频| 四虎成人永久免费视频| 亚洲精品久久久蜜桃| 国产亚洲精品精品精品| 播五月开心婷婷综合| 色网站在线视频| 老牛影视一区二区三区| 日本a在线免费观看| 99国产精品一区二区| 欧美大香线蕉线伊人久久| 2020最新国产精品| 91免费精品国偷自产在线| 欧美电影网址| 91国产美女在线观看| 在线视频观看国产| 日韩午夜在线视频| 高清av电影在线观看| 国产视频精品免费播放| 亚洲第一视频在线| 欧美美女一区二区在线观看| 天堂网免费视频| 精品国产91乱高清在线观看| 99精品久久久久| 18成人在线观看| 毛片视频免费播放| 国产欧美日本一区视频| 野外性满足hd| 99这里只有久久精品视频| 欧美色图校园春色| 激情综合色播激情啊| 色播五月激情五月| 麻豆精品在线看| 牛夜精品久久久久久久| 久久亚洲二区| www.欧美日本| 日韩av一区二区在线影视| 欧美日韩一区二区在线免费观看| 99视频一区| 你懂的av在线| 国产模特精品视频久久久久| 人妻精品无码一区二区三区| 在线综合亚洲| 成年人免费在线播放| 久久一日本道色综合久久| 国产第一页视频| 天堂久久久久va久久久久| 欧美综合在线观看视频| 日韩国产精品久久| 免费看黄色一级大片| 美女视频黄久久| 午夜啪啪小视频| 国产自产v一区二区三区c| 992kp免费看片| 成人综合在线观看| 免费成人蒂法网站| 久久九九久精品国产免费直播| caopeng视频| 国产精品网友自拍| 国产极品美女在线| 亚洲国产日韩a在线播放性色| 国产性xxxx高清| 在线观看国产91| 亚洲午夜精品久久久| 日韩一区国产二区欧美三区| 粉嫩小泬无遮挡久久久久久| 亚洲精品视频免费在线观看| 91最新在线| 久久99精品国产99久久6尤物| av人人综合网| 国产精国产精品| 国产日本亚洲| 精品一区久久久| 久久精品高清| 亚洲精品无码国产| 久久九九99| 中文字幕在线视频一区二区三区 | 精品亚洲第一| 日韩av自拍| 九九热只有这里有精品| 日日摸夜夜添夜夜添亚洲女人| 午夜视频在线观| 26uuu国产电影一区二区| 国产91在线播放九色| 亚洲一级在线观看| 一区二区三区麻豆| 欧美成人精品3d动漫h| 毛片免费在线观看| 欧美大码xxxx| 国产精品伦一区二区| 国产欧美韩日| 日韩欧美高清| 国产美女网站在线观看| 精品在线视频一区| 素人fc2av清纯18岁| 亚洲精品日韩专区silk| 国产一区二区视频免费| 精品久久五月天| av播放在线| 69av在线视频| 日韩欧美中文字幕一区二区三区| 欧美亚洲另类在线一区二区三区| 亚洲女同中文字幕| 成人一区二区三| 成人美女视频在线观看18| 看黄色录像一级片| 色悠久久久久综合欧美99| 粉嫩小泬无遮挡久久久久久| xxxxx91麻豆| 电影亚洲精品噜噜在线观看| 国产乱码精品一区二区三区卡| 国产精品99一区二区三| 免费在线a视频| 成人激情视频网站| 粉嫩av性色av蜜臀av网站| 欧美日韩在线一区二区| 免费福利在线观看| 7m第一福利500精品视频| 一本一道久久a久久| 亚洲成人a**址| 久久人人精品| 黄色性生活一级片| 图片区日韩欧美亚洲| 精品久久久久中文慕人妻| 色偷偷av一区二区三区乱| 456亚洲精品成人影院| 精品一区在线播放| 亚洲国产一区二区三区高清| 中文字幕久久久久久久| 亚洲精品国久久99热| 一级特黄色大片| 国产亚洲a∨片在线观看| 中文日产幕无线码一区二区| 好吊色欧美一区二区三区视频| 国产主播一区| 成人做爰www看视频软件| 亚洲自拍偷拍图区| 亚洲奶汁xxxx哺乳期| 欧美日韩成人免费| 一区二区三区国产好| 丁香六月激情网| 大胆亚洲人体视频| 日韩网红少妇无码视频香港| 亚洲精品狠狠操| jk漫画禁漫成人入口| 日本欧美色综合网站免费| 老**午夜毛片一区二区三区| 一级片久久久久| 欧美日韩一区二区三区免费看| 91青青在线视频| 国产男人精品视频| 午夜激情久久| 国模大尺度视频| 亚洲国产精品久久久久秋霞影院 | 无码人妻丰满熟妇奶水区码| 亚洲美女免费精品视频在线观看| 黄色亚洲网站| 午夜精品福利一区二区| 激情综合色播五月| 久久99久久98精品免观看软件| 精品久久久久一区二区国产| 美女av在线免费看| 日本高清不卡三区| 久久精品久久久精品美女| 好吊日在线视频| 亚洲精品一区二区三区四区高清| 亚洲天堂电影| 亚洲精品成人久久久998| 国产一区二区网址| 国产极品在线播放| 亚洲情综合五月天| 高清不卡一区| 国产3p露脸普通话对白| 久久久91精品国产一区二区三区| 波多野结衣爱爱| 草民午夜欧美限制a级福利片| 国产精品18hdxxxⅹ在线| 日韩欧美精品在线观看视频| 国产精品久久久久久久久晋中| 成人av免费播放| 国产成人精品久久| 亚洲人成免费网站| 亚洲人人夜夜澡人人爽| 欧美精品久久一区二区三区| 1024在线看片你懂得| 日韩av一区二区三区在线观看| 国产一区二区三区日韩| 久久99国产综合精品免费| 色偷偷噜噜噜亚洲男人| 麻豆视频一区| 91视频这里只有精品| 亚洲福利一二三区| av基地在线| 狠狠色噜噜狠狠狠狠色吗综合| 美女精品一区二区| 五月婷婷激情网|