Redis一键巡检脚本

2024-06-03 08:36
文章标签 redis 一键 脚本 巡检

本文主要是介绍Redis一键巡检脚本,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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

#!/bin/bash# 检查是否安装了redis-cli工具,如果没有安装,则提示安装if ! command -v redis-cli &> /dev/nullthenecho "redis-cli could not be found, please install it first."exit 1fi# 设置你的Redis地址和端口,如果没有安装,则提示安装REDIS_HOST="127.0.0.1"REDIS_PORT=6379# 登录的密码,如果没有设置密码,这一行可以注释掉REDIS_PASSWORD="123456"function check_redis() {
#这是核心函数,它接受主机、端口和密码作为参数并执行检查local HOST=$1local PORT=$2local PASSWORD=$3# 执行INFO命令,获取Redis状态信息if [ -z "$PASSWORD" ]; thenREDIS_INFO=$(redis-cli -h $HOST -p $PORT INFO)elseREDIS_INFO=$(redis-cli -h $HOST -p $PORT -a $PASSWORD INFO)fiecho "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" ]; thenecho "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)))doSLAVE_INFO=$(echo "$REDIS_INFO" | grep "^slave${i}:")echo "Slave ${i}: $SLAVE_INFO"doneelif [ "$ROLE" = "slave" ]; thenecho "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"fiecho "-----------------------------------------"}# 单机模式巡检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; doNODE_IP=$(echo $NODE | cut -d':' -f1)NODE_PORT=$(echo $NODE | cut -d':' -f2)check_redis $NODE_IP $NODE_PORT $REDIS_PASSWORDdone

脚本说明:

  • 检查redis-cli工具是否安装:如果没有安装,则提示安装。
  • 基本配置:你需要设置Redis的地址、端口以及密码(如果有的话)。
  • 函数check_redis:这是核心函数,它接受主机、端口和密码作为参数并执行检查。
  • 内存使用、连接数、key数量检查:通过redis-cli INFO命令提取相关信息。
  • 区分单机、主从、集群:通过检查role字段来判断Redis的角色,并针对不同的角色执行相应的操作。
  • 单机模式巡检:对单个Redis实例执行检查。
  • 集群模式巡检:遍历所有集群节点进行检查。

这篇关于Redis一键巡检脚本的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1026489

相关文章

Redis 命令详解与实战案例

《Redis命令详解与实战案例》本文详细介绍了Redis的基础知识、核心数据结构与命令、高级功能与命令、最佳实践与性能优化,以及实战应用场景,通过实战案例,展示了如何使用Redis构建高性能应用系统... 目录Redis 命令详解与实战案例一、Redis 基础介绍二、Redis 核心数据结构与命令1. 字符

SpringBoot18 redis的配置方法

《SpringBoot18redis的配置方法》本文介绍在SpringBoot项目中集成和使用Redis的方法,包括添加依赖、配置文件、自定义序列化方式、使用方式、实际使用示例、常见操作总结以及注意... 目录一、Spring Boot 中使用 Redis1. 添加依赖2. 配置文件3. Redis 配置类

Redis中群集三种模式的实现

《Redis中群集三种模式的实现》Redis群集有三种模式,分别是主从同步/复制、哨兵模式、Cluster,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1. Redis三种模式概述2、Redis 主从复制2.1 主从复制的作用2.2 主从复制流程2

Redis的安全机制详细介绍及配置方法

《Redis的安全机制详细介绍及配置方法》本文介绍Redis安全机制的配置方法,包括绑定IP地址、设置密码、保护模式、禁用危险命令、防火墙限制、TLS加密、客户端连接限制、最大内存使用和日志审计等,通... 目录1. 绑定 IP 地址2. 设置密码3. 保护模式4. 禁用危险命令5. 通过防火墙限制访问6.

深入理解Redis线程模型的原理及使用

《深入理解Redis线程模型的原理及使用》Redis的线程模型整体还是多线程的,只是后台执行指令的核心线程是单线程的,整个线程模型可以理解为还是以单线程为主,基于这种单线程为主的线程模型,不同客户端的... 目录1 Redis是单线程www.chinasem.cn还是多线程2 Redis如何保证指令原子性2.

Docker + Redis 部署集群的实现步骤

《Docker+Redis部署集群的实现步骤》本文详细介绍了在三台服务器上部署高可用Redis集群的完整流程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录一、环境准备1. 服务器规划(3 台服务器)2. 防火墙配置(三台服务器均执行)3. 安装 docke

Redis中删除策略的几种实现方式

《Redis中删除策略的几种实现方式》本文详细介绍了Redis的过期键删除策略和内存淘汰策略,过期键删除策略包括定时删除、惰性删除和定期删除,具有一定的参考价值,感兴趣的可以了解一下... 目录前言一、设计背景:为什么需要删除策略?二、第一类:过期键的 3 种核心删除策略1. 定时删除(Timed Dele

Spring Boot整合Redis注解实现增删改查功能(Redis注解使用)

《SpringBoot整合Redis注解实现增删改查功能(Redis注解使用)》文章介绍了如何使用SpringBoot整合Redis注解实现增删改查功能,包括配置、实体类、Repository、Se... 目录配置Redis连接定义实体类创建Repository接口增删改查操作示例插入数据查询数据删除数据更

Redis 基本数据类型和使用详解

《Redis基本数据类型和使用详解》String是Redis最基本的数据类型,一个键对应一个值,它的功能十分强大,可以存储字符串、整数、浮点数等多种数据格式,本文给大家介绍Redis基本数据类型和... 目录一、Redis 入门介绍二、Redis 的五大基本数据类型2.1 String 类型2.2 Hash

Redis中Hash从使用过程到原理说明

《Redis中Hash从使用过程到原理说明》RedisHash结构用于存储字段-值对,适合对象数据,支持HSET、HGET等命令,采用ziplist或hashtable编码,通过渐进式rehash优化... 目录一、开篇:Hash就像超市的货架二、Hash的基本使用1. 常用命令示例2. Java操作示例三