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-02
Redis的Cluster集群搭建的實(shí)現(xiàn)步驟
本文檔只對(duì)Redis的Cluster集群做簡(jiǎn)單的介紹,并沒(méi)有對(duì)分布式系統(tǒng)的所涉及到的概念做深入的探討。感興趣的小伙伴們可以參考一下2021-07-07
Redis數(shù)據(jù)結(jié)構(gòu)之intset整數(shù)集合使用學(xué)習(xí)
這篇文章主要為大家介紹了Redis數(shù)據(jù)結(jié)構(gòu)之整數(shù)集合使用學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07
Redis 數(shù)據(jù)類(lèi)型Streams詳解
Redis Streams是Redis 5.0新增的數(shù)據(jù)類(lèi)型,提供了一種日志結(jié)構(gòu)化數(shù)據(jù)存儲(chǔ)方式,這種類(lèi)型適合用于構(gòu)建消息隊(duì)列、事件日志和處理時(shí)間序列數(shù)據(jù)的應(yīng)用,本文介紹Redis 數(shù)據(jù)類(lèi)型Streams相關(guān)知識(shí),感興趣的朋友一起看看吧2024-10-10
redis中RedissonLock如何實(shí)現(xiàn)等待鎖的
本文主要介紹了redis中RedissonLock如何實(shí)現(xiàn)等待鎖的,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11
Redis RDB快照持久化及寫(xiě)操作禁止問(wèn)題排查與解決
本文主要介紹了Redis RDB快照持久化及寫(xiě)操作禁止問(wèn)題排查與解決,由于?stop-writes-on-bgsave-error?選項(xiàng)處于啟用狀態(tài),所以寫(xiě)操作被禁止,下面就來(lái)介紹一下,感興趣的可以了解一下2025-04-04

