日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

高并发服务遇 redis 瓶颈引发的事故

發布時間:2024/4/11 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 高并发服务遇 redis 瓶颈引发的事故 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

元旦期間?訂單業務線?告知?推送系統?無法正常收發消息,作為推送系統維護者的我正外面瀟灑,無法第一時間回去,直接讓 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?端口范圍也不大,縮短了可用的連接范圍。

sysctl -a|egrep "tw_reuse|timestamp|local_port"net.ipv4.ip_local_port_range = 35768 60999 net.ipv4.tcp_timestamps = 1 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 關閉。

MaxIdle = 50 MaxActive = 500 Wait = false

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

解決方法

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

MaxIdle = 300 MaxActive = 400 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降到 7w 左右,當然概率上消息的時延會高了幾個ms。

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

這個方案來自我在上家公司做推送系統的經驗,有興趣的朋友可以看看 PPT,內涵不少高并發經驗。分布式推送系統設計與實現[1]

總結

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

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

References

[1]?分布式推送系統設計與實現:?https://github.com/rfyiamcool/share_ppt#%E5%88%86%E5%B8%83%E5%BC%8F%E8%A1%8C%E6%83%85%E6%8E%A8%E9%80%81%E7%B3%BB%E7%BB%9Fgolang

總結

以上是生活随笔為你收集整理的高并发服务遇 redis 瓶颈引发的事故的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产第8页| 欧美一级网 | 国产 日韩 欧美 精品 | 天天婷婷| 一区二区三区视频免费观看 | 97热久久| 欧美特级黄色大片 | 国产精品熟女久久久久久 | 日韩三级视频在线 | 在线视频免费观看你懂的 | 久色婷婷| 亚洲欧美日韩在线不卡 | 中文字幕一区二区人妻痴汉电车 | 黄色成年人视频 | 无码一区二区三区在线观看 | 老司机久久精品视频 | 超碰国产97 | 亚洲久爱 | 欧美亚洲黄色 | 98久久| 亚洲免费a | 久久精品丝袜 | 成年人晚上看的视频 | 日韩3p | 亚洲成年人专区 | 你懂的网站在线 | 野花av | 色窝窝无码一区二区三区成人网站 | 欧美视频一区二区在线观看 | 中文字幕日本人妻久久久免费 | 午夜黄色av | 天天干天天干天天 | 黄频视频在线观看 | 人妻91麻豆一区二区三区 | 欧色丰满女同hd | 双性人做受视频 | 91在线免费视频观看 | 人妻一区二区三区视频 | 成人动漫在线观看视频 | 干爹你真棒插曲免费 | 久热免费在线视频 | 国产精品999在线观看 | 九九九九精品 | 欧美精品欧美极品欧美激情 | 久久精品激情 | 日本激情影院 | 成人免费黄色大片 | 91肉色超薄丝袜脚交一区二区 | 2019自拍偷拍| 天天操夜夜爱 | 高清一区二区三区四区 | 精品久久不卡 | 久久久高清 | 久久久久99精品成人片三人毛片 | 国产一区二区在 | 制服.丝袜.亚洲.中文.综合 | 欧美黑人巨大xxx极品 | 色.www | 淫视频网站 | 五月天婷婷伊人 | 性欧美videossex精品 | 欧美性生活一区二区三区 | 色一涩 | 自拍视频一区二区 | 久久亚洲私人国产精品va | 不卡中文字幕av | 姑娘第5集高清在线观看 | 天天操天天插天天干 | 91丨porny丨中文 | 国产精视频| 九九久视频 | 特黄特色大片免费 | 国产精品欧美在线 | 中文字字幕| 麻豆视频网页 | 96日本xxxxxⅹxxx17 | 极品美女高潮出白浆 | 美女视频黄是免费 | 日日色综合 | 另类综合在线 | 亚洲精品推荐 | 亚洲啪av永久无码精品放毛片 | 久久久亚洲精品视频 | 国产精彩视频在线观看 | 黄色在线免费观看 | 国产精品老牛影院99av | 亚洲另类天堂 | 99国产在线播放 | 国产夫妇交换聚会群4p | 一级成人毛片 | 日本美女性爱视频 | 欧美视频一区在线观看 | 亚洲熟女一区二区三区 | www.色在线观看 | 黄色男人的天堂 | 黄色欧美在线观看 | 成人一级黄色片 | 国产日韩视频一区 | 少妇av在线 |