DB監控-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
更多相關文章
  • 1、通過SQL(結構化查詢語言)操作資料庫: DDL:數據定義語言,創建庫,創建表,選擇; DML:數據操作語言,完成數據增刪改; DQL:數據查詢語言,完成數據查詢; DCL:數據控制語言,授權、回收許可權;2、資料庫連接: mysql -uroot或者mysql -uroot -p密碼; SQL不 ...
  • 今天整理模型,用的 "Navicat Data Modeler”生成.sql,然後在mysql中執行,發現錯誤: [Err] 1215 - Cannot add foreign key constraint 開始以為是外鍵類型和長度等不一致,後來才發現主表用的是“MyISAM”換成 “innoDB”... ...
  • 介紹 KEY分區和HASH分區相似,但是KEY分區支持除text和BLOB之外的所有數據類型的分區,而HASH分區只支持數字分區,KEY分區不允許使用用戶自定義的表達式進行分區,KEY分區使用系統提供的HASH函數進行分區。當表中存在主鍵或者唯一鍵時,如果創建key分區時沒有指定欄位系統預設會首選主 ...
  • Mysql監控屬於DB監控的模塊之一,包括採集、展示、監控告警。本文主要介紹Mysql監控的主要指標和採集方法。 Mysql監控和Redis監控的邏輯類似,可參考文章《Redis監控》。 DBA前臺添加Mysql監控時系統會調用自動調度平臺介面將Mysql監控的加密賬戶密碼和ip埠等信息發送至目標 ...
  • 基本上分三步走 1,添加fcitx的鍵盤輸入法系統,因為sogou是基於fcitx的,而系統預設的是iBus; 2,安裝sogou輸入法; 3,設置系統參數及一些註意點。 第一步、添加fcitx鍵盤輸入法系統 ①先添加以下源 sudo add-apt-repository ppa:fcitx-tea ...
  • http://www.jxedt.com/wen/bukao/3174956875936366607.htmlhttp://www.jxedt.com/wen/bukao/3174956867599728675.htmlhttp://www.jxedt.com/wen/bukao/317495687 ...
  • ln是linux中又一個非常重要命令,它的功能是為某一個文件在另外一個位置建立一個同步的鏈接,分為軟鏈接、硬鏈接。軟鏈接相當於windows的快捷方式,下麵是使用方法和示例 ln是linux中又一個非常重要命令,它的功能是為某一個文件在另外一個位置建立一個同步的鏈接.當我們需要在不同的目錄,用到相同 ...
  • DOS下windows系統查看wifi密碼 首先,按win+R鍵,win鍵如下 彈出框中輸入cmd 在彈出界面輸入 netsh wlan show profiles 你可以看到你鏈接過的所有wifi名稱(我只鏈接了一個wifi) 選擇你要查看的wifi密碼,輸入netsh wlan show pro ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...