Redis哨兵模式集群(一主两从)
- 0.说明
- 1.准备:
- 2.安装
- 1.配置redis.conf
- 2.配置sentinel.conf
- 3.设置自启动
- 1.设置redis自启动
- 2.设置sentinel自启动
- 4.查询同步状态
- 5.测试集群
- 6.集群操作
0.说明
IP地址 | 主机名 | 别名 | 说明 |
192.168.1.117 | 主机 | ||
192.168.1.119 | 从机 | ||
192.168.1.121 | 从机 |
1.准备:
- 添加用户权限
# 创建一个gid为246的redis用户组
groupadd -g 246 redis
# 创建一个uid为246,gid为246的redis 用户
useradd -u 246 -g 246 redis
passwd redis [password]
# 查看用户uid
id redis
# 删除用户组
# userdel -rf redis
# 查看用户列表
# cut -d : -f 1 /etc/passwd
- 设置文件夹权限
chown -R redis redis-5.0.3
chgrp -R redis redis-5.0.3
- 安装gcc环境
由于redis是用C写的, 所以要有gcc环境
#查看是否安装gcc
rpm -qa | grep gcc
#若无安装,则进行安装
yum install gcc
2.安装
#安装redis
cd /opt
tar xzf redis-5.0.3.tar.gz
cd redis-5.0.3
make
#报错则用:
make MALLOC=libc
1.配置redis.conf
主节点
vi /opt/redis-5.0.3/redis.conf
bind 0.0.0.0
# 禁止外网访问redis,启用,则只能够通过lookback ip(127.0.0.1)访问Redis
protected-mode no
# 开启守护进程模式
daemonize yes
# 默认/var/run只有root用户有权限写入,所以改成/var/tmp所有用户有权限写入
pidfile /var/tmp/redis_6379.pid
# 日志文件目录
logfile "/opt/redis-5.0.3/redis_6379.log"
# 生成数据文件目录
dir /opt/redis-5.0.3
# 设置密码
requirepass [password]
# 主节点密码
masterauth [password]
从节点
vi /opt/redis-5.0.3/redis.conf
bind 0.0.0.0
# 禁止外网访问redis,启用,则只能够通过lookback ip(127.0.0.1)访问Redis
protected-mode no
# 开启守护进程模式
daemonize yes
# 默认/var/run只有root用户有权限写入,所以改成/var/tmp所有用户有权限写入
pidfile /var/tmp/redis_6379.pid
# 日志文件目录
logfile "/opt/redis-5.0.3/redis.log"
# 生成数据文件目录
dir /opt/redis-5.0.3
# 设置密码
requirepass [password]
# 主节点认证密码
masterauth [password]
slaveof 192.168.1.117 6379
2.配置sentinel.conf
主节点和从节点
vi /opt/redis-5.0.3/sentinel.conf
daemonize yes
pidfile "/var/tmp/redis-sentinel.pid"
logfile "/opt/redis-5.0.3/redis-sentinel.log"
dir "/opt/redis-5.0.3"
# sentinel监控的master的名字叫做mymaster,地址为192.168.1.117 6379
# 1代表,当集群中有1个sentinel认为master死了时,才能真正认为该master已经不可用了
# 注:必须放在其他配置上面
sentinel monitor mymaster 192.168.1.117 6379 1
sentinel auth-pass mymaster [password]
# sentinel会向master发送心跳超时时间
sentinel down-after-milliseconds mymaster 10000
# failover主从切换时,最多可以有多少个slave同时对新的master进行同步
sentinel parallel-syncs mymaster 1
# 执行failover等待时间
sentinel failover-timeout mymaster 10000
3.设置自启动
1.设置redis自启动
# 复制官方自启动脚本到系统执行目录
cp /opt/redis-5.0.3/utils/redis_init_script /etc/init.d/redis
修改redis自启动配置:
vi /etc/init.d/redis
配置如下:
#!/bin/sh
#
# Simple Redis init.d script conceived to work on Linux systems
# as it does use of the /proc filesystem.
### BEGIN INIT INFO
# Provides: redis_6379
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Redis data structure server
# Description: Redis data structure server. See https://redis.io
### END INIT INFO
REDISPORT=6379
# 设置执行工具路径
EXEC=/opt/redis-5.0.3/src/redis-server
# 设置cli执行工具路径
CLIEXEC=/opt/redis-5.0.3/src/redis-cli
# 修改pid为其他用户可写目录
PIDFILE=/var/tmp/redis_${REDISPORT}.pid
# 指定配置文件目录
CONF="/opt/redis-5.0.3/redis.conf"
case "$1" in
start)
if [ -f $PIDFILE ]
then
echo "$PIDFILE exists, process is already running or crashed"
else
echo "Starting Redis server..."
# 使用redis用户执行
sudo -u redis $EXEC $CONF
fi
;;
stop)
if [ ! -f $PIDFILE ]
then
echo "$PIDFILE does not exist, process is not running"
else
PID=$(cat $PIDFILE)
echo "Stopping ..."
# 使用redis用户加密码shutdown
sudo -u redis $CLIEXEC -a "[password]" -p $REDISPORT shutdown
while [ -x /proc/${PID} ]
do
echo "Waiting for Redis to shutdown ..."
sleep 1
done
echo "Redis stopped"
fi
;;
# 加重启命令
restart|force-reload)
${0} stop
${0} start
;;
*)
echo "Please use start or stop as first argument"
;;
esac
- 加入自启动:
chkconfig --add redis
服务器意外宕机,pid文件未删除,还是无法自启动
- 启动redis服务:
# 修改配置以后只能root用户操作,但进程属于redis用户
service redis start
ps aux | grep redis
service redis stop
2.设置sentinel自启动
# 复制官方自启动脚本到系统执行目录
cp /opt/redis-5.0.3/utils/redis_init_script /etc/init.d/redis-sentinel
修改redis-sentinel自启动配置:
vi /etc/init.d/redis-sentinel
配置如下:
#!/bin/sh
#
# Simple Redis init.d script conceived to work on Linux systems
# as it does use of the /proc filesystem.
### BEGIN INIT INFO
# Provides: redis_6379
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Redis data structure server
# Description: Redis data structure server. See https://redis.io
### END INIT INFO
REDISPORT=6379
# 设置哨兵执行工具路径
EXEC=/opt/redis-5.0.3/src/redis-sentinel
# 设置cli执行工具路径
CLIEXEC=/opt/redis-5.0.3/src/redis-cli
# 修改pid为其他用户可写目录
PIDFILE=/var/tmp/redis-sentinel.pid
# 指定配置文件目录
CONF="/opt/redis-5.0.3/sentinel.conf"
case "$1" in
start)
if [ -f $PIDFILE ]
then
echo "$PIDFILE exists, process is already running or crashed"
else
echo "Starting Redis server..."
sudo -u redis $EXEC $CONF
fi
;;
stop)
if [ ! -f $PIDFILE ]
then
echo "$PIDFILE does not exist, process is not running"
else
PID=$(cat $PIDFILE)
echo "Stopping ..."
# 直接杀掉进程,删掉进程ID文件
kill -9 $(cat ${PIDFILE}) && rm -f ${PIDFILE}
while [ -x /proc/${PID} ]
do
echo "Waiting for Redis to shutdown ..."
sleep 1
done
echo "Redis stopped"
fi
;;
*)
echo "Please use start or stop as first argument"
;;
esac
- 加入自启动:
chkconfig --add redis-sentinel
服务器意外宕机,pid文件未删除,还是无法自启动
- 启动redis-sentinel服务
# 修改配置以后只能root用户操作,以redis用户启动redis-sentinel
service redis-sentinel start
ps aux | grep redis
service redis-sentinel stop
4.查询同步状态
cd /opt/redis-5.0.3/src
./redis-cli -h 192.168.1.117 -p 6379
> info replication
> auth [password]
> exit
5.测试集群
./redis-cli -h 192.168.1.117 -c -p 6379
set hello world
./redis-cli -h 192.168.1.119 -c -p 6379
./redis-cli -h 192.168.1.121 -c -p 6379
get hello
6.集群操作
# 查询redis允许的最大连接数
config get maxclients
# 当前的redis连接数
info clients
# 获取客户端列表
client list
# 设置当前连接点redis的名称
client setname [name]
# 查看当前连接的名称
client getname
# 杀死指定连接
client kill ip:port
# 查看client的IP
./redis-cli -h 192.168.1.117 -p 6379 -a [password] client list | awk '{print $2}'| cut -d = -f 2| cut -d : -f 1 | sort | uniq -c | sort -rn