Redis一鍵巡檢腳本的實(shí)現(xiàn)
今日分享redis一鍵巡檢腳本,適用于單機(jī)、主從和cluster集群。大家有需要的可以先在本地測(cè)試,確認(rèn)沒(méi)問(wèn)題后再運(yùn)行于生產(chǎn)環(huán)境。
#!/bin/bash # 檢查是否安裝了redis-cli工具,如果沒(méi)有安裝,則提示安裝 if ! command -v redis-cli &> /dev/null then echo "redis-cli could not be found, please install it first." exit 1 fi # 設(shè)置你的Redis地址和端口,如果沒(méi)有安裝,則提示安裝 REDIS_HOST="127.0.0.1" REDIS_PORT=6379 # 登錄的密碼,如果沒(méi)有設(shè)置密碼,這一行可以注釋掉 REDIS_PASSWORD="123456" function check_redis() { #這是核心函數(shù),它接受主機(jī)、端口和密碼作為參數(shù)并執(zhí)行檢查 local HOST=$1 local PORT=$2 local PASSWORD=$3 # 執(zhí)行INFO命令,獲取Redis狀態(tài)信息 if [ -z "$PASSWORD" ]; then REDIS_INFO=$(redis-cli -h $HOST -p $PORT INFO) else REDIS_INFO=$(redis-cli -h $HOST -p $PORT -a $PASSWORD INFO) fi echo "Checking Redis on $HOST:$PORT" # 打印內(nèi)存使用情況 MEMORY_USED=$(echo "$REDIS_INFO" | grep "used_memory_human" | cut -d':' -f2) echo "Memory Used: $MEMORY_USED" # 打印連接數(shù) TOTAL_CONNECTIONS=$(echo "$REDIS_INFO" | grep "total_connections_received" | cut -d':' -f2) echo "Total Connections Received: $TOTAL_CONNECTIONS" # 打印當(dāng)前連接數(shù) CURRENT_CONNECTIONS=$(echo "$REDIS_INFO" | grep "connected_clients" | cut -d':' -f2) echo "Currently Connected Clients: $CURRENT_CONNECTIONS" # 打印Key數(shù)量 TOTAL_KEYS=$(redis-cli -h $HOST -p $PORT -a $PASSWORD DBSIZE) echo "Total Keys: $TOTAL_KEYS" # 打印角色,判斷是否為主從結(jié)構(gòu)或集群 ROLE=$(echo "$REDIS_INFO" | grep "role" | cut -d':' -f2) echo "Role: $ROLE" if [ "$ROLE" = "master" ]; then echo "This is a master instance." # 打印已連接的從節(jié)點(diǎn)數(shù)量以及信息 CONNECTED_SLAVES=$(echo "$REDIS_INFO" | grep "connected_slaves" | cut -d':' -f2) echo "Connected Slaves: $CONNECTED_SLAVES" for i in $(seq 0 $(($CONNECTED_SLAVES - 1))) do SLAVE_INFO=$(echo "$REDIS_INFO" | grep "^slave${i}:") echo "Slave ${i}: $SLAVE_INFO" done elif [ "$ROLE" = "slave" ]; then echo "This is a slave instance." # 打印主節(jié)點(diǎn)的信息 MASTER_HOST=$(echo "$REDIS_INFO" | grep "master_host" | cut -d':' -f2) MASTER_PORT=$(echo "$REDIS_INFO" | grep "master_port" | cut -d':' -f2) echo "Connected to Master: $MASTER_HOST:$MASTER_PORT" fi echo "-----------------------------------------" } # 單機(jī)模式巡檢 check_redis $REDIS_HOST $REDIS_PORT $REDIS_PASSWORD # 如果有多個(gè)Redis實(shí)例(如主從結(jié)構(gòu)或集群模式),可以增加相應(yīng)的IP和端口 # 如:check_redis "192.168.1.1" 6380 "yourpassword" # 集群模式巡檢,通過(guò)集群節(jié)點(diǎn)遍歷 # 獲取集群節(jié)點(diǎn)列表 CLUSTER_NODES=$(redis-cli -h $REDIS_HOST -p $REDIS_PORT -a $REDIS_PASSWORD CLUSTER NODES | awk '{print $2}' | awk -F@ '{print $1}') for NODE in $CLUSTER_NODES; do NODE_IP=$(echo $NODE | cut -d':' -f1) NODE_PORT=$(echo $NODE | cut -d':' -f2) check_redis $NODE_IP $NODE_PORT $REDIS_PASSWORD done
腳本說(shuō)明:
- 檢查redis-cli工具是否安裝:如果沒(méi)有安裝,則提示安裝。
- 基本配置:你需要設(shè)置Redis的地址、端口以及密碼(如果有的話)。
- 函數(shù)check_redis:這是核心函數(shù),它接受主機(jī)、端口和密碼作為參數(shù)并執(zhí)行檢查。
- 內(nèi)存使用、連接數(shù)、key數(shù)量檢查:通過(guò)redis-cli INFO命令提取相關(guān)信息。
- 區(qū)分單機(jī)、主從、集群:通過(guò)檢查role字段來(lái)判斷Redis的角色,并針對(duì)不同的角色執(zhí)行相應(yīng)的操作。
- 單機(jī)模式巡檢:對(duì)單個(gè)Redis實(shí)例執(zhí)行檢查。
- 集群模式巡檢:遍歷所有集群節(jié)點(diǎn)進(jìn)行檢查。
到此這篇關(guān)于Redis一鍵巡檢腳本的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Redis一鍵巡檢內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
如何利用 Redis 實(shí)現(xiàn)接口頻次限制
這篇文章主要介紹了如何利用 Redis 實(shí)現(xiàn)接口頻次限制,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-02Redis的Cluster集群搭建的實(shí)現(xiàn)步驟
本文檔只對(duì)Redis的Cluster集群做簡(jiǎn)單的介紹,并沒(méi)有對(duì)分布式系統(tǒng)的所涉及到的概念做深入的探討。感興趣的小伙伴們可以參考一下2021-07-07Redis數(shù)據(jù)結(jié)構(gòu)之intset整數(shù)集合使用學(xué)習(xí)
這篇文章主要為大家介紹了Redis數(shù)據(jù)結(jié)構(gòu)之整數(shù)集合使用學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07redis中RedissonLock如何實(shí)現(xiàn)等待鎖的
本文主要介紹了redis中RedissonLock如何實(shí)現(xiàn)等待鎖的,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11Redis RDB快照持久化及寫操作禁止問(wèn)題排查與解決
本文主要介紹了Redis RDB快照持久化及寫操作禁止問(wèn)題排查與解決,由于?stop-writes-on-bgsave-error?選項(xiàng)處于啟用狀態(tài),所以寫操作被禁止,下面就來(lái)介紹一下,感興趣的可以了解一下2025-04-04