Docker应用系列(一)| 构建Redis哨兵集群
本示例基于Centos 7,在阿里云的三台机器上部署redis集群,假设目前使用的账号为release,拥有sudo权限。
由于Docker官方镜像下载较慢,可以开启阿里云的Docker镜像下载加速器,可参考此文进行配置。
假设三台主机的ip分别为:
- 主机一:192.168.0.1
- 主机二:192.168.0.2
- 主机三:192.168.0.3
三台主机的安装步骤相似,以主机一为例:
1. 安装docker服务:
sudo yum install -y docker
2. 启动docker服务:
sudo service docker start
3. 查找redis镜像:
sudo docker search redis
4. 下载官方redis镜像:
sudo docker pull docker.io/redis
5. 下载完后可检查镜像:
sudo docker images
6. 主机上建立挂载目录和redis配置文件:
mkdir -p /data/redis_data
cd /data/redis_data
touch redis.conf
vi redis.conf
主机一上的redis.conf配置信息如下:
logfile "redis.log"
port 6379
dir /data
appendonly yes
appendfilename appendonly.aof
requirepass 1234
主机二、三上也同样建立挂载目录和redis配置文件,其内容稍有不同:
logfile "redis.log"
port 6379
dir /data
appendonly yes
appendfilename appendonly.aof
slaveof 192.168.0.1 6389
masterauth 1234
requirepass 1234
配置说明:
- dir:工作目录
- logfile:日志文件在工作目录下
- slaveof:指明为主机一的从机
- requirepass:redis客户端连接的认证密码,若不需要可不配置
- masterauth:主从redis同步的认证密码,与连接密码同,若不需要可不用配置
- appendonly:是否需要持久化,yes为需要
7. 三台主机上都启动容器:
sudo docker run -p : -v /data/redis_data/:/data --name redis- -d docker.io/redis redis-server redis.conf
命令说明:
- -p 6379:6379 : 将容器的6379端口映射到主机的6379端口
- -v /data/redis_data:/data : 将主机中目录/data/redis_data挂载到容器的/data
- --name redis-6379: 给出容器名称
- -d: 后台运行
- docker.io/redis: 镜像名称
- redis-server redis.conf: redis的启动命令,指定配置文件
经过这一步后,三台主机已经建立了主从关系。
8. 查看容器运行情况:
sudo docker ps -a
运行中的容器,其状态为Up,
若要停止并删除容器,其命令为:
sudo docker stop 容器id
sudo docker rm 容器id
9. 观察容器内部redis的情况:
sudo docker exec -it 容器id /bin/bash
该命令可进入容器内部,其默认的工作目录即为/data,再执行redis-cli命令,观察redis信息:
[release@sh-lbs02 -sentinel]$ sudo docker exec -it cac /bin/bash
root@cac589144cfd:/data# redis-cli
127.0.0.1:> info
NOAUTH Authentication required.
127.0.0.1:> auth SVKFGKPaFT
OK
127.0.0.1:> info
# Server
...
# Replication
role:slave
master_host:192.168.0.1
master_port:
...
至此,可确认三台主机的主从模式已经建立成功。
10. 主机上建立哨兵目录和其配置文件:
cd /data/redis_data
touch sentinel.conf
vi sentinel.conf
三台主机上sentinel.conf的内容相同,如下:
logfile "sentinel.log"
sentinel monitor mymaster 192.168.0.1
sentinel auth-pass mymaster
配置说明:
- logfile "sentinel.log":输出日志目录
- sentinel monitor mymaster 192.168.0.1 6379 1:哨兵监控的主服务器名称为mymaster,ip为192.168.0.1,端口为6379,将这个主服务器标记为失效至少需要1个哨兵进程的同意
- sentinel auth-pass mymaster 1234 : 哨兵的认证密码
11. 三台主机上启动哨兵模式:
sudo docker run -p : -v /data/redis_data/:/data --name redis- -d docker.io/redis redis-sentinel sentinel.conf
命令说明:
- -p 26379:26379 : 将容器的26379端口映射到主机的26379端口
- -v /data/redis_data:/data : 将主机中目录/data/redis_data挂载到容器的/data
- --name redis-26379: 给出容器名称
- -d: 后台运行
- docker.io/redis: 镜像名称
- redis-sentinel sentinel.conf: sentinel的启动命令,指定配置文件
经过这一步后,哨兵模式已经建立起来。可通过观察日志查看启动情况
12. 观察容器内哨兵情况:
sudo docker exec -it 容器id /bin/bash
该命令可进入哨兵容器内部,其默认的工作目录即为/data,再执行redis-cli命令,观察redis信息:
[release@sh-lbs02 -sentinel]$ sudo docker exec -it /bin/bash
root@259da4458937:/data# redis-cli -h 127.0.0.1 -p
127.0.0.1:> info
# Server
...
# Sentinel
sentinel_masters:
sentinel_tilt:
sentinel_running_scripts:
sentinel_scripts_queue_length:
sentinel_simulate_failure_flags:
master0:name=mymaster,status=ok,address=192.168.0.1:,slaves=,sentinels=
127.0.0.1:>
至此,可以确定哨兵模式已启动成功。
Docker应用系列(一)| 构建Redis哨兵集群的更多相关文章
- Redis哨兵集群创建脚本--v2
1. 基础环境 操作系统版本 CentOS Linux release 7.6.1810 (Core) Docker 版本 19.03.11, build 42e35e61f3 Redis 版本 ...
- Linux - redis哨兵集群实例
目录 Linux - redis哨兵集群实例 命令整理 配置流程 Linux - redis哨兵集群实例 命令整理 官网地址:http://redisdoc.com/ redis-cli info # ...
- helm部署Redis哨兵集群
介绍 Redis Sentinel集群是由若干Sentinel节点组成的分布式集群,可以实现故障发现.故障自动转移.配置中心和客户端通知. 如下图: Redis Sentinel 故障转移过程: 从这 ...
- 11.Redis 哨兵集群实现高可用
作者:中华石杉 Redis 哨兵集群实现高可用 哨兵的介绍 sentinel,中文名是哨兵.哨兵是 redis 集群机构中非常重要的一个组件,主要有以下功能: 集群监控:负责监控 redis mast ...
- python连接redis哨兵集群
一.redis集群模式有多种, 哨兵模式只是其中的一种实现方式, 其原理请自行谷歌或者百度 二.python 连接 redis 哨兵集群 1. 安装redis包 pip install redis 2 ...
- redis哨兵集群搭建
下载redis jar包redis-4.0.11.tar.gz放在/data/redis目录下 解压 命令:tar -zxvf redis-4.0.11.tar.gz 解压后如图所示 在/usr/lo ...
- redis哨兵集群、docker入门
redis-sentinel主从复制高可用 Redis-Sentinel Redis-Sentinel是redis官方推荐的高可用性解决方案,当用redis作master-slave的高可用时,如果m ...
- 单台服务器-利用docker搭建Redis哨兵集群模式
前言:只有一台华为云服务器,所以打算创建三个容器来模拟三个服务器了. 一:拉取redis镜像 二:拉取redis.conf文件 放在自定义的目录下:wget -c http://download.re ...
- redis哨兵集群+spring boot 2.×
Ubuntu集群构建篇 redis-cli:不跟参数,默认访问localhost:6379端口,无密码登陆 redis-cli -h ${host} -p ${port} -a ${password} ...
随机推荐
- PHP扩展开发--01.编写一个helloWorld扩展
为什么要用C扩展 C是静态编译的,执行效率比PHP代码高很多.同样的运算代码,使用C来开发,性能会比PHP要提升数百倍. 另外C扩展是在进程启动时加载的,PHP代码只能操作Request生命周期的数据 ...
- IIS 网站日志分析
最近由于ADSL代理总出问题,导致爬虫服务器总被目标网站封,由于请求内容总是空,前端APP获取不到想要的内容就一直刷新,导致爬虫服务器请求更加繁忙. 爬虫服务器每执行完一个流程,都会给统计服务器Pos ...
- [数据库中间件]将用户添加到DB2组授权
1.将用户oracle添加到db2的用户组中,命令如下: usermod -a -G db2iam #将用户添加到组中并不改变当前所属组 注:以下与主题无关,只是列举一些关于用户的命令 id user ...
- 【CodeForces】671 C. Ultimate Weirdness of an Array
[题目]C. Ultimate Weirdness of an Array [题意]给定长度为n的正整数序列,定义一个序列的价值为max(gcd(ai,aj)),1<=i<j<=n, ...
- BestCoder Round #40 解题报告
这场是第一场没有米的BC... 大概也是想震一震那些一听说没米了就不打BC的人吧 这次的题目质量比以往高了许多 (然而我并没有打这一场BC 但是今天下午到现在做的过程中真的学到了不少知识呢 A题略水. ...
- 【洛谷 P4072】 [SDOI2016]征途(斜率优化)
好久没写斜率优化板子都忘了, 硬是交了十几遍.. 推一下柿子就能得到答案为 \[m*\sum x^2-(\sum x)^2\] 后面是个定值,前面简单dp,斜率优化一下就行了. \(f[i][j]=f ...
- Linux Deploy 使用 Repository部署Linux系统
Linux Deploy 使用 Repository部署Linux系统 为了解决镜像不稳定导致包下载错误,能得到一个稳定环境,可以使用linux deploy导出功能. 这里提供两个制作好的包 用户名 ...
- 重载jquery on方法实现click事件在移动端的快速响应
额,这个标题取的还真是挺装的... 其实我想表达的是jquery click事件如何在移动端自动转换成touchstart事件. 因为移动端click事件会比touchstart事件慢几拍 移动设备某 ...
- 利用Jsoup模拟跳过登录爬虫获取数据
今天在学习爬虫的时候想着学习一下利用jsoup模拟登录.下面分为有验证码和无验证码的情况进行讨论. ---------------------------无验证码的情况---------------- ...
- Bootstrap文件上传组件:bootstrap fileinput
为了上传预览pdf与图片特用此插件. 源码以及API地址: bootstrap-fileinput源码:https://github.com/kartik-v/bootstrap-fileinput ...