redis集群 服务器更换ip,怎么办,怎么更换redis集群的ip

redis集群 服务器更换ip,怎么办,怎么更换redis集群的ip

1、安装redis三主三从集群

参考 安装redis三主三从集群

在此例中 安装的redis集群信息如下

机器IP redis端口 redis安装目录 每个redis节点配置文件 每个redis节点的集群配置文件
192.168.2.162 6379 /usr/local/redis/ /usr/local/redis/conf/redis-cluster-6379.conf /data/redis7/cluster/6379/data/nodes-6379.conf
192.168.2.162 6380 /usr/local/redis/ /usr/local/redis/conf/redis-cluster-6380.conf /data/redis7/cluster/6380/data/nodes-6380.conf
192.168.2.164 6379 /usr/local/redis/ /usr/local/redis/conf/redis-cluster-6379.conf /data/redis7/cluster/6379/data/nodes-6379.conf
192.168.2.164 6380 /usr/local/redis/ /usr/local/redis/conf/redis-cluster-6380.conf /data/redis7/cluster/6380/data/nodes-6380.conf
192.168.2.168 6379 /usr/local/redis/ /usr/local/redis/conf/redis-cluster-6379.conf /data/redis7/cluster/6379/data/nodes-6379.conf
192.168.2.168 6380 /usr/local/redis/ /usr/local/redis/conf/redis-cluster-6380.conf /data/redis7/cluster/6380/data/nodes-6380.conf

2、正常状态的redis集群

查看redis集群状态

在redis集群中任一台机器上登录redis

bash 复制代码
redis-cli -c -p 6379

登入redis后 执行

bash 复制代码
auth 123456
cluster info
cluster nodes

其中cluster info 显示 cluster_state:ok 即表示集群状态正常。

redis存储的数据如下 用redisinsight连接redis集群中任一节点 查看redis存储的数据

3、更改redis集群服务器的ip 重启服务器 集群会down

把 192.168.2.162 改为 192.168.2.172

把 192.168.2.164 改为 192.168.2.174

把 192.168.2.168 改为 192.168.2.178

然后重启服务器

再次查看redis集群状态

在redis集群中任一台机器上登录redis

bash 复制代码
redis-cli -c -p 6379

登入redis后 执行

bash 复制代码
auth 123456
cluster info
cluster nodes

其中cluster info 显示 cluster_state:fail 即表示集群状态不正常。

发现redis集群已经处于down的状态。cluster_state:fail 就表示集群已经down了。

用redisinsight连接同样发现集群已经down了。

4、更改redis集群服务器的ip 重启服务器 集群down的原因

因为更改了服务器ip,服务器的IP和原来不一样了,但是记录集群状态的节点配置文件中的IP还仍然是以前的IP(因为集群是更改服务器IP之前创建的)

bash 复制代码
cat /data/redis7/cluster/6379/data/nodes-6379.conf
cat /data/redis7/cluster/6380/data/nodes-6380.conf

导致集群之间还认为是以前的IP,因此集群down了。

5、更改redis集群服务器的ip后,如何解决redis集群down的问题

有两种解决方法:

1、删除现有redis集群,创建新的redis集群,这种方法会破坏现有的redis数据,因此在生产服务器上不可用。

2、更改每个redis集群节点的节点配置文件,把IP对应改成新的IP,此种方法不损失redis数据,可以使用。

找到IP更改记录如下:

把 192.168.2.162 改为 192.168.2.172

把 192.168.2.164 改为 192.168.2.174

把 192.168.2.168 改为 192.168.2.178

更改每个redis集群节点的节点配置文件,把IP对应改成新的IP:

bash 复制代码
sed -i "s/192.168.2.162/192.168.2.172/g"  /data/redis7/cluster/6379/data/nodes-6379.conf /data/redis7/cluster/6380/data/nodes-6380.conf
sed -i "s/192.168.2.164/192.168.2.174/g"  /data/redis7/cluster/6379/data/nodes-6379.conf /data/redis7/cluster/6380/data/nodes-6380.conf
sed -i "s/192.168.2.168/192.168.2.178/g"  /data/redis7/cluster/6379/data/nodes-6379.conf /data/redis7/cluster/6380/data/nodes-6380.conf

查看更改后的节点配置文件 已经改成了新的IP

bash 复制代码
cat /data/redis7/cluster/6379/data/nodes-6379.conf
cat /data/redis7/cluster/6380/data/nodes-6380.conf

最后重启所有redis节点

bash 复制代码
/etc/init.d/redisd6379 stop
/etc/init.d/redisd6380 stop

/etc/init.d/redisd6379 start
/etc/init.d/redisd6380 start

再次查看redis集群状态

在redis集群中任一台机器上登录redis

bash 复制代码
redis-cli -c -p 6379

登入redis后 执行

bash 复制代码
auth 123456
cluster info
cluster nodes

其中cluster info 显示 cluster_state:ok 即表示集群状态正常。

用redisinsight连接redis集群master节点 查看redis存储的数据 和更改redis集群服务器IP之前的数据是一样的,没有损失数据。

相关推荐
我叫Double3 分钟前
简易版的EINO基于redis库的向量搜索项目v2
数据库·redis·bootstrap
Liangwei Lin34 分钟前
LeetCode 22. 括号生成
linux·运维·服务器
( •̀∀•́ )92036 分钟前
Linux 下部署 `social-auto-upload` 遇到的问题及完整解决方案
linux·运维·服务器
高锰酸钾_37 分钟前
计算机网络-链路层-差错控制
服务器·网络·计算机网络
HelloWorld工程师1 小时前
SSL证书在哪里可以免费且快速申请?
服务器·网络协议·ssl
techdashen1 小时前
dial9:给 Tokio 装上“飞行记录仪“
java·数据库·redis
号码认证服务2 小时前
如何让经销商接电话时看到“XX集团”?申请号码认证统一上线
服务器·经验分享·sql·华为·智能手机·华为云·云计算
原来是猿3 小时前
Linux - 【理解进程组、会话与作业控制】
linux·运维·服务器
2501_945837433 小时前
OpenClaw:重新定义 AI 智能体,从对话到执行的革命
服务器
wearegogog1233 小时前
Modbus TCP 通讯协议实现
服务器·网络·tcp/ip