redis監控

来源:http://www.cnblogs.com/lxmhhy/archive/2016/11/06/6034549.html
-Advertisement-
Play Games

公司的redis業務很多,redis監控自然也是DB監控的一大模塊,包括採集、展示、監控告警。本文主要介紹redis監控的主要指標和採集方法。 一、Redis監控系統邏輯 1、DBA通過前臺頁面添加redis監控,填寫ip和埠,配置閾值、負責人等信息 2、前臺調用自動調度平臺介面將redis監控採 ...


  公司的redis業務很多,redis監控自然也是DB監控的一大模塊,包括採集、展示、監控告警。本文主要介紹redis監控的主要指標和採集方法。

  一、Redis監控系統邏輯

  1、DBA通過前臺頁面添加redis監控,填寫ip和埠,配置閾值、負責人等信息

  2、前臺調用自動調度平臺介面將redis監控採集Agent發送到目標機器上的固定文件夾,並添加crond,每分鐘運行(採集Agent包含採集程式和ip埠信息文件)

  3、redis監控Agent採集相關指標通過http介面上報到mysql伺服器(目標機器無法直接連接mysql)

  4、前臺讀取mysql數據進行展示

  5、解析程式每分鐘通過讀取配置信息和Agent上報的數據進行解析併發送告警(Rtx/Wechat/Sms)給指定負責人

  二、採集指標和命令

  1、redis服務進程 ip-port

約定所有redis服務都必須以ip1(內網ip)來綁定,每個機器只有一個ip1,可以有多個埠,即多個redis實例。採集程式讀取ip埠信息文件來判斷有多少個實例

ps aux | grep -E "redis-server.*$port"

約定所有redis客戶端安裝標準路徑是

REDISPATH_CLI="/usr/local/redis/bin/redis-cli"

如果發現不是標準路徑會有 No such file or directory 的提示,則採集程式會在每天早上10點發送Rtx彈窗給DBA(DBA也可以根據前臺頁面圖表展示來判斷該採集器有無上報數據,無上報數據則可以上機查看採集器日誌)

採集器使用下麵的命令來採集redis實例的所有信息,然後根據信息篩選出需要的指標上報到mysql

$REDISPATH_CLI -h ${agentIp} -p ${port} info > ${tmpFile} 2>&1 

如果redis實例沒有綁定在ip1或者127.0.0.1上面則會提示 Connection refused

  2、連接客戶數 

grep "connected_clients:" ${tmpFile} | awk -F ":" '{print $2}'

  3、阻塞連接數 

grep "blocked_clients:" ${tmpFile} | awk -F ":" '{print $2}'

  4、redis占用記憶體,單位Byte轉成MB

grep "used_memory:" ${tmpFile} | awk -F ":" '{print $2}' | awk '{printf "%.2f",$1/1024/1024}'

  5、記憶體峰值,單位Byte轉成MB

grep "used_memory_peak:" ${tmpFile} | awk -F ":" '{print $2}' | awk '{printf "%.2f",$1/1024/1024}'

  6、主從角色

grep "role:" ${tmpFile} | awk -F ":" '{print $2}'   #  master(主),slave(從)

  7、master_link_status

grep "master_link_status:" ${tmpFile} | awk -F ":" '{print $2}'   # up down

down:Master已經不可訪問了,Slave依然運行良好,並且保留有AOF與RDB文件

  8、執行命令總數和qps

grep "total_commands_processed:" ${tmpFile} | awk -F ":" '{print $2}'

計算qps需要計算兩次 total_commands_processed,然後除以時間差。邏輯是第一分鐘將total_commands_processed的值和當時採集該值的時間保存到last.cache中,第二分鐘採集的時候獲取值和時間,和上次相減得到兩個差值相除即可。

  9、上報時間

reportTime=`date +'%Y-%m-%d %H:%M:00'`

時間的秒數是0,方便前臺畫圖展示

  三、解析告警

分析上報的指標是否異常,根據reportTime判斷Agent心跳情況,將狀態和異常信息存入mysql,發送告警給相關負責人。資料庫分表如下:

  redisMonitor庫:配置表redisConf、當前狀態redisCurrentStatus、異常信息表redisDisplay

  歷史庫按月分庫,按照ip分表,保存redis採集器上報數據,Ex: redisStatus167872716

  四、前臺展示

  1、異常頁面

  2、狀態頁面

原創文章,轉載請備註原文地址 http://www.cnblogs.com/lxmhhy/p/6034549.html

知識交流討論請加qq:1130010617。謝謝合作。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 核心提示:本部分一個9道題,給定時間50小時。屬於fcc前端學習的“高級編程腳本”題,對於初學者來說,確實算是“高級”了。如果只想著閉門造車,50小時確實也不過分。就題目設的坑和古怪規則來說,估計趕得上實際的情形。有些題目,可能要有一點數理基礎才行。 1.如果傳入字元串是一個有效的美國電話號碼,則返 ...
  • 這是一個利用jquery動態插入輸入內容的代碼。 html代碼: <div title="分表2" class="ui-edit" style="padding:20px;" > <div id="optionContainer" class="ftitle">經驗實體信息(必填,多個網商店鋪需加行 ...
  • 在數據傳輸過程中,json是以文本,即字元串的形式傳遞的,而JS操作的是JSON對象,所以,JSON對象和JSON字元串之間的相互轉換是關鍵。例如:JSON字元串:var str1 = '{ "name": "cxh", "sex": "man" }'; JSON對象:var str2 = { "n ...
  • 上大學學習軟體設計有一年多了,明年五月就要畢業了。回頭看看發現自己其實挺差勁的,不能因為在一群不學習的人中就覺得自己多厲害。其實自己也是個廢物呢:) 最近開通了博客所以就整理了一下筆記,在這裡發佈一下自己以前學習css時總是記不住去翻書又很常用的屬性,都是一些很基礎的,大神輕噴。很適合初學者多看看。 ...
  • html部分(圖片都是本地,自己需要改動圖片) <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> <link rel="stylesheet" type="text/css" href="css/one.css" ...
  • https://github.com/Trinea/android-open-project ...
  • 以上就介紹了比SwipeRefreshLayout更漂亮和強大的下拉刷新控制項:Android-MaterialRefreshLayout 1.xml 2.Java 3、參考網站 https://github.com/android-cjj/Android-MaterialRefreshLayout/ ...
  • SQL 對大小寫不敏感! 數據操作語言 (DML): select - 從資料庫表中獲取數據 update - 更新資料庫表中的數據 delete - 從資料庫表中刪除數據 insert into - 向資料庫表中插入數據 數據定義語言 (DDL): create database - 創建新資料庫 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...