在CentOS上配置Redis主从复制涉及几个步骤。以下是一个基本的指南:
首先,确保你已经在两台服务器(一台作为主节点,另一台作为从节点)上安装了Redis。
sudo yum install epel-release
sudo yum install redis
编辑主节点的Redis配置文件 /etc/redis.conf:
sudo vi /etc/redis.conf
找到并修改以下配置项:
bind 0.0.0.0 # 允许所有IP访问,根据需要修改
port 6379 # 默认端口
requirepass your_master_password # 设置主节点密码
保存并退出编辑器。
编辑从节点的Redis配置文件 /etc/redis.conf:
sudo vi /etc/redis.conf
找到并修改以下配置项:
bind 0.0.0.0 # 允许所有IP访问,根据需要修改
port 6379 # 默认端口
slaveof your_master_ip 6379 # 设置主节点的IP和端口
masterauth your_master_password # 设置主节点密码
保存并退出编辑器。
在两台服务器上分别重启Redis服务以应用配置更改:
sudo systemctl restart redis
在主节点上检查Redis是否正常运行:
redis-cli -h localhost -p 6379 -a your_master_password info replication
你应该看到类似以下的输出,表明主节点正在运行并且没有从节点:
# Replication
role:master
connected_slaves:0
slave0:ip=127.0.0.1,port=6379,state=online,offset=0,lag=0
在从节点上检查Redis是否正常运行并且已经连接到主节点:
redis-cli -h localhost -p 6379 -a your_master_password info replication
你应该看到类似以下的输出,表明从节点已经成功连接到主节点:
# Replication
role:slave
master_host:your_master_ip
master_port:6379
master_link_status:up
你可以通过以下方式测试读写分离:
redis-cli -h localhost -p 6379 -a your_master_password set test_key "Hello, Master!"
redis-cli -h localhost -p 6379 -a your_master_password get test_key
如果从节点返回了 “Hello, Master!”,则说明读写分离配置成功。
通过以上步骤,你应该能够在CentOS上成功配置Redis主从复制。