Centos7.6部署redis6.0.8集群(redis cluster模式)

Stella981
• 阅读 714

集群规划:

三台服务器各部署一个主节点、一个从节点,同一台服务器上不是直接主从关系。

服务器

角色

ip:端口

node1

master1/slave2

192.168.146.199:6379/192.168.146.199:6380

node2

master2/slave3

192.168.146.200:6379/192.168.146.200:6380

node3

master3/slave1

192.168.146.201:6379/192.168.146.201:6380

命令行开头为#表示在所有主机上操作,命令行开后为具体主机名则表示在该主机上操作。

1、三台服务器基础设置

设置主机名:

# hostnamectl --static set-hostname node1/node2/node3

配置映射:

# vi /etc/hosts
192.168.146.199 node1
192.168.146.200 node2
192.168.146.201 node3

时区调整,时间校准:

# date -R
# timedatectl set-timezone Asia/Shanghai
# yum -y install ntp
# ntpdate ntp1.aliyun.com

安装wget:

$ yum install -y wget

关闭selinux:

# vi /etc/sysconfig/selinux
SELINUX=disabled

重启服务器并验证:

# getenforce
Disabled

设置防火墙

# firewall-cmd --zone=public --add-port=6379/tcp --permanent
success
# firewall-cmd --zone=public --add-port=6380/tcp --permanent
success
# firewall-cmd --zone=public --add-port=16379/tcp --permanent
success
# firewall-cmd --zone=public --add-port=16380/tcp --permanent
success
# firewall-cmd --permanent --zone=public --list-ports
6379/tcp 6380/tcp 16379/tcp 16380/tcp
# firewall-cmd --reload
success

2、gcc版本问题避免

# yum -y install gcc tcl
# yum -y install centos-release-scl
# yum -y install devtoolset-9-gcc devtoolset-9-gcc-c++ devtoolset-9-binutils

查看gcc版本:

# gcc -v

scl只是临时启用,退出shell后会恢复原系统gcc版本:
# scl enable devtoolset-9 bash

如下命令表示永久启用:
# echo "source /opt/rh/devtoolset-9/enable" >> /etc/profile

查看gcc版本:
# gcc -v

3、redis安装

# cd /opt
# wget http://download.redis.io/releases/redis-6.0.8.tar.gz
# tar zxvf redis-6.0.8.tar.gz
# cd redis-6.0.8
# make MALLOC=libc
# make test

将执行文件弄到环境变量所在目录:

# make install

临时启动测试:

# redis-server
# ps -ef | grep redis
root      17830   8648  0 23:14 pts/0    00:00:00 redis-server *:6379
# redis-cli
127.0.0.1:6379> set foo bar
OK
127.0.0.1:6379> get foo
"bar"

创建日志文件存放目录:

# mkdir -p /var/log/redis/

创建工作目录:

# mkdir -p /var/lib/redis/6379
# mkdir -p /var/lib/redis/6380

4、修改redis配置文件

节点1上修改配置文件:

[root@node1 ~]# cd /opt/redis-6.0.8
[root@node1 redis-6.0.8]# mkdir cluster
[root@node1 redis-6.0.8]# cp -i redis.conf cluster/redis-6379.conf
[root@node1 redis-6.0.8]# vi cluster/redis-6379.conf
port 6379
daemonize yes
dir /var/lib/redis/6379
logfile "/var/log/redis/redis-6379.log"
cluster-enabled yes
cluster-config-file nodes-6379.conf
cluster-node-timeout 15000
cluster-require-full-coverage no
appendonly yes

#port 6379    #端口
#daemonize yes    #守护进程
#dir /var/lib/redis/6379    #数据存储目录
#logfile "/var/log/redis/redis-6379.log"    #日志存储目录
#cluster-enabled yes    #开启集群
#cluster-config-file nodes-6379.conf
#cluster-node-timeout 15000
#cluster-require-full-coverage no
#appendonly yes    #持久化

将节点1服务器配置文件拷贝到节点2、节点3:

[root@node1 redis-6.0.8]# scp -r /opt/redis-6.0.8/cluster/ root@192.168.146.200:/opt/redis-6.0.8/
[root@node1 redis-6.0.8]# scp -r /opt/redis-6.0.8/cluster/ root@192.168.146.201:/opt/redis-6.0.8/

修改节点服务器监听IP地址:

[root@node1 opt]# cd /opt/redis-6.0.8
[root@node1 opt]# sed -i 's/127.0.0.1/192.168.146.199/g' cluster/redis-6379.conf

[root@node2 opt]# cd /opt/redis-6.0.8
[root@node2 opt]# sed -i 's/127.0.0.1/192.168.146.200/g' cluster/redis-6379.conf

[root@node3 opt]# cd /opt/redis-6.0.8
[root@node3 opt]# sed -i 's/127.0.0.1/192.168.146.201/g' cluster/redis-6379.conf

根据7379生成6380配置文件:

# sed 's/6379/6380/g' cluster/redis-6379.conf > cluster/redis-6380.conf

5、制作redis启动配置文件

[root@node1 cluster]# cd /opt/redis-6.0.8

制作启动脚本:

[root@node1 redis-6.0.8]# vi cluster_start.sh
redis-server cluster/redis-6379.conf
redis-server cluster/redis-6380.conf
[root@node1 redis-6.0.8]# chmod +x cluster_start.sh

制作关闭脚本:

[root@node1 redis-6.0.8]# vi cluster_shutdown.sh
pgrep redis-server | xargs -exec kill -9
[root@node1 redis-6.0.8]# chmod +x cluster_shutdown.sh

将节点1服务器启动关闭脚本拷贝到节点2、节点3:

[root@node1 redis-6.0.8]# scp -r /opt/redis-6.0.8/cluster_*.sh root@192.168.146.200:/opt/redis-6.0.8/
[root@node1 redis-6.0.8]# scp -r /opt/redis-6.0.8/cluster_*.sh root@192.168.146.201:/opt/redis-6.0.8/

启动redis:

# ./cluster_start.sh
# ps -ef|grep redis
root      26731      1  0 01:23 ?        00:00:00 redis-server 192.168.146.199:6379 [cluster]
root      26736      1  0 01:23 ?        00:00:00 redis-server 192.168.146.199:6380 [cluster]
root      26741   8648  0 01:23 pts/0    00:00:00 grep --color=auto redis

关闭redis:

# ./cluster_shutdown.sh

6、创建集群

创建集群,--cluster-replicas 1代表3主3从,前3个代表3个master,后3个代表3个slave。通过该方式创建的带有从节点的机器不能够自己手动指定主节点

[root@node1 redis-6.0.8]# redis-cli --cluster create 192.168.146.199:6379 192.168.146.200:6379 192.168.146.201:6379 192.168.146.199:6380 192.168.146.200:6380 192.168.146.201:6380 --cluster-replicas 1
>>> Performing hash slots allocation on 6 nodes...
Master[0] -> Slots 0 - 5460
Master[1] -> Slots 5461 - 10922
Master[2] -> Slots 10923 - 16383
Adding replica 192.168.146.200:6380 to 192.168.146.199:6379
Adding replica 192.168.146.201:6380 to 192.168.146.200:6379
Adding replica 192.168.146.199:6380 to 192.168.146.201:6379
M: 7a0af6d896222c60b582c8ecb16d1369a5ef33b4 192.168.146.199:6379
   slots:[0-5460] (5461 slots) master
M: 825e26272e82f4900f2b99bb05cc8efa87f2c238 192.168.146.200:6379
   slots:[5461-10922] (5462 slots) master
M: e52b4a755ab35381931ba89cf0399ac2657c0d93 192.168.146.201:6379
   slots:[10923-16383] (5461 slots) master
S: caed0e5b336cb31d6d6b29874170075a21e6923b 192.168.146.199:6380
   replicates e52b4a755ab35381931ba89cf0399ac2657c0d93
S: c155299d628e705565915cec624faf67946556a5 192.168.146.200:6380
   replicates 7a0af6d896222c60b582c8ecb16d1369a5ef33b4
S: d9bca2b5cabb426aa2e296e6696e60e35ef4bebe 192.168.146.201:6380
   replicates 825e26272e82f4900f2b99bb05cc8efa87f2c238
Can I set the above configuration? (type 'yes' to accept): yes
>>> Nodes configuration updated
>>> Assign a different config epoch to each node
>>> Sending CLUSTER MEET messages to join the cluster
Waiting for the cluster to join
.
>>> Performing Cluster Check (using node 192.168.146.199:6379)
M: 7a0af6d896222c60b582c8ecb16d1369a5ef33b4 192.168.146.199:6379
   slots:[0-5460] (5461 slots) master
   1 additional replica(s)
S: c155299d628e705565915cec624faf67946556a5 192.168.146.200:6380
   slots: (0 slots) slave
   replicates 7a0af6d896222c60b582c8ecb16d1369a5ef33b4
M: 825e26272e82f4900f2b99bb05cc8efa87f2c238 192.168.146.200:6379
   slots:[5461-10922] (5462 slots) master
   1 additional replica(s)
S: d9bca2b5cabb426aa2e296e6696e60e35ef4bebe 192.168.146.201:6380
   slots: (0 slots) slave
   replicates 825e26272e82f4900f2b99bb05cc8efa87f2c238
M: e52b4a755ab35381931ba89cf0399ac2657c0d93 192.168.146.201:6379
   slots:[10923-16383] (5461 slots) master
   1 additional replica(s)
S: caed0e5b336cb31d6d6b29874170075a21e6923b 192.168.146.199:6380
   slots: (0 slots) slave
   replicates e52b4a755ab35381931ba89cf0399ac2657c0d93
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.
备注:注意看M和S,对照下集群角色表

7、查看集群信息

查看集群状态:

[root@node1 redis-6.0.8]# redis-cli -c -h 192.168.146.199 -p 6379 cluster info
cluster_state:ok
cluster_slots_assigned:16384
cluster_slots_ok:16384
cluster_slots_pfail:0
cluster_slots_fail:0
cluster_known_nodes:6
cluster_size:3
cluster_current_epoch:6
cluster_my_epoch:1
cluster_stats_messages_ping_sent:482
cluster_stats_messages_pong_sent:488
cluster_stats_messages_sent:970
cluster_stats_messages_ping_received:483
cluster_stats_messages_pong_received:482
cluster_stats_messages_meet_received:5
cluster_stats_messages_received:970

查看集群节点信息:

[root@node1 redis-6.0.8]# redis-cli -c -h 192.168.146.199 -p 6379 cluster nodes
7a0af6d896222c60b582c8ecb16d1369a5ef33b4 192.168.146.199:6379@16379 myself,master - 0 1600191841000 1 connected 0-5460
c155299d628e705565915cec624faf67946556a5 192.168.146.200:6380@16380 slave 7a0af6d896222c60b582c8ecb16d1369a5ef33b4 0 1600191840159 1 connected
825e26272e82f4900f2b99bb05cc8efa87f2c238 192.168.146.200:6379@16379 master - 0 1600191842184 2 connected 5461-10922
d9bca2b5cabb426aa2e296e6696e60e35ef4bebe 192.168.146.201:6380@16380 slave 825e26272e82f4900f2b99bb05cc8efa87f2c238 0 1600191843194 2 connected
e52b4a755ab35381931ba89cf0399ac2657c0d93 192.168.146.201:6379@16379 master - 0 1600191842000 3 connected 10923-16383
caed0e5b336cb31d6d6b29874170075a21e6923b 192.168.146.199:6380@16380 slave e52b4a755ab35381931ba89cf0399ac2657c0d93 0 1600191844207 3 connected

8、测试用例

[root@node1 redis-6.0.8]# redis-cli -c -h 192.168.146.199 -p 6379
192.168.146.199:6379> set name node1
-> Redirected to slot [5798] located at 192.168.146.200:6379
OK

[root@node2 redis-6.0.8]# redis-cli -c -h 192.168.146.200 -p 6379
192.168.146.200:6379> get name
"node1"

root@node3 redis-6.0.8]# redis-cli -c -h 192.168.146.201 -p 6379
192.168.146.201:6379> get name
-> Redirected to slot [5798] located at 192.168.146.200:6379
"node1"
192.168.146.201:6379> del name
-> Redirected to slot [5798] located at 192.168.146.200:6379
(integer) 1
192.168.146.201:6379> get name
-> Redirected to slot [5798] located at 192.168.146.200:6379
(nil)

9、目录说明

# cd /var/lib/redis/6379
# ll
total 8
-rw-r--r-- 1 root root   0 Sep 16 01:21 appendonly.aof
-rw-r--r-- 1 root root 175 Sep 16 01:35 dump.rdb
-rw-r--r-- 1 root root 817 Sep 16 01:36 nodes-6379.conf

# cd /var/lib/redis/6380
# ll
total 12
-rw-r--r-- 1 root root 149 Sep 16 01:52 appendonly.aof
-rw-r--r-- 1 root root 191 Sep 16 01:52 dump.rdb
-rw-r--r-- 1 root root 817 Sep 16 01:36 nodes-6380.conf
点赞
收藏
评论区
推荐文章
秃头王路飞 秃头王路飞
5个月前
webpack5手撸vue2脚手架
webpack5手撸vue相信工作个12年的小伙伴们在面试的时候多多少少怕被问到关于webpack方面的知识,本菜鸟最近闲来无事,就尝试了手撸了下vue2的脚手架,第一次发帖实在是没有经验,望海涵。languageJavaScript"name":"vuecliversion2","version":"1.0.0","desc
浅梦一笑 浅梦一笑
5个月前
初学 Python 需要安装哪些软件?超级实用,小白必看!
编程这个东西是真的奇妙。对于懂得的人来说,会觉得这个工具是多么的好用、有趣,而对于小白来说,就如同大山一样。其实这个都可以理解,大家都是这样过来的。那么接下来就说一下python相关的东西吧,并说一下我对编程的理解。本人也是小白一名,如有不对的地方,还请各位大神指出01名词解释:如果在编程方面接触的比较少,那么对于软件这一块,有几个名词一定要了解,比如开发环
blmius blmius
1年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
技术小男生 技术小男生
5个月前
linux环境jdk环境变量配置
1:编辑系统配置文件vi/etc/profile2:按字母键i进入编辑模式,在最底部添加内容:JAVAHOME/opt/jdk1.8.0152CLASSPATH.:$JAVAHOME/lib/dt.jar:$JAVAHOME/lib/tools.jarPATH$JAVAHOME/bin:$PATH3:生效配置
光头强的博客 光头强的博客
5个月前
Java面向对象试题
1、请创建一个Animal动物类,要求有方法eat()方法,方法输出一条语句“吃东西”。创建一个接口A,接口里有一个抽象方法fly()。创建一个Bird类继承Animal类并实现接口A里的方法输出一条有语句“鸟儿飞翔”,重写eat()方法输出一条语句“鸟儿吃虫”。在Test类中向上转型创建b对象,调用eat方法。然后向下转型调用eat()方
刚刚好 刚刚好
5个月前
css问题
1、在IOS中图片不显示(给图片加了圆角或者img没有父级)<div<imgsrc""/</divdiv{width:20px;height:20px;borderradius:20px;overflow:h
小森森 小森森
5个月前
校园表白墙微信小程序V1.0 SayLove -基于微信云开发-一键快速搭建,开箱即用
后续会继续更新,敬请期待2.0全新版本欢迎添加左边的微信一起探讨!项目地址:(https://www.aliyun.com/activity/daily/bestoffer?userCodesskuuw5n)\2.Bug修复更新日历2.情侣脸功能大家不要使用了,现在阿里云的接口已经要收费了(土豪请随意),\\和注意
晴空闲云 晴空闲云
5个月前
css中box-sizing解放盒子实际宽高计算
我们知道传统的盒子模型,如果增加内边距padding和边框border,那么会撑大整个盒子,造成盒子的宽度不好计算,在实务中特别不方便。boxsizing可以设置盒模型的方式,可以很好的设置固定宽高的盒模型。盒子宽高计算假如我们设置如下盒子:宽度和高度均为200px,那么这会这个盒子实际的宽高就都是200px。但是当我们设置这个盒子的边框和内间距的时候,那
艾木酱 艾木酱
5个月前
快速入门|使用MemFire Cloud构建React Native应用程序
MemFireCloud是一款提供云数据库,用户可以创建云数据库,并对数据库进行管理,还可以对数据库进行备份操作。它还提供后端即服务,用户可以在1分钟内新建一个应用,使用自动生成的API和SDK,访问云数据库、对象存储、用户认证与授权等功能,可专
helloworld_28799839 helloworld_28799839
5个月前
常用知识整理
Javascript判断对象是否为空jsObject.keys(myObject).length0经常使用的三元运算我们经常遇到处理表格列状态字段如status的时候可以用到vue