集羣規劃:node
三臺服務器各部署一個主節點、一個從節點,同一臺服務器上不是直接主從關係。linux
服務器c++ |
角色redis |
ip:端口shell |
node1centos |
master1/slave2 | 192.168.146.199:6379/192.168.146.199:6380bash |
node2服務器 |
master2/slave3app |
192.168.146.200:6379/192.168.146.200:6380tcp |
node3 |
master3/slave1 |
192.168.146.201:6379/192.168.146.201:6380 |
命令行開頭爲#表示在全部主機上操做,命令行開後爲具體主機名則表示在該主機上操做。
一、三臺服務器基礎設置
設置主機名:
# 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
二、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
三、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
四、修改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服務器配置文件拷貝到節點二、節點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
五、製做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服務器啓動關閉腳本拷貝到節點二、節點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
六、建立集羣
建立集羣,--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,對照下集羣角色表
七、查看集羣信息
查看集羣狀態:
[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
八、測試用例
[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)
九、目錄說明
# 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