最近維護的redis cluster須要掃描每一個實例的內存使用率,首先咱們須要獲取實例已經使用的內存,獲取實例的最大內存配額,兩個值相比就能獲取到內存使用比例。python
實例的最大內存獲取方法: mysql
$REDIS_CLI -h $host -p $port config get maxmemory|tail -1|awk '{printf "%.4f\n", ($1 / 1024 /1024 /1024)}'
實例的已使用內存獲取方法:redis
$REDIS_CLI -h $host -p $port info memory|awk -F : '/used_memory:/ {printf "%.4f\n", ($2 /1024/1024/1024)}'
獲取到的值單位是字節,咱們須要更換成G爲了更方便的直觀的讀取。sql
最後使用已經使用的內存除以最大的內存就是內存使用的比例,若是超過90%則報警,會進行內存的擴容或數據的清理操做。bash
實例動態擴容內存的方法: blog
# 計算方法 , 例如要分配25G 則: 25*1024*1024*1024 = 26843545600 config set maxmemory 26843545600
由於集羣有太多的redis實例,我寫了一個掃描的腳本:ip
[root@xxx]# cat kv2HostList 192.0.171.150 192.0.171.152 192.0.171.153 192.0.171.155 192.0.171.156 192.0.171.158 192.0.171.159 192.0.171.160
#!/bin/bash ########################################### # # 檢查KV集羣裏面每一個實例的內存使用入庫 # ########################################### STARTPORT=8381 ENDPORT=8400 WORKDIR="/software/scripts/redisCheckMem" REDIS_HOST_FILE="$WORKDIR/kv2HostList" REDIS_CLI='/data/redisApp/bin/redis-cli' TMP_DB_FILE="$WORKDIR/DBfile.txt" # 定義內存使用比例的閥值 W_NUM='90' # Define color red() { echo -e "\033[31m $1 \033[0m" } green() { echo -e "\033[32m $1 \033[0m" } yellow() { echo -e "\033[33m $1 \033[0m" } AutoCheck() { datetime=`date +%Y%m%d%H` >$TMP_DB_FILE for host in `cat $REDIS_HOST_FILE` do echo "------------------------------------------------" for port in `seq $STARTPORT $ENDPORT` do Max_mem=$($REDIS_CLI -h $host -p $port config get maxmemory|tail -1|awk '{printf "%.4f\n", ($1 / 1024 /1024 /1024)}') Used_mem=$($REDIS_CLI -h $host -p $port info memory|awk -F : '/used_memory:/ {printf "%.4f\n", ($2 /1024/1024/1024)}') P_used_mem=$(awk "BEGIN{print $Used_mem/$Max_mem*100 }") yellow "Server:[$host:$port] MemoryInfo : " echo -e "\t Max_memory: $Max_mem G" echo -e "\t Used_memory: $Used_mem G" num=$(echo $P_used_mem|awk -F . '{print $1}') if [[ $num -gt $W_NUM ]];then red "\t Percentage used: $P_used_mem" red "\t Warring: 內存使用率太高,請關注!!!" else green "\t Percentage used: $P_used_mem" fi echo -n "insert into bdcsc2_clustermonitor_kv (date,ip,port,mem_use,kv) values " >> $TMP_DB_FILE echo "('$datetime','$host','$port','$Used_mem','kv2');" >> $TMP_DB_FILE sleep 0.5 done done } Report2db() { mysql -h192.168.0.47 -uroot -xxx-D report < $TMP_DB_FILE } case "$1" in check) AutoCheck ;; report2db) AutoCheck Report2db ;; *) echo "Usage: $0 {check | report2db}" esac