Redis一键巡检脚本

今日分享redis一键巡检脚本,适用于单机、主从和cluster集群。大家有需要的可以先在本地测试,确认没问题后再运行于生产环境。

bash 复制代码
#!/bin/bash

# 检查是否安装了redis-cli工具,如果没有安装,则提示安装

if ! command -v redis-cli &> /dev/null

then

    echo "redis-cli could not be found, please install it first."

    exit 1

fi

# 设置你的Redis地址和端口,如果没有安装,则提示安装

REDIS_HOST="127.0.0.1"

REDIS_PORT=6379

# 登录的密码,如果没有设置密码,这一行可以注释掉

REDIS_PASSWORD="123456"

function check_redis() {
#这是核心函数,它接受主机、端口和密码作为参数并执行检查

    local HOST=$1

    local PORT=$2

    local PASSWORD=$3

    # 执行INFO命令,获取Redis状态信息

    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"

    # 打印内存使用情况

    MEMORY_USED=$(echo "$REDIS_INFO" | grep "used_memory_human" | cut -d':' -f2)

    echo "Memory Used: $MEMORY_USED"

    # 打印连接数

    TOTAL_CONNECTIONS=$(echo "$REDIS_INFO" | grep "total_connections_received" | cut -d':' -f2)

    echo "Total Connections Received: $TOTAL_CONNECTIONS"

    # 打印当前连接数

    CURRENT_CONNECTIONS=$(echo "$REDIS_INFO" | grep "connected_clients" | cut -d':' -f2)

    echo "Currently Connected Clients: $CURRENT_CONNECTIONS"

    # 打印Key数量

    TOTAL_KEYS=$(redis-cli -h $HOST -p $PORT -a $PASSWORD DBSIZE)

    echo "Total Keys: $TOTAL_KEYS"

    # 打印角色,判断是否为主从结构或集群

    ROLE=$(echo "$REDIS_INFO" | grep "role" | cut -d':' -f2)

    echo "Role: $ROLE"

    if [ "$ROLE" = "master" ]; then

        echo "This is a master instance."

        # 打印已连接的从节点数量以及信息

        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."

        # 打印主节点的信息

        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 "-----------------------------------------"

}

# 单机模式巡检

check_redis $REDIS_HOST $REDIS_PORT $REDIS_PASSWORD

# 如果有多个Redis实例(如主从结构或集群模式),可以增加相应的IP和端口

# 如:check_redis "192.168.1.1" 6380 "yourpassword"

# 集群模式巡检,通过集群节点遍历

# 获取集群节点列表

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

脚本说明:

  • 检查redis-cli工具是否安装:如果没有安装,则提示安装。
  • 基本配置:你需要设置Redis的地址、端口以及密码(如果有的话)。
  • 函数check_redis:这是核心函数,它接受主机、端口和密码作为参数并执行检查。
  • 内存使用、连接数、key数量检查:通过redis-cli INFO命令提取相关信息。
  • 区分单机、主从、集群:通过检查role字段来判断Redis的角色,并针对不同的角色执行相应的操作。
  • 单机模式巡检:对单个Redis实例执行检查。
  • 集群模式巡检:遍历所有集群节点进行检查。
相关推荐
爱学习的阿磊1 分钟前
使用Fabric自动化你的部署流程
jvm·数据库·python
摇滚侠5 分钟前
阿里云安装的 Redis 在什么位置,如何找到 Redis 的安装位置
redis·阿里云·云计算
枷锁—sha7 分钟前
【SRC】SQL注入快速判定与应对策略(一)
网络·数据库·sql·安全·网络安全·系统安全
惜分飞20 分钟前
ORA-600 kcratr_nab_less_than_odr和ORA-600 4193故障处理--惜分飞
数据库·oracle
chian-ocean20 分钟前
CANN 生态进阶:利用 `profiling-tools` 优化模型性能
数据库·mysql
m0_5500246324 分钟前
持续集成/持续部署(CI/CD) for Python
jvm·数据库·python
AC赳赳老秦24 分钟前
代码生成超越 GPT-4:DeepSeek-V4 编程任务实战与 2026 开发者效率提升指南
数据库·数据仓库·人工智能·科技·rabbitmq·memcache·deepseek
啦啦啦_999938 分钟前
Redis-2-queryFormat()方法
数据库·redis·缓存
爱喝白开水a40 分钟前
前端AI自动化测试:brower-use调研让大模型帮你做网页交互与测试
前端·人工智能·大模型·prompt·交互·agent·rag
董世昌4141 分钟前
深度解析ES6 Set与Map:相同点、核心差异及实战选型
前端·javascript·es6