1.环境说明

我们将使用192.168.220.128、192.168.220.129两台机器搭建sentinel交叉主从为例

当前我们已在192.168.220.128上按redis安装教程安装了redis,192.168.220.129上没有安装

2. 配置128上的slave

  1. cd /usr/myapp/redis-2.8./conf #进入配置文件所在目录
  2. cp redis.conf redis-.conf #128上的master所用配置文件
  3. cp redis.conf redis-.conf #128上的slave所用配置文件
  4. #配置128上的6380从属129的6379端口
  5. cat >> redis-.conf << EOF
  6. slaveof 192.168.220.129
  7. EOF

3. 配置128上的sentinel

2.1修改conf/redis-6379.conf和conf/redis-6380.conf,配置masterauth字段值

2.2修改conf/sentinel.conf,配置以下字段的值

  1. port
  2. sentinel announce-ip 192.168.220.128
  3. dir /usr/myapp/redis-2.8./data
  4.  
  5. sentinel monitor mymaster1 192.168.220.128
  6. sentinel down-after-milliseconds mymaster1
  7. sentinel parallel-syncs mymaster1 2
  8. sentinel failover-timeout mymaster1
  9. sentinel auth-pass mymaster1 yourpasswd
  10.  
  11. sentinel monitor mymaster2 192.168.220.129
  12. sentinel down-after-milliseconds mymaster2
  13. sentinel parallel-syncs mymaster2 2
  14. sentinel failover-timeout mymaster2
  15. sentinel auth-pass mymaster2 yourpasswd

mymaster1和mymaster2可理解为后边master的别名,如果还有其他master类似地添加上即可。

2.3为了方便把sentinel启动脚本写到adm目录下

  1. cd adm
  2.  
  3. cat > start_sentinel << EOF
  4. ../bin/redis-sentinel ../conf/sentinel.conf
  5. EOF

4. 在129部署redis

3.1将128上的redis打包发送到129上

  1. tar -cf redis.tar redis-2.8.
  2. scp redis.tar root@192.168.220.129:/usr/myapp

3.2修改配置文件中的ip地址

修改conf/redis-6379.conf和conf/redis-6380.conf,将bind的IP修改为本机网卡IP:

修改conf/redis-6380.conf中的slaveof,将129的6380配置为从属128的6379

修改conf/sentinel.conf,将sentinel announce-ip值修改为本机IP

5. 启动集群

到128、129和130三台机器redis的adm文件夹下分别执行./start_redis和./start_sentinel,启动redis和sentinel服务即可。

redis是数据库服务,sentinel相当于哨兵作用,两者相互独立;sentinel监视redis服务如果sentinel查看到自己参与管理的master停止,则会与其他参与管理的sentinel共同商量,从原master下属的slave中选出一个来担任新的master。

如果redis服务停止之前是master,当其重新启动后不再是master而是变成各sentinel新选举出来的master的slave。

master和slave的区别是master可读写,slave只可读;其实通过配置slave也可读写,所以最为严谨的说法是master和slave的区别是,slave同步master的操作而master不会同步slave的操作slave之间也不会互相同步操作。

6. 应用连接集群

在哨兵模式中,应用应该往主里写数据但是应用是不知道哪个是主那个是从的,一个个去连接然后查看是主是从的做法也是不够合理的。

在实际使用中是通过sentinel来获取哪个是主哪个是从的。

  1. Set sentinels = new HashSet();
  2. sentinels.add(new HostAndPort("192.168.220.128", ).toString());
  3. sentinels.add(new HostAndPort("192.168.220.129", ).toString());
  4. sentinels.add(new HostAndPort("192.168.220.130", ).toString());
  5. JedisSentinelPool sentinelPool = new JedisSentinelPool("mymaster", sentinels);
  6. Jedis master = sentinelPool.getResource();
  7. master.set("name","张三");
  8. String value = master2.get("name");

参考:

http://blog.csdn.net/ownfire/article/details/51546543

https://segmentfault.com/a/1190000002680804

http://blog.csdn.net/xianymo/article/details/46412271

redis sentinel哨兵模式集群搭建教程的更多相关文章

  1. Redis sentinel 哨兵模式集群方案配置

    第一个方案是创建 redis cluster,第二种方案就是用哨兵模式来进行主从替换以及故障恢复.兵模式集群方案配置 一.sentinel介绍 Sentinel作用: 1):Master状态检测 2) ...

  2. redis主从复制,哨兵以及集群搭建部署

    redis主从复制 1.redis支持多实例的功能,一台机器上,可以运行多个单个的redis数据库 环境准备,运行3个redis数据库,达到 1主 2从的配置 主库 6379.conf port 63 ...

  3. Redis主从哨兵和集群搭建

    主从配置 哨兵配置 集群配置 1.主从: 国王和丞相,国王权力大(读写),丞相权利小(读) 2.哨兵: 国王和王子,国王死了(主服务挂掉),王子继位(从服务变主服务) 3.集群: 国王和国王,一个国王 ...

  4. Redis 3.0.2集群搭建以及相关问题汇总

    Redis3 正式支持了 cluster,是为了解决构建redis集群时的诸多不便 (1)像操作单个redis一样操作key,不用操心key在哪个节点上(2)在线动态添加.删除redis节点,不用停止 ...

  5. Redis单机安装以及集群搭建

    今天主要来看一下Redis的安装以及集群搭建(我也是第一次搭建). 环境:CentOS 7.1,redis-5.0.7 一.单机安装 1.将Redis安装包放置服务器并解压 2.进入redis安装目录 ...

  6. 转:Redis 3.2.1集群搭建

    Redis 3.2.1集群搭建   一.概述 Redis3.0版本之后支持Cluster. 1.1.redis cluster的现状 目前redis支持的cluster特性: 1):节点自动发现 2) ...

  7. 【运维技术】Zookeeper单机以及集群搭建教程

    Zookeeper单机以及集群搭建教程 单机搭建 单机安装以及启动 安装zookeeper的前提是必须有java环境 # 选择目录进行下载安装 cd /app # 下载zk,可以去官方网站下载,自己上 ...

  8. Redis 5.0.5集群搭建

    Redis 5.0.5集群搭建 一.概述 Redis3.0版本之后支持Cluster. 1.1.redis cluster的现状 目前redis支持的cluster特性: 1):节点自动发现 2):s ...

  9. Redis 哨兵(sentinel)模式集群配置(5.0.3版本)

    一.准备工作 1.系统环境:centos6.4 2.服务器六台(1主5从): 192.168.1.161(master) 192.168.1.162(slave) 192.168.1.163(slav ...

随机推荐

  1. C# linq 最大、最小对象的扩展

    public static class LinqExtension { public static T MaxBy<T, TR>(this IEnumerable<T> en, ...

  2. 如何用conda安装软件|处理conda安装工具的动态库问题

    conda的确是一个非常好的工具,对于初学者而言,安装软件就跟用XXX软件管理器一样方便.正因为他如此便利,以至于我介绍如何手动安装工具时,总有人问我为啥不用conda. 我用conda,并且用的很好 ...

  3. 设计模式(八)Proxy Parttern 代理模式

    核心作用: 通过代理,控制对对象的访问 可以详细控制某个对象的方法,在调用这个方法做前置处理,调用这个方法后做后置处理(AOP的微观实现) AOP(Aspect Oriented Programmin ...

  4. Maven命令行创建java或javaWeb项目

    Maven命令行创建java或javaWeb项目   1.命令行创建普通java项目 mvn archetype:generate -DgroupId=com.fxust -DartifactId=d ...

  5. leecode第八十八题(合并两个有序数组)

    class Solution { public: void merge(vector<int>& nums1, int m, vector<int>& nums ...

  6. Codeforces 920G - List Of Integers

    920G - List Of Integers 思路:容斥+二分 代码: #include<bits/stdc++.h> using namespace std; #define ll l ...

  7. xlua怎么样hotfix C#中的重写方法???

    问题的来源之这样的: 线上项目遇到一个问题,就是子类 override 了父类的一个 virtual 方法,并且调用到了父类里面的 virtual 方法.现在子类  override 的方法里有一些错 ...

  8. lua --- 函数的本质

    1.lua中的函数是带有此法界定的第一类值. 2.创建一个函数的过程,本质上就是一个创建赋值语句的过程. 常见的创建函数的过程: function fun() print("Hello wo ...

  9. 图片方向 image orientation Exif

    更新 : 2019-01-02 refer https://stackoverflow.com/questions/3129099/how-to-flip-images-horizontally-wi ...

  10. @suppresswarnings(unchecked)的作用

    @suppresswarnings(unchecked)的作用 一般在项目中会出现红色的报错,这个是影响项目运行的,无法启动,会停在那里,而warning警告,黄色的虽然不是会让项目停止,但是却是不规 ...