三台机器分布
192.168.189.129 // master的角色
192.168.189.130 // slave1的角色
192.168.189.131 // salve2的角色
三台服务器安装redis
1 2 3 4 5 6 |
cd /usr/local/src
tar zxf redis-5.0.6.tar.gz
cd redis-5.0.6
make && make isntall
cp redis.conf /etc/
|
编译主redis的配置文件
1 2 3 4 5 |
vim /etc/redis.conf
---------------------------------------------
bind 0.0.0.0
daemonize yes //后台运行
---------------------------------------------
|
编译从redis两台机器的配置文件
1 2 3 |
bind 0.0.0.0
daemonize yes
replicaof 192.168.18.140 6379 //这条是注释的在原配置文件中可以自己解开注释 写的是主的redis的IP和地址
|
redis服务开启
1 |
redis-server /etc/redis.conf
|
1 2 3 4 5 |
[root@localhost redis-5.0.5]# redis-cli //执行这条命令可以看看到身份 是master 有两个从的主机
127.0.0.1:6379> info
# Replication
role:master
connected_slaves:2 //从的redis的个数
|
从机器:
1 2 |
[root@localhost ~]# redis-cli
127.0.0.1:6379> info
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
# Replication
role:slave #角色为从
master_host:127.0.0.1
master_port:6379 #端口
master_link_status:down
master_last_io_seconds_ago:-1
master_sync_in_progress:0
slave_repl_offset:12431
master_link_down_since_seconds:254
slave_priority:100
slave_read_only:1
connected_slaves:0
master_replid:c19f164c73069fbf600c31c999ee3d67363c946e
master_replid2:0000000000000000000000000000000000000000
master_repl_offset:12431
second_repl_offset:-1
repl_backlog_active:1
repl_backlog_size:1048576
repl_backlog_first_byte_offset:1
repl_backlog_histlen:12431
|
在主redis中写入数据, 在从的redis查看是否可以获得
1 2 3 4 5 6 |
在主写入数据
127.0.0.1:6379> set name zhou
OK
在从上可以获取到
127.0.0.1:6379> get name
"zhou"
|
开启redis的哨兵模式
接下来的操作可以完成redis的哨兵模式 哨兵模式的完成实在redis的主从基础上完成的。
三台redis都做如下操作
1 |
cp /usr/local/src/redis-5.0.6/sentinel.conf /etc/
|
1 2 3 4 5 |
vim /etc/sentinel.conf
---------------------------------------------------------
protected -mode no
sentinel monitor mymaster 192.168.189.130 6379 2
----------------------------------------------------------
|
1 |
redis-server /etc/sentinel.conf --sentinel #哨兵模式的开启命令
|
测试哨兵
关闭redis主的服务器,可以看到从机器的选举过程表示成功
效果演示:
redis操作命令总结:
1 2 3 4 5 |
redis-server /etc/redis.conf #开启redis服务
redis-cli #进入redis进行存储数据或读取数据
redis-server /etc/sentinel.conf --sentinel #哨兵的枚举与查看
|