Redis哨兵集群创建脚本--v1
基础环境
操作系统版本 CentOS Linux release 7.6.1810 (Core)
Docker 版本 19.03.11, build 42e35e61f3
Redis 版本 3.2.3-alpine
网络配置使用docker macvlan ,创建命令如下:
docker network create -d macvlan --subnet=10.10.10.0/24 --gateway=10.10.10.1 -o parent=eth0 macnet
脚本内容如下:
参数解释:
cmd 定义redis容器启动命令
sentinel_cmd 定义sentinel容器启动命令
image 容器启动镜像
redis_conf redis容器配置文件
sentinel_conf sentinel容器配置文件
redis_quota redis容器cpu、内存配额
sentinel_quota sentinel容器cpu、内存配额
base_dir 脚本运行的家目录
base_conf_dir redis配置文件目录
envv 环境配置,为区分多套集群配置,暂时写死
#!/bin/bash
#Author: Jixson
#Date: 2020-07-02
cmd="/usr/local/bin/redis-server /usr/local/etc/redis/redis.conf"
sentinel_cmd="/usr/local/bin/redis-sentinel /usr/local/etc/redis/sentinel.conf"
image="redis:3.2.3-alpine"
redis_conf="/usr/local/etc/redis/redis.conf"
sentinel_conf="/usr/local/etc/redis/sentinel.conf"
redis_quota="-c2 -m 4g"
sentinel_quota="-c2 -m 1g"
base_dir="/jixson/redis"
base_conf_dir="${base_dir}/conf"
envv="gemini"
mkdir -p ${envv}
#Get IP address
#创建macvlan网络后,把可用IP写入ipmark文件,把已使用的IP写入ipmark_assigned
#由于macvlan自动分配的IP可能与局域网内的IP冲突,故实际使用时,可以使用--iprange参数,限制使用范围
master_ip=$(cat ipmark | head -1)
sed -i "/^${master_ip}/d" ipmark
echo "${master_ip} assigned" >> ipmark_assigned
slave_ip=$(cat ipmark | head -1)
sed -i "/^${slave_ip}/d" ipmark
echo "${slave_ip} assigned" >> ipmark_assigned
sentinel_ip01=$(cat ipmark | head -1)
sed -i "/^${sentinel_ip01}/d" ipmark
echo "${sentinel_ip01} assigned" >> ipmark_assigned
sentinel_ip02=$(cat ipmark | head -1)
sed -i "/^${sentinel_ip02}/d" ipmark
echo "${sentinel_ip02} assigned" >> ipmark_assigned
sentinel_ip03=$(cat ipmark | head -1)
sed -i "/^${sentinel_ip03}/d" ipmark
echo "${sentinel_ip03} assigned" >> ipmark_assigned
#声明主机,写入容器内的hosts
hn1="--add-host=redisdata01.biyao.com:${master_ip}"
hn2="--add-host=redisdata02.biyao.com:${slave_ip}"
hn3="--add-host=sentinel01.biyao.com:${sentinel_ip01}"
hn4="--add-host=sentinel02.biyao.com:${sentinel_ip02}"
hn5="--add-host=sentinel03.biyao.com:${sentinel_ip03}"
hosts="$hn1 $hn2 $hn3 $hn4 $hn5"
#配置文件可从官网获取,根据实际情况修改
#生成master conf
\cp -f "${base_conf_dir}/redis-master.conf" "${base_dir}/${envv}/redis-master.conf"
master_conf="${base_dir}/${envv}/redis-master.conf"
masterconf="-v ${master_conf}:${redis_conf}"
#生成slave conf
\cp -f "${base_conf_dir}/redis-slave.conf" "${base_dir}/${envv}/redis-slave.conf"
slave_conf="${base_dir}/${envv}/redis-slave.conf"
slaveconf="-v ${slave_conf}:${redis_conf}"
#生成sentinel conf
\cp -f "${base_conf_dir}/sentinel.conf" "${base_dir}/${envv}/sentinel01.conf"
sentinel01_conf="${base_dir}/${envv}/sentinel01.conf"
sentinel01conf="-v ${sentinel01_conf}:${sentinel_conf}"
\cp -f "${base_conf_dir}/sentinel.conf" "${base_dir}/${envv}/sentinel02.conf"
sentinel02_conf="${base_dir}/${envv}/sentinel02.conf"
sentinel02conf="-v ${sentinel02_conf}:${sentinel_conf}"
\cp -f "${base_conf_dir}/sentinel.conf" "${base_dir}/${envv}/sentinel03.conf"
sentinel03_conf="${base_dir}/${envv}/sentinel03.conf"
sentinel03conf="-v ${sentinel03_conf}:${sentinel_conf}"
#run redis
docker run -d --network macnet --ip=$master_ip $redis_quota $hosts --name redis-master ${masterconf} ${image} ${cmd}
docker run -d --network macnet --ip=$slave_ip $redis_quota $hosts --name redis-slave ${slaveconf} ${image} ${cmd}
#run sentinel
docker run -d --network macnet --ip=$sentinel_ip01 $sentinel_quota $hosts --name sentinel01 ${sentinel01conf} ${image} ${sentinel_cmd}
docker run -d --network macnet --ip=$sentinel_ip02 $sentinel_quota $hosts --name sentinel02 ${sentinel02conf} ${image} ${sentinel_cmd}
docker run -d --network macnet --ip=$sentinel_ip03 $sentinel_quota $hosts --name sentinel03 ${sentinel03conf} ${image} ${sentinel_cmd}
创建后的效果
Redis哨兵集群创建脚本--v1的更多相关文章
- Redis哨兵集群创建脚本--v2
1. 基础环境 操作系统版本 CentOS Linux release 7.6.1810 (Core) Docker 版本 19.03.11, build 42e35e61f3 Redis 版本 ...
- redis哨兵集群搭建
下载redis jar包redis-4.0.11.tar.gz放在/data/redis目录下 解压 命令:tar -zxvf redis-4.0.11.tar.gz 解压后如图所示 在/usr/lo ...
- 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哨兵集群、docker入门
redis-sentinel主从复制高可用 Redis-Sentinel Redis-Sentinel是redis官方推荐的高可用性解决方案,当用redis作master-slave的高可用时,如果m ...
- redis 哨兵集群原理及部署
复制粘贴自: https://www.cnblogs.com/kevingrace/p/9004460.html 请点击此链接查看原文. 仅供本人学习参考, 如有侵权, 请联系删除, 多谢! Redi ...
- Redis进阶实践之十 Redis哨兵集群模式
一.引言 上一篇文章我们详细的讲解了Redis的主从集群模式,其实这个集群模式配置很简单,只需要在Slave的节点上进行配置,Master主节点的配置不需要做任何更改,但是有一 ...
随机推荐
- linux系统判断内存是否达到瓶颈的小技巧
1.linux下最常用的系统状态监控工具top 工具,可以使用top -c 来进行查看当前内存的占用情况 free 为内存的剩余状态,当前为3.8G的空闲内存,总的物理内存是8G,按键 shift+m ...
- 了解Nginx与PHP的交互?
Nginx可以接收请求并转发给PHP-FPM. 1.开始深入Nginx与FastCGI协议 通过对Nginx新增Server配置实现了nginx与PHP的一次通信,配置文件非常简单. 从上图的Ngin ...
- 附020.Nginx-ingress部署及使用
一 手动部署-官网版 1.1 获取资源 [root@master01 ~]# mkdir ingress [root@master01 ~]# cd ingress/ [root@master01 i ...
- python模拟网站登陆-滑动验证码
普通滑动验证 以http://admin.emaotai.cn/login.aspx为例这类验证码只需要我们将滑块拖动指定位置,处理起来比较简单.拖动之前需要先将滚动条滚动到指定元素位置. impor ...
- 一文入门Kafka,必知必会的概念通通搞定
Kakfa在大数据消息引擎领域,绝对是没有争议的国民老公. 这是kafka系列的第一篇文章.预计共出20篇系列文章,全部原创,从0到1,跟你一起死磕kafka. 本文盘点了 Kafka 的各种术语并且 ...
- 关联函数-web_save_param_length
int web_save_param_length(const char * Param,const char * Base,LAST); 参数说明: Param:保存长度的参数的名称. Base:参 ...
- LaTeX实时预览中文
参考资料:http://blog.sina.com.cn/s/blog_6ea58f530101aizw.html 功夫不负有心人,终于在经过艰苦卓绝的寻找之后,让我的Texpad实现了实时预览.此时 ...
- SFTP协议生成公共秘钥文件
[步骤] 1 ssh方式登录服务器 2 执行命令生成秘钥对 ssh-keygen -t rsa 然后给秘钥文件命名 3.查看当前目录的.ssh目录是否有authorized_keys文件 如果有则把新 ...
- Flask框架基础功能
引言 本文简单汇总Flask框架几大基础功能,包括: 路由系统 模板 数据库 几种常用Flask库 一个简单的Flask事例 Flask是一个基于Python,依赖Jinja2模板和WSGI服务的框架 ...
- Wireshark论证TCP3次握手的过程
wireshark过滤条件:ip.addr == 120.79.36.180 千万别写成 ip.dst == 120.79.36.180 ,这样子就看不到服务器给我们返回的包了 此时,在浏览器输入12 ...