国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

高并發服務遇redis瓶頸引發time-wait事故

開發 前端 Redis
元旦期間 訂單業務線 告知 推送系統 無法正常收發消息,作為推送系統維護者的我正外面瀟灑,無法第一時間回去,直接讓 ops 幫忙重啟服務,一切好了起來,重啟果然是個大殺器。

摘要

元旦期間 訂單業務線 告知 推送系統 無法正常收發消息,作為推送系統維護者的我正外面瀟灑,無法第一時間回去,直接讓 ops 幫忙重啟服務,一切好了起來,重啟果然是個大殺器。由于推送系統本身是分布式部署,消息有做各種的可靠性策略,所以重啟是不會丟失消息事件的。

事后通過日志分析有大量的 redis 的報錯,十分鐘內有 16w 次的錯誤。日志的錯誤是 connect: cannot assign requested address 。該錯誤不是推送服務內部及 redis 庫返回的 error,而是系統回饋的 errno 錯誤。

這個錯誤是由于無法申請可用地址引起的,也就是無法申請到可用的 socket。

話說,元旦當天在線數和訂單量確實大了不少,往常推送系統的長連接客戶端在 35w,這次峰值飆到 50w 左右, 集群共 6 個節點,其中有 4 個節點每個都抗了 9w+ 的長連接。另外,推送的消息量也隨之翻倍。

分析

下面是 kibana 日志的統計,出錯的時間區間里有近 16w 次的 redis 報錯。

下面是出問題節點的 TCP 連接狀況,可以看到 established 在 6w,而 time-wait 連接干到 2w 多個。

為什么會產生這么多 time-wait?誰主動關閉就就有 time-wait,但推送系統除了協議解析失敗之外,其余情況都不會主動 close 客戶端,哪怕是鑒權失敗和弱網絡客戶端寫緩沖爆滿,事后通過日志也確定了不是推送系統自身產生的 tw。

另外,linux 主機被 ops 交付時應該有做內核調優初始化的,在開啟 tw_reuse 參數后,time-wait 是可以復用的。難道是沒開啟 reuse?

查看 sysctl.conf 的內核參數得知,果然 tcp_tw_reuse 參數沒有打開,不能快速地復用還處在 time-wait 狀態的地址,只能等待 time-wait 的超時關閉,rfc 協議里規定等待 2 分鐘左右,開啟 tw_reuse可在 1s 后復用該地址。另外 ip_local_port_range 端口范圍也不大,縮短了可用的連接范圍。

  1. sysctl  -a|egrep "tw_reuse|timestamp|local_port" 
  2.  
  3. net.ipv4.ip_local_port_range = 35768    60999 
  4. net.ipv4.tcp_timestamps = 1 
  5. net.ipv4.tcp_tw_reuse = 0 

所以,由于沒有可用地址才爆出了 connect: cannot assign requested address 錯誤。

內在問題

追究問題

上面是表象問題,來查查為什么會有這么多的 time-wait ?再說一遍,通常哪一端主動 close fd,哪一端就會產生 time-wait。事后通過 netstat 得知 time-wait 連接基本是來自 redis 主機。

下面是推送代碼中的連接池配置,空閑連接池只有 50,最大可以 new 的連接可以到 500 個。這代表當有大量請求時,企圖先從 size 為 50 的連接池里獲取連接,如果拿不到連接則 new 一個新連接,連接用完了后需要歸還連接池,如果這時候連接池已經滿了,那么該連接會主動進行 close 關閉。

  1. MaxIdle   = 50 
  2. MaxActive = 500 
  3. Wait      = false 

除此之外,還發現一個問題。有幾處 redis 的處理邏輯是異步的,比如每次收到心跳包都會 go 一個協程去更新 redis, 這也加劇了連接池的搶奪,改為同步代碼。這樣在一個連接上下文中同時只對一個 redis 連接操作。

解決方法

調大 golang redis client 的 maxIdle 連接池大小,避免了高下無空閑連接而新建連接和池子爆滿又不能歸還連接的尷尬場面。當 pool wait 為 true 時,意味著如果空閑池中沒有可用的連接,且當前已建立連接的連接數大于 MaxActive 最大空閑數,則一直阻塞等待其他人歸還連接。反之直接返回 “connection pool exhausted” 錯誤。

  1. MaxIdle   = 300 
  2. MaxActive = 400 
  3. Wait      = true 

redis 的 qps 性能瓶頸

redis 的性能一直是大家所稱贊的,在不使用 redis 6.0 multi io thread 下,QPS 一般可以在 13w 左右,如果使用多指令和 pipeline 的話,可以干到 40w 的 OPS 命令數,當然 qps 還是在 12w-13w 左右。

Redis QPS 高低跟 redis 版本和 cpu hz、cache 存在正比關系

根據我的經驗,在內網環境下且已實例化連接對象,單條 redis 指令請求耗時通常在 0.2ms 左右,200us 已經夠快了,但為什么還會有大量因 redis client 連接池無空閑連接而建立新連接的情況?

通過 grafana 監控分析 redis 集群,發現有幾個節點 QPS 已經到了 Redis 單實例性能瓶頸,QPS 干到了近 15w 左右。難怪不能快速處理來自業務的 redis 請求。這個瓶頸必然會影響請求的時延。請求的時延都高了,連接池不能及時返回連接池,所以就造成了文章開頭說的問題。總之,業務流量的暴增引起了一系列問題。

發現問題,那么就要解決問題,redis 的 qps 優化方案有兩步:

  • 擴容 redis 節點,遷移 slot 使其分擔流量
  • 盡量把程序中 redis 的請求改成批量模式

增加節點容易,批量也容易。起初在優化推送系統時,已經把同一個邏輯中的 redis 操作改為批量模式了。但問題來了,很多的 redis 操作在不同的邏輯塊里面,沒法合成一個 pipeline。

然后做了進一步的優化,把不同邏輯中的 redis 請求合并到一個 pipeline 里,優點在于提高了 redis 的吞吐,減少了 socket 系統調用、網絡中斷開銷,缺點是增加了邏輯復雜度,使用 channal 管道做隊列及通知增加了 runtime 調度開銷,pipeline worker 觸發條件是滿足 3 個 command 或 5ms 超時,定時器采用分段的時間輪。

對比優化修改前,cpu開銷減少了 3% 左右,壓測下redis qps平均降了 3w 左右差值,最多可以降到 7w 左右,當然概率上消息的時延會高了幾個ms。

實現的邏輯參考下圖,調用方把redis command和接收結果的chan推送到任務隊列中,然后由一個worker去消費,worker組裝多個redis cmd為pipeline,向redis發起請求并拿回結果,拆解結果集后,給每個命令對應的結果chan推送結果。調用方在推送任務到隊列后,就一直監聽傳輸結果的chan。

這個方案來自我在上家公司做推送系統的經驗,有興趣的朋友可以看看 PPT,內涵不少golang高并發經驗。

總結

推送系統設計之初是預計 20w 的長連接數,穩定后再無優化調整,也一直穩定跑在線上。后面隨著業務的暴漲,長連接數也一直跟著暴漲,現在日常穩定在 35w,出問題時暴到 50w,我們沒有因為業務暴增進行整條鏈路壓測及優化。

話說,如果對推送系統平時多上點心也不至于出這個問題。我曾經開發過相對高規格的推送系統,而現在公司的推送系統我是后接手的,由于它的架子一般,但業務性又太強,看著腦仁疼,所以就沒有推倒來重構。一直是在這個架子上添添補補,做了一些常規的性能優化。嗯,看來不能掉以輕心,免得績效離我遠去。

責任編輯:張燕妮 來源: 峰云就她了
相關推薦

2020-05-07 11:00:24

Go亂碼框架

2023-02-16 08:55:13

2019-12-27 11:13:24

高并發服務器邏輯

2021-08-26 05:04:38

TCP網絡HTTP

2020-11-11 10:00:13

NAT性能內核

2023-09-03 22:44:28

I/O高并發

2023-07-18 09:24:04

MySQL線程

2018-02-05 09:30:23

高性能高并發服務

2021-10-08 08:55:23

FacebookBGP工具

2025-08-27 10:05:00

Python高并發調用開發

2020-12-09 08:59:59

MongoDB復合索事故

2024-02-02 11:24:00

I/O高并發場景

2017-06-09 10:16:40

2022-10-25 18:00:00

Redis事務生產事故

2016-12-28 14:16:25

京東高并發系統設計

2025-11-28 09:15:03

2021-07-12 09:09:54

Go 連接池緩存

2021-09-30 14:23:23

服務器開發工具

2015-03-27 10:18:25

TCP協議CLOSE_WAIT狀服務器異常

2022-05-17 11:46:48

高并發服務數據庫
點贊
收藏

51CTO技術棧公眾號

亚洲а∨天堂久久精品喷水| 亚洲精品久久久一区二区三区 | 狠狠色一日本高清视频| 欧美日韩在线播放视频| 欧美精品乱人伦久久久久久| 各处沟厕大尺度偷拍女厕嘘嘘| 亚洲精品韩国| 国产成人综合精品| 9.1麻豆精品| 日韩欧美一区中文| 亚洲成人av在线影院| 久久九九久精品国产免费直播| 福利91精品一区二区三区| 在线日韩一区二区| 自拍偷拍一区二区三区四区| 国产乱码精品一区二区三| 国产伦精品一区二区三区在线| 免费精品国产| 九九热99久久久国产盗摄| 爱福利在线视频| 欧美视频你懂的| 在线电影av| 一区二区三区.www| 午夜激情福利在线| 99亚偷拍自图区亚洲| 日韩人妻一区二区三区蜜桃视频| 黄页网站一区| 成人黄色在线免费观看| 91亚洲人成网污www| 51ⅴ精品国产91久久久久久| 少妇高潮一区二区三区99| 亚洲国产成人av在线| 国内精品久久久久久野外| 日韩欧美主播在线| 四虎精品成人影院观看地址| 亚洲制服丝袜在线| 日韩男人天堂| 亚洲福利视频一区二区| fc2人成共享视频在线观看| 亚洲精品精品亚洲| 高清欧美精品xxxxx在线看| 国产精品灌醉下药二区| 午夜免费一区二区| 久久嫩草精品久久久久| 国产淫片免费看| 久久久精品2019中文字幕之3| 337p粉嫩大胆噜噜噜鲁| 国模大尺度一区二区三区| 一级毛片在线视频| 日韩午夜黄色| 精品一区2区三区| 一区视频在线| 国产亚洲欧美另类一区二区三区| 影音先锋一区| 日韩欧美一区二区三区四区 | 91麻豆123| 中文字幕视频在线免费观看| 亚洲欧洲精品一区二区精品久久久| 9久久婷婷国产综合精品性色| 国产精品初高中害羞小美女文| 欧美一区二区三区爽大粗免费| 亚洲最新在线观看| 久久综合久久久| 大白屁股一区二区视频| 真不卡电影网| 国产视频自拍一区| 日韩一级精品| 黑人巨大精品欧美一区二区奶水| 欧美成va人片在线观看| 麻豆国产一区二区三区四区| avav免费在线观看| 四色成人av永久网址| 国产精品三级久久久久三级| 精品一区二区三区毛片| 粉嫩av一区二区三区四区五区 | 婷婷伊人综合| 精品剧情在线观看| 久久久久久77777| 亚洲人成在线播放网站岛国 | 午夜精品久久久久久久久久| 亚洲高潮无码久久| 久久国产精品色| 日韩一区在线视频| 亚洲另类av| 欧美高清视频一区| av爱爱亚洲一区| 浪潮av在线| 在线播放91灌醉迷j高跟美女| 国产高清自产拍av在线| 欧美激情伊人电影| 欧美天堂亚洲电影院在线观看| 看全色黄大色大片| 1区2区3区国产精品| 黄色网址视频在线观看| 久久久精品影院| 精品9999| 无码人妻精品一区二区三区66| 国产原创精品视频| 久久久久久免费毛片精品| 最新av电影| 亚洲另类欧美自拍| 神马影视一区二区| 三年中文高清在线观看第6集| 亚洲欧洲韩国日本视频| 国产福利电影在线播放| 成人网在线免费观看| 99久久婷婷国产综合精品电影| 欧美新色视频| 欧美激情中文网| 毛片av一区二区三区| 在线视频色在线| xxxx欧美18另类的高清| 亚洲精品社区| 高清av影院| 日韩在线观看网站| 日本va欧美va精品| 九色网友自拍视频手机在线| 欧美高清视频在线| 狠狠狠色丁香婷婷综合久久五月| 最近中文字幕在线中文视频| 俺去亚洲欧洲欧美日韩| 日本亚洲视频在线| 国产色在线 com| 国产精品久久久91| 国产欧美在线观看一区| 亚洲精品成人图区| 乱色588欧美| 日本韩国欧美一区二区三区| 精品国产一区二区三区成人影院| 亚洲精品电影在线一区| 欧美日韩精品欧美日韩精品一| 欧美日韩一区二区综合| 四虎最新地址发布| 大胆人体色综合| 国产成人精品免费一区二区| av毛片在线免费| 狠狠色综合网站久久久久久久| 亚洲福利一二三区| 校花撩起jk露出白色内裤国产精品 | 亚洲黄色高清| 少妇**av毛片在线看| 久久精品久久久久| 久久99久久99精品免视看婷婷| 日本高清中文字幕在线| 国产欧美在线播放| 亚洲欧美日韩成人高清在线一区| 成人黄色免费短视频| 一区二区国产日产| 欧美成人欧美edvon| 国产精品毛片在线| 日本中文字幕在线观看| 国产伦精品一区二区三| 欧美在线一二三| 狠狠色丁香久久综合频道| 天堂成人在线| 国产欧美日韩中文| 欧美日韩国产麻豆| 国产精品久久久久久久久妇女| 黄页免费在线观看| 91精品久久久久久久久久另类 | 国模套图日韩精品一区二区| 日本不卡二区| 精品国产免费人成电影在线观看四季 | 性欧美freesex顶级少妇| 丝袜足脚交91精品| 亚洲成人久久久久| 韩日av一区二区| 久久久人成影片一区二区三区在哪下载 | 高清成人在线| 轻点好疼好大好爽视频| 一区二区亚洲精品国产| 99re66热这里只有精品3直播| 国产精品久久久久久久久久辛辛| 欧美国产激情视频| 欧美亚洲一区在线| 亚洲高清三级视频| 伊人精品视频| 国产理论在线| 久久无码高潮喷水| 2019精品视频| 天天综合网天天综合色| 精品91久久久久| 无码小电影在线观看网站免费| 激情综合在线观看| 国产精品成人品| 9191国产精品| 成人午夜又粗又硬又大| 日韩欧美天堂| 99免在线观看免费视频高清| 中文字幕一区二区三区有限公司| 亚洲一区999| 亚洲人成人一区二区在线观看| 天堂美国久久| heyzo高清在线| www.日日操| 91在线观看网站| 亚洲人午夜精品| 亚洲mv在线观看| 国产精品一区二区免费不卡| 杨幂一区二区三区免费看视频|