1、环境规划

  1. 10.213.50.138(主) redis+sentinel
  2. 10.213.50.168(从) redis+sentinel
  3. 10.213.50.227  作为客户端测试插入数

2、redis部署

wget http://download.redis.io/releases/redis-3.2.9.tar.gz
1: 解压到/usr/local/src 目录:放源码包
root@redis1:/usr/local/src# tar zxvf redis-3.2.9.tar.gz
root@redis1:/usr/local/src# ls -lh
drwxrwxr-x 6 root root 4.0K 2月 22 15:01 redis-3.2.9 2:创建目录:/usr/local/redis,编译安装到目录/usr/local/redis/ --放执行文件
make PREFIX=/usr/local/redis install 3:程序做软连接到bin目录,方便直接执行
ln -s /usr/local/redis/bin/redis-cli /usr/local/bin/redis-cli
ln -s /usr/local/redis/bin/redis-sentinel /usr/local/bin/redis-sentinel
ln -s /usr/local/redis/bin/redis-server /usr/local/bin/redis-server

1:复制配置文件,在源码包里有sentinel.conf和redis.conf文件,复制到/etc/redis/目录下,如果有多个实例,建议改名,如本实例用的redis端口是7021,sentinel是17021:
cp /usr/local/src/redis-3.2.9/redis.conf /etc/redis/redis_7021.conf
cp /usr/local/src/redis-3.2.9/sentinel.conf /etc/redis/sentinel_17021.conf
后面会给出该配置文件的相关参数 2:做成一个服务,在源码包里的utils目录下的redis_init_script文件复制到/etc/init.d/下,并且改名成redis,以后就可以通过这个程序进行关闭和开启了。
cp /usr/local/src/redis-3.2.9/utils/redis_init_script /etc/init.d/redis 3:修改/etc/init.d/redis文件(后面会给出redis程序的代码),使得开启和关闭,以及关闭的时候需要输入密码(假设redis需要认证)。
 

3、redis配置(master)

bind 0.0.0.0
protected-mode yes
port
daemonize yes
pidfile "/var/run/redis_6379.pid"
logfile "/var/log/redis_6379.log" redis从配置
bind 0.0.0.0
protected-mode yes
port
daemonize yes
pidfile "/var/run/redis_6379.pid"
logfile "/var/log/redis_6379.log"
slaveof 10.213.50.138 #从redis比主redis多这一行,
#######master设置密码的情况下同步数据,其实很简单,我们只要让slave能连上master就可以了,我们在slave的配置文件中加一句话即可。

masterauth 123456      

sentinel  则也要加入加密,放在monitor下面
sentinel monitor master 127.0.0.1 6379 1
sentinel auth-pass mymaster redis123
启动redis并检查info replication 是否正常 redis-server /etc/redis/.conf 在从redis上面观察

4、配置redis-sentinel

protected-mode no
daemonize yes
port
logfile "/var/log/redis/sentinel.log"
pidfile "/var/run/sentinel.pid"
sentinel monitor mymaster 10.213.50.138
sentinel down-after-milliseconds mymaster
sentinel failover-timeout mymaster
sentinel client-reconfig-script mymaster /etc/notify_mymaster.sh
启动redis-sentinel 并检查状态
redis-sentinel /etc/sentinel.conf

5、vip漂移脚本,需要执行权限

cat /etc/notify_mymaster.sh #!/bin/bash
MASTER_IP=$
LOCAL_IP='10.213.50.168'
VIP='10.213.50.188'
NETMASK=''
INTERFACE='eth0'
if [ ${MASTER_IP} = ${LOCAL_IP} ]; then
/sbin/ip addr add ${VIP}/${NETMASK} dev ${INTERFACE}
/sbin/arping -q -c -A ${VIP} -I ${INTERFACE}
exit
else
/sbin/ip addr del ${VIP}/${NETMASK} dev ${INTERFACE}
exit
fi
exit

6、客户端测试数据

cat redis.sh
#!/bin/bash
for ((i=;i<;i++))
do
echo -en "helloworld" | redis-cli -h 10.213.50.188 -x set name$i >>redis.log
sleep
done

7、绑定vip到主库

/sbin/ip addr add 10.213.50.188/24 dev eth0

8、停止主redis观察从库

从库变成了主库,并且vip地址漂移过来了

客户端插入数据会中断,中断时间就是redis  vip漂移及redis从库提升到主库的时间

Redis+sentinel 高可用实践的更多相关文章

  1. Redis|Sentinel 高可用架构

    一 前言 Redis-Sentinel是Redis官方推荐的高可用性(HA)解决方案,当用Redis做Master-slave的高可用方案时,假如master宕机了,Redis本身(包括它的很多客户端 ...

  2. Redis Sentinel 高可用实现说明

    背景:      前面介绍了Redis 复制.Sentinel的搭建和原理说明,通过这篇文章大致能了解Sentinel的原理和实现方法以及相关的搭建.这篇文章就针对Redis Sentinel的搭建做 ...

  3. Redis Sentinel高可用架构

    Redis目前高可用的架构非常多,比如keepalived+redis,redis cluster,twemproxy,codis,这些架构各有优劣,今天暂且不说这些架构,今天主要说说redis se ...

  4. Redis Sentinel 高可用服务搭建

    阅读目录: 关于 Redis 的概念 关于 Redis Sentinel 的概念 搭建 Redis Server(master) 搭建 Redis Server(slave) 搭建 Redis Sen ...

  5. 【转载】Redis Sentinel 高可用服务架构搭建

    作者:田园里的蟋蟀 出处:http://www.cnblogs.com/xishuai/ 本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接. 阅读 ...

  6. Redis Sentinel 高可用方案

      redis 主从复制的问题 Redis主从复制可将主节点数据同步给从节点,从节点此时有两个作用: 1,一旦主节点宕机,从节点作为主节点的备份可以随时顶上来. 2,扩展主节点的读能力,分担主节点读压 ...

  7. Redis Sentinel 高可用部署实践集群

    一.Redis Sentinel 介绍    1.Sentinel     数据库环境搭建,从单机版到主备.再到多数据库集群,我们需要一个高可用的监控:比如Mysql中,我们可能会采用MHA来搭建我们 ...

  8. redis sentinel 高可用(HA)方案部署,及python应用示例

    redis sentinel(哨兵)高可用集群的部署方法,并通过 python 程序实例讲解如何使用 redis sentinel 简介 介绍 redis sentinel(哨兵)集群的部署,配置一主 ...

  9. Redis Sentinel 高可用机制

    内容目录: Sentinel 如何工作的? 核心配置项 怎么选出新 master 的? Sentinel 有多个,具体谁来执行故障转移? Sentinel 是怎么发现 slave 和其他 sentin ...

随机推荐

  1. 四面体ply格式文件图和数据对应关系分析

    通过一个简单的文件来理解ply格式的文件是有所帮助的,我在网上找了一个四面体的ply文件,我通过meshlab打开看到的效果如下所示,我录制成gif文件,希望可以从不同角度展示出来: 同时我截图少许, ...

  2. Javascript显示提示信息加样式

    #region JS提示============================================ /// <summary> /// 添加编辑删除提示 /// </s ...

  3. Sum All Odd Fibonacci Numbers-freecodecamp算法题目

    Sum All Odd Fibonacci Numbers 1.要求 给一个正整数num,返回小于或等于num的斐波纳契奇数之和. 斐波纳契数列中的前几个数字是 1.1.2.3.5 和 8,随后的每一 ...

  4. 6- vue django restful framework 打造生鲜超市 -完成商品列表页(下)

    Vue+Django REST framework实战 搭建一个前后端分离的生鲜超市网站 Django rtf 完成 商品列表页下 drf中的request和response drf对于django的 ...

  5. 5.Cisco Packet Tracer里关于交换机或路由器配置文件和系统映像备份与恢复

    我们会将交换机或路由器的配置文件和系统镜像直接备份到tftp服务器上,所以我们需要准备一台tftp的服务器 1我们需要给服务器配一个ip地址,给路由器的f0/1端口配置一个ip地址,路由器与服务器能相 ...

  6. day03_基本数据类型基本运算

    1.什么是数据类型 变量值才是我们存储的数据,所以数据类指的就是变量值的不同种类 2.为何数据要分类型? 变量值是用来保存现实世界中的状态的,那么针对不同的状态就应该用不同类型的数据去表示 3.如何用 ...

  7. hibernate的get() load() 和find()区别

    如果找不到符合条件的纪录,get()方法将返回null.如果找不到符合条件的纪录,find()方法将返回null.如果找不到符合 条件的纪录,load()将会报出ObjectNotFoundEccep ...

  8. Problem E. TeaTree - HDU - 6430 (树的启发式合并)

    题意 有一棵树,每个节点有一个权值. 任何两个不同的节点都会把他们权值的\(gcd\)告诉他们的\(LCA\)节点.问每个节点被告诉的最大的数. 题解 第一次接触到树的启发式合并. 用一个set维护每 ...

  9. 数学算法:CF534A-Exam(思维)

    Exam time limit per test 1 second memory limit per test 256 megabytes input standard input output st ...

  10. nova boot添加volume_type参数支持

    早前由于添加了全SSD的高性能Ceph集群,区别于现有的HDD集群,在OpenStack端需要能够选择使用两种集群.Cinder配置多Ceph后端的文档早已整理,整理文件夹时发现这篇为nova boo ...