www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > > 架構師社區(qū)
[導讀]周一早上剛上班,突然大量用戶反饋進入網(wǎng)頁很慢,登錄服務器一看,Redis調用時間嚴重超時,這樣高速的緩存反而變成了短板,由于數(shù)據(jù)一直沒有返回,導致了請求響應變慢。

來源:https://www.sevenyuan.cn/


周一早上剛上班,突然大量用戶反饋進入網(wǎng)頁很慢,登錄服務器一看,Redis調用時間嚴重超時,這樣高速的緩存反而變成了短板,由于數(shù)據(jù)一直沒有返回,導致了請求響應變慢。

網(wǎng)頁監(jiān)控

通過阿里的 Grafana 監(jiān)控,服務器的 CPU 負載、內存、網(wǎng)絡輸入輸出都挺正常的,所以肯定是 Redis 出現(xiàn)了問題。

我們應用使用的是單節(jié)點的 32M 16GB 的阿里云 Redis,登錄網(wǎng)頁監(jiān)控看性能監(jiān)控,發(fā)現(xiàn) CPU 使用情況飆升到100%?。?!

QPS 雖然從 1000 多升到 6000,但是遠遠低于極限值,連接數(shù)量從 0 升到 3000,也是遠遠低于極限值(可能用戶剛上班,開始有請求,然后響應延遲,導致命令隊列數(shù)量過多,打開很多連接)。

臨時方案:先租用一臺新的 Redis 服務器,更換應用服務器的 Redis 配置,重啟應用,避免影響更多用戶。

然后我們繼續(xù)跟蹤 Redis 的具體情況。

服務器命令監(jiān)控

登錄 Redis-cli,通過 info 命令查看服務器狀態(tài)和命令統(tǒng)計,祥哥總結了兩點異常點:

查詢 redis 慢指令 slowlog,排行前十的指令均為keys *,并且耗時嚴重,在當前業(yè)務流量下執(zhí)行keys*,一定會阻塞業(yè)務,導致查詢慢,cpu 高的。值得注意的是應用層面沒有開放keys *接口,不排查有后臺人為或后臺程序觸發(fā)該指令。

查看 redis 指令執(zhí)行情況,排除exec,flushall等指令,業(yè)務使用指令中,耗時嚴重的有 setnx 有7.5千萬次調用平均耗時 6s,setex 有8.4千萬次調用平均耗時7.33s,del 有2.6億次調用平均耗時69s,hmset 有1億次調用平均耗時 64s,hmget 有6.8千萬次調用平均耗時 9s,hgetall 有14億次調用平均耗時 205s,keys 有2千萬次調用平均耗時 3740s。

通常而言,這些指令耗時與 value 大小呈正比,所以可以排查這些指令相關的數(shù)據(jù)近期有沒有較大增長?;蛘呓谟袥]有業(yè)務改造,會頻繁使用上述指令,也會造成 cpu 高。

通過 info commandstats 可以查看 Redis 命令統(tǒng)計信息,其中命令格式是

cmdstat_XXX: calls=XXX,usec=XXX,usec_per_call=XXX
調用次數(shù)、耗費CPU時間、每個命令平均耗費CPU(單位為微秒)

通過 slowlog 命令查看慢命令(默認超過 10ms 就會被記錄到日志,只會記錄其命令執(zhí)行的時間,不包含 IO 往返操作,也不記錄單由網(wǎng)絡延遲引起的響應慢)

(當時也忘了截圖,所以就介紹一下 slowlog 怎么看)

xxxxx> slowlog get 10
 3) 1) (integer) 411           
    2) (integer) 1545386469     
    3) (integer) 232663          
    4) 1) "keys" 2) "mecury:*" 

圖中各字段表示的是:

  • 1=日志的唯一標識符
  • 2=命令的執(zhí)行時間點,以UNIX時間戳表示
  • 3=查詢命令執(zhí)行時間,以微妙為單位,中的是230ms
  • 4=執(zhí)行的命令,以數(shù)組的形式排列。完整的命令是 keys mucury:*

所以通過這些參數(shù),基本可以確定,是突然有大量的keys *命令導致CPU負載升高,導致響應延遲,問題我們應用中沒有開放keys *命令Σ(o?д?o?)

最后將這些統(tǒng)計結果和慢命令發(fā)到研發(fā)群,發(fā)現(xiàn)是別的應用配置配成了我們的Redis,然后他們有個業(yè)務場景是爬數(shù)據(jù),突然涌入大量的調用,不斷的keys *,導致我們的Redis不堪重負,于是將配置修改正確,不再調用我們的Redis。

總結

  • Redis 抖動可以先看網(wǎng)頁監(jiān)控(阿里云做的真好?。?/span>
  • 通過命令查看 Redis 指令狀態(tài)和慢命令的情況
  • 考慮優(yōu)化 Redis 在代碼中的使用情況
  • 如果流量繼續(xù)上升,需要考慮一下升級了=-=

免責聲明:本文內容由21ic獲得授權后發(fā)布,版權歸原作者所有,本平臺僅提供信息存儲服務。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: 驅動電源

在工業(yè)自動化蓬勃發(fā)展的當下,工業(yè)電機作為核心動力設備,其驅動電源的性能直接關系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅動電源設計中至關重要的兩個環(huán)節(jié),集成化方案的設計成為提升電機驅動性能的關鍵。

關鍵字: 工業(yè)電機 驅動電源

LED 驅動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設備的使用壽命。然而,在實際應用中,LED 驅動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設計、生...

關鍵字: 驅動電源 照明系統(tǒng) 散熱

根據(jù)LED驅動電源的公式,電感內電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關鍵字: LED 設計 驅動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產業(yè)的重要發(fā)展方向。電動汽車的核心技術之一是電機驅動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅動系統(tǒng)中的關鍵元件,其性能直接影響到電動汽車的動力性能和...

關鍵字: 電動汽車 新能源 驅動電源

在現(xiàn)代城市建設中,街道及停車場照明作為基礎設施的重要組成部分,其質量和效率直接關系到城市的公共安全、居民生活質量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關鍵字: 發(fā)光二極管 驅動電源 LED

LED通用照明設計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關鍵字: LED 驅動電源 功率因數(shù)校正

在LED照明技術日益普及的今天,LED驅動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關鍵字: LED照明技術 電磁干擾 驅動電源

開關電源具有效率高的特性,而且開關電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅動電源

關鍵字: LED 驅動電源 開關電源

LED驅動電源是把電源供應轉換為特定的電壓電流以驅動LED發(fā)光的電壓轉換器,通常情況下:LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: LED 隧道燈 驅動電源
關閉