本文主要是介绍Redis哨兵模式及集群配置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
文章目录
- 1 Redis安装和配置
- 1.1 编译环境配置
- 1.2 Redis安装
- 1.2.1 使用SecureFX把Redis安装包传到centos
- 1.2.2 解压redis安装包
- 1.2.3 编译
- 1.2.4 安装
- 1.2.5 Copy文件
- 2 启动Redis以及客户端
- 2.1 配置redis.conf文件
- 2.2 后台启动
- 2.3 开启客户端
- 2.4 退出客户端
- 2.5 关闭redis服务
- 3 Redis主从复制
- 3.1 配置方法
- 3.1.1 创建从机
- 3.1.2 启动从机和客户端
- 3.1.3 通过info replication指令查看当前主从机关系
- 4 哨兵模式
- 4.1 准备工作
- 4.1.1 准备若干份的从机
- 4.1.2 配置哨兵
- 4.2 启动哨兵
- 4.3 测试
- 5 Redis集群
- 5.1 配置节点
- 5.1.1 配置单个节点
- 5.1.2 复制节点若干份。通常组成六个节点的集群,三主三从
- 5.2 编写脚本启动所有的节点
- 5.3 执行脚本启动所有节点
- 5.4 创建cluster
- 5.5 连接集群
- 5.6 查看集群信息
1 Redis安装和配置
1.1 编译环境配置
Redis是C语言开发的,安装redis需要先去官网下载源码进行编译,编译需要依赖于GCC编译环境,如果CentOS上没有安装gcc编译环境,需要提前安装,安装命令如下:(这里我们使用root用户处理这些操作)
[root@localhost ~]# yum install gcc-c+
1.2 Redis安装
1.2.1 使用SecureFX把Redis安装包传到centos
1.2.2 解压redis安装包
[root@localhost local]# tar -zxvf redis-5.0.5.tar.gz
1.2.3 编译
在解压的根目录下执行make
[root@localhost local]# cd redis-5.0.5
[root@localhost redis-5.0.5]# make
如果编译失败,需要先删除安装文件目录,后解压重新编译。
1.2.4 安装
[root@localhost redis-5.0.5]# make PREFIX=/home/admin/myapps/redis install
其中PREFIX是自定义的安装目录
1.2.5 Copy文件
Redis启动需要一个配置文件,可以修改端口号信息。将redis解压的文件夹中的redis.conf
文件复制到安装目录。
[root@localhost redis-5.0.5]# cp redis.conf /home/admin/myapps/redis
2 启动Redis以及客户端
2.1 配置redis.conf文件
- 在redis.conf文件中,设置:
daemonize yes
,允许后台启动 - 设置绑定ip地址:默认是localhost地址(127.0.0.1),这里需要修改为虚拟机的ip地址(我的是192.168.111.128)。
bind 192.168.111.128
2.2 后台启动
[root@localhost redis]# ./bin/redis-server redis.conf
2.3 开启客户端
[root@localhost redis]# ./bin/redis-cli -h 192.168.111.128 -p 6379
2.4 退出客户端
quit
2.5 关闭redis服务
- 强制关闭:
kill -9 pid
,其中pid为相关进程的id,可以通过ps -aux | grep redis
查看。 - 正常关闭:
./bin/redis-cli -h 192.168.111.128 -p 6379 shutdown
如果不加-h和-p参数,则默认是关闭localhost下的6397端口的服务。
3 Redis主从复制
- 持久化保证了即使redis服务重启也不会丢失数据,但是当redis服务器的硬盘损坏了可能会导致数据丢失,通过redis的主从复制机制就可以避免这种单点故障(单台服务器的故障)。
- 主redis中的数据和从上的数据保持实时同步,当主redis写入数据时通过主从复制机制复制到两个从服务上。
- 主从复制不会阻塞master,在同步数据时,master 可以继续处理client 请求.
- 主机master配置:无需配置
3.1 配置方法
主机不需要配置,只配置从机。
3.1.1 创建从机
复制redis目录若干份,对每一份中要做如下操作:
- redis.conf修改:
- 修改绑定的端口:
port 6380
(确保每一个从机的端口不一样) - 绑定主机ip和端口:replicaof 主机ip 主机端口号
replicaof 192.168.111.128 6379
- 修改绑定的端口:
- 删除从机的持久化文件
3.1.2 启动从机和客户端
3.1.3 通过info replication指令查看当前主从机关系
4 哨兵模式
传统的主从关系中,如果主机宕机了,需要手动配置一个从机顶替上来,并且还要修改其他从机与其的关系。通过哨兵模式可以自动化这个过程。
哨兵是一个单独的进程,启动之前确保主从服务是正常的
。先启动主服务,后启动从服务
4.1 准备工作
哨兵主要是用来监听主服务器的,所以一般把哨兵部署在从服务器上监听。
4.1.1 准备若干份的从机
- 删除从机中的持久化文件
- redis.conf中修改绑定的端口号
- redis.conf中replicaof的修改,确定主从关系
4.1.2 配置哨兵
哨兵只需要配置其中一个从机即可!!
任选一个从机,在其bin目录下新建文件sentinel.conf
,在其中写入内容:
sentinel monitor mastername 192.168.111.128 6379 1
- mastername 监控主数据的名称,自定义
- 192.168.111.128:监控主数据库的IP;
- 6379:端口
- 1:最低通过票数
4.2 启动哨兵
哨兵可以理解为一个监控的进程。既然要监控,那么首先需要先有监控的对象,即主从机需要先启动。就按照先前的启动方式启动即可。
通过ps -aux | grep redis
确定主从机已经启动!
之后启动哨兵:
[root@localhost redis]# ./bin/redis-sentinel ./bin/sentinel.conf > sent.log &
启动之后同样查看进程,如果出现sentinel进程说明已经启动成功!
查询配置文件sentinel.conf中生成的内容:
启动哨兵的时候,修改了哨兵的配置文件。如果需要再次启动哨兵,需要删除myid唯一标示。(保险的做法就是启动的一次,新配置一次)
4.3 测试
关闭主机,在从机中通过info replication
检查状态,发现某一个从机变为了主机,另一个从机自动绑定到了新主机。
5 Redis集群
集群搭建的总体方法:
- 先配置并启动若干redis节点
- 再将这些节点配置为cluster
5.1 配置节点
5.1.1 配置单个节点
- 删除所有的持久化文件
- 修改redis.conf:
- 把
cluster-enabled yes
解开注释 - 修改端口号
- 如果之前配置过主从机(replicaof),则注释掉这句话
- 把
5.1.2 复制节点若干份。通常组成六个节点的集群,三主三从
- 每个节点需要修改端口号避免重复
5.2 编写脚本启动所有的节点
假定当前的目录为:
|-: redis-cluster|-: 7001|-: 7002......|-: 7006
则在redis-cluster目录下新建startall.sh
脚本:
cd 7001
./bin/redis-server ./redis.conf
cd ..
cd 7002
./bin/redis-server ./redis.conf
cd ..
cd 7003
./bin/redis-server ./redis.conf
cd ..
cd 7004
./bin/redis-server ./redis.conf
cd ..
cd 7005
./bin/redis-server ./redis.conf
cd ..
cd 7006
./bin/redis-server ./redis.conf
cd ..
- 修改脚本的权限,使其能够执行:
chmod u+x startall.sh
5.3 执行脚本启动所有节点
./startall.sh
执行完毕后,输入ps -aux | grep redis
,会出现六个节点的进程:
5.4 创建cluster
在任意节点下启动一次即可。
./bin/redis-cli --cluster create 192.168.111.128:7001 192.168.111.128:7002 192.168.111.128:7003 192.168.111.128:7004 192.168.111.128:7005 192.168.111.128:7006 --cluster-replicas 1
基本语法如下:
./bin/redis-cli --cluster create ip1:port1 ip2:port2 ... --cluster-replicas 1
- 其中–cluster-replicas 表示每个主节点配置几个从节点
5.5 连接集群
连接集群内的任意一个节点即可连接到整个集群。
./bin/redis-cli -h 192.168.111.128 -p 7001 -c
注意添加-c命令,表示以集群模式连接
务必关闭防火墙!
- 关闭防火墙:service iptables stop
- 查看防火墙状态:service iptables status
5.6 查看集群信息
cluster info
cluster nodes
这篇关于Redis哨兵模式及集群配置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!