redis sentinel哨兵模式集群搭建教程
1.环境说明
我们将使用192.168.220.128、192.168.220.129两台机器搭建sentinel交叉主从为例
当前我们已在192.168.220.128上按redis安装教程安装了redis,192.168.220.129上没有安装
2. 配置128上的slave
cd /usr/myapp/redis-2.8./conf #进入配置文件所在目录
cp redis.conf redis-.conf #128上的master所用配置文件
cp redis.conf redis-.conf #128上的slave所用配置文件
#配置128上的6380从属129的6379端口
cat >> redis-.conf << EOF
slaveof 192.168.220.129
EOF
3. 配置128上的sentinel
2.1修改conf/redis-6379.conf和conf/redis-6380.conf,配置masterauth字段值

2.2修改conf/sentinel.conf,配置以下字段的值
port
sentinel announce-ip 192.168.220.128
dir /usr/myapp/redis-2.8./data sentinel monitor mymaster1 192.168.220.128
sentinel down-after-milliseconds mymaster1
sentinel parallel-syncs mymaster1 2
sentinel failover-timeout mymaster1
sentinel auth-pass mymaster1 yourpasswd sentinel monitor mymaster2 192.168.220.129
sentinel down-after-milliseconds mymaster2
sentinel parallel-syncs mymaster2 2
sentinel failover-timeout mymaster2
sentinel auth-pass mymaster2 yourpasswd
mymaster1和mymaster2可理解为后边master的别名,如果还有其他master类似地添加上即可。
2.3为了方便把sentinel启动脚本写到adm目录下
cd adm cat > start_sentinel << EOF
../bin/redis-sentinel ../conf/sentinel.conf
EOF
4. 在129部署redis
3.1将128上的redis打包发送到129上
tar -cf redis.tar redis-2.8.
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来获取哪个是主哪个是从的。
Set sentinels = new HashSet();
sentinels.add(new HostAndPort("192.168.220.128", ).toString());
sentinels.add(new HostAndPort("192.168.220.129", ).toString());
sentinels.add(new HostAndPort("192.168.220.130", ).toString());
JedisSentinelPool sentinelPool = new JedisSentinelPool("mymaster", sentinels);
Jedis master = sentinelPool.getResource();
master.set("name","张三");
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哨兵模式集群搭建教程的更多相关文章
- Redis sentinel 哨兵模式集群方案配置
第一个方案是创建 redis cluster,第二种方案就是用哨兵模式来进行主从替换以及故障恢复.兵模式集群方案配置 一.sentinel介绍 Sentinel作用: 1):Master状态检测 2) ...
- redis主从复制,哨兵以及集群搭建部署
redis主从复制 1.redis支持多实例的功能,一台机器上,可以运行多个单个的redis数据库 环境准备,运行3个redis数据库,达到 1主 2从的配置 主库 6379.conf port 63 ...
- Redis主从哨兵和集群搭建
主从配置 哨兵配置 集群配置 1.主从: 国王和丞相,国王权力大(读写),丞相权利小(读) 2.哨兵: 国王和王子,国王死了(主服务挂掉),王子继位(从服务变主服务) 3.集群: 国王和国王,一个国王 ...
- Redis 3.0.2集群搭建以及相关问题汇总
Redis3 正式支持了 cluster,是为了解决构建redis集群时的诸多不便 (1)像操作单个redis一样操作key,不用操心key在哪个节点上(2)在线动态添加.删除redis节点,不用停止 ...
- Redis单机安装以及集群搭建
今天主要来看一下Redis的安装以及集群搭建(我也是第一次搭建). 环境:CentOS 7.1,redis-5.0.7 一.单机安装 1.将Redis安装包放置服务器并解压 2.进入redis安装目录 ...
- 转:Redis 3.2.1集群搭建
Redis 3.2.1集群搭建 一.概述 Redis3.0版本之后支持Cluster. 1.1.redis cluster的现状 目前redis支持的cluster特性: 1):节点自动发现 2) ...
- 【运维技术】Zookeeper单机以及集群搭建教程
Zookeeper单机以及集群搭建教程 单机搭建 单机安装以及启动 安装zookeeper的前提是必须有java环境 # 选择目录进行下载安装 cd /app # 下载zk,可以去官方网站下载,自己上 ...
- Redis 5.0.5集群搭建
Redis 5.0.5集群搭建 一.概述 Redis3.0版本之后支持Cluster. 1.1.redis cluster的现状 目前redis支持的cluster特性: 1):节点自动发现 2):s ...
- 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 ...
随机推荐
- 每日质量NPM包复制_copy-to-clipboard
一.copy-to-clipboard 官方定义: Simple module exposing copy function 理解: 一个超级简单的复制功能,并且这种方法适用于通过别的事件触发复制功能 ...
- python中那些双下划线开头得函数和变量
Python中下划线---完全解读 Python 用下划线作为变量前缀和后缀指定特殊变量 _xxx 不能用’from module import *’导入 __xxx__ 系统定义名字 __x ...
- linux学习笔记--程序与进程管理
.工作管理 1.前台程序放后台程序 命令后 加 & 2.任务执行时将前台任务任务放到后台中并[暂停] ctr + z 3.jobs 观察后台工作状态 及多少任务在执行,可以通过 help ...
- Java中的单实例
前几天刚学完单实例设计模式,今天看代码时发现一行代码很奇怪,getRuntime()函数的返回类型怎么是它本身,忽然想起前几天学的单实例模式,于是找到方法的定义,果然是静态私有变量,获取实例的公有方法 ...
- Could not open ServletContext resource [/WEB-INF/xxx-servlet.xml]
Could not open ServletContext resource [/WEB-INF/xxx-servlet.xml] 造成这个问题的原因很多,网上的解决思路也很多,比如以下的: http ...
- npm升级package.json依赖包到最新版本号
转载自:https://blog.csdn.net/syaivin/article/details/79388244?utm_source=blogxgwz1 1.安装: npm install -g ...
- yum update软件包冲突
因升级系统过程中断,重新进入系统继续升级出现如下问题(内容太多,只粘部分内容) # yum update 正在解决依赖关系 --> 正在检查事务 ---> 软件包 alsa-firmwar ...
- Python中数据类型
一.整数 Python可以处理任意大小的整数,当然包括负整数,在Python程序中,整数的表示方法和数学上的写法一模一样,例如:1,100,-8080,0,等等. 计算机由于使用二进制,所以,有时候用 ...
- 在线html编辑器
1.http://liveweave.com/ 2.有时间研究下这个. http://dabblet.com/gist/4034534 3.10个免费的在线编辑器. https://www.ev这个需 ...
- 第 4 章 容器 - 029 - 限制容器的 Block IO
限制容器的 Block IO Block IO 是另一种可以限制容器使用的资源. Block IO 指的是磁盘的读写,docker 可通过设置权重.限制 bps 和 iops 的方式控制容器读写磁盘的 ...