赞
踩
下载redis
wget http://download.redis.io/releases/redis-5.0.5.tar.gz
wget命令无效,执行下面安装插件
yum -y install wget
复制redis.conf文件
第一台主配置
- 修改端口号防止冲突——》修改 protected-mode 为no(是否受保护,默认是)
- ——》bing 172.1.1.1 注释(设置连接,注释掉表示都可以连接)
第二台从配置
- 修改端口号防止冲突——》修改 protected-mode 为no(是否受保护,默认是)
- ——》bing 172.1.1.1 注释(设置连接,注释掉表示都可以连接)
- ——》修改 pidfile /var/run/redis_6379 为 pid pidfile /var/run/redis_7000.pid
首先进入到 src下面
启动主节点:./redis-server ../redis.conf &
启动从节点:./redis-server ../redis7000.conf --slaveof 192.168.0.31 6379 &
客户端连接:./redis-cli -p 7000
查看主从配置:info replication
断开主从复制:在slave节点,执行7000:>slaveof no one
这里有坑在启动时redis-5.0.3/src下未发现 ./redis-server文件,只找到几个.c后辍的文件
- Redis是C实现的,需要gcc来进行编译,原因可能是未安装gcc,使用命令安装gcc:yum install gcc
-
- 还需要编译一下,进入redis-3.2.0目录 make && make install
- 这两个我都执行了,但是觉得下面make就够了,可以试试
至此一主一从完成,可以在一个上set另一个get测试
开始守护线程启动redis配置
- vim sentinel.conf #在redis的跟目录下
- port 26379
- daemonize yes 是否开启守护线程
- protected-mode no #保护模式如果开启只接受回环地址的ipv4和ipv6地址链接,拒绝外部链接,而且正常应该配置多个哨兵,避免一个哨兵出现独裁情况,如果配置多个哨兵那如果开启也会拒绝其他sentinel的连接。导致哨兵配置无法生效。
-
- logfile "/usr/redis/log/sentinel.log" #指明日志文件,路径需要提前创建
-
- dir "/usr/redis/sentinel" #Sentinel服务运行时使用的临时文件夹
-
- sentinel monitor mymaster 192.168.198.128 6379 1 #Sentinel去监视一个名为master001的主redis实例,这个主实例的IP地址为本机地址192.168.110.101,端口号为6379,而将这个主实例判断为失效至少需要2个 Sentinel进程的同意,只要同意Sentinel的数量不达标,自动failover就不会执行
-
- sentinel down-after-milliseconds master001 5000:指定了Sentinel认为Redis实例已经失效所需的毫秒数。当实例超过该时间没有返回PING,或者直接返回错误,那么Sentinel将这个实例标记为主观下线。只有一个 Sentinel进程将实例标记为主观下线并不一定会引起实例的自动故障迁移:只有在足够数量的Sentinel都将一个实例标记为主观下线之后,实例才会被标记为客观下线,这时自动故障迁移才会执行
-
-
- sentinel failover-timeout master001 30000:如果在该时间(ms)内未能完成failover操作,则认为该failover失败
-
- #我只配置了前三个
-
-
- sentinel notification-script <master-name> <script-path>:指定sentinel检测到该监控的redis实例指向的实例异常时,调用的报警脚本。该配置项可选,但是很常用
-
- sentinel parallel-syncs master001 1:指定了在执行故障转移时,最多可以有多少个从Redis实例在同步新的主实例,在从Redis实例较多的情况下这个数字越小,同步的时间越长,完成故障转移所需的时间就越长
哨兵配置完成启动哨兵: redis、src下 ./redis-sentinel ../sentinel.conf &
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。