当前位置: 首页 > article >正文

Redis在docker中的主从,哨兵配置

主从配置

docker 中redis服务启动,将配置文件和数据挂载到 redisData中,记得先创建好redis.conf

docker run -p 6379:6379 \
 --name redis \
 -v /root/redisData/data:/data \
 -v /root/redisData/conf/redis.conf:/etc/redis/redis.conf \
 -d redis redis-server /etc/redis/redis.conf

从节点使用了6380端口,参照上面自行修改

进入从节点的配置文件修改

# 开启密码验证(可选)
#requirepass 123456

# 允许redis外地连接,需要注释掉绑定的IP
# bind 127.0.0.1

#端口
port 6380

# 关闭保护模式(可选)
protected-mode no

# 注释掉daemonize yes,或者配置成 daemonize no。因为该配置和 docker run中的 -d 参数冲突,会导致容器一直启动失败
daemonize no

# 开启RDB
# save ""
save 3600 1
save 300 100
save 60 10000

# 这里选择开启了AOF,可以关闭
appendonly yes

# 这些设置将在 AOF 文件大小增长到一定百分比(auto-aof-rewrite-percentage)和最小大小(auto-aof-rewrite-min-size)时触发 AOF 重写。
#auto-aof-rewrite-percentage 100
#auto-aof-rewrite-min-size 16mb

#开启主从
slaveof 192.168.200.100 6379

进入redis容器

docker exec -it redis redis-cli -p 6380

展示redis信息

info replication

哨兵配置

创建挂载文件夹,我挂载在/root/redisData/sentinel下,在目录中创建sentinel.conf

port 26379
daemonize no
sentinel monitor mymaster 192.168.200.100 6379 1
sentinel auth-pass mymaster ""
sentinel down-after-milliseconds mymaster 5000
sentinel parallel-syncs mymaster 1
sentinel failover-timeout mymaster 60000

在启动后会自动写入一些配置,这里无密码时会出错,启动后手动将密码配置一项补全,下面为启动之后补完的代码

port 26379
daemonize no
sentinel myid f5d5274ad22e1894a5fd845e50201ae47a5eeca8
sentinel deny-scripts-reconfig yes
sentinel monitor mymaster 192.168.200.100 6379 1
sentinel down-after-milliseconds mymaster 5000
sentinel failover-timeout mymaster 60000
# Generated by CONFIG REWRITE
dir "/data"
sentinel auth-pass mymaster "" 
sentinel config-epoch mymaster 0
sentinel leader-epoch mymaster 0
sentinel known-replica mymaster 172.17.0.1 6380
sentinel current-epoch 0

启动哨兵服务

docker run -p 26381:26379 --name redis-sentinel1 -v /root/redisData/sentinel/sentinel.conf:/etc/redis/sentinel.conf -d redis redis-sentinel /etc/redis/sentinel.conf
docker run -p 26382:26379 --name redis-sentinel2 -v /root/redisData/sentinel/sentinel.conf:/etc/redis/sentinel.conf -d redis redis-sentinel /etc/redis/sentinel.conf

进入哨兵容器

docker exec -it redis-sentinel1 redis-cli -p 26379

查看哨兵信息

info sentinel


http://www.kler.cn/a/390801.html

相关文章:

  • 算法(二)——一维差分、等差数列差分
  • C#Halcon找线封装
  • 【 Verdi实用技巧-Part-3】
  • Vue进阶(贰幺贰)npm run build多环境编译
  • Sql 创建用户
  • 中国科技统计年鉴EXCEL版(2021-2023年)-社科数据
  • kafka消费者的消费分区策略有哪些,默认是哪个?
  • C#-命名空间
  • qsqlmysql.lib的编译和使用
  • Java接收xml格式参数转为json
  • sql注入基础知识
  • 海柔仿真系统存储实践:混合云架构下实现高可用与极简运维
  • 【cft.show-web3解题思路】-php://input伪协议
  • 行业类别-金融科技-子类别区块链技术-细分类别智能合约-应用场景供应链金融课题
  • Python 正则表达式使用指南
  • Vue页面假死点不动现象Cannot read properties of undefined(reading ‘_wrapper‘)报错
  • 如何在Linux中使用Cron定时执行SQL任务
  • ROM修改进阶教程------安卓14 安卓15去除app签名验证的几种操作步骤 详细图文解析
  • 机器学习(基础2)
  • HCIP-快速生成树RSTP
  • redis:zset有序集合命令和内部编码
  • 漏洞扫描工具和漏洞利用工具
  • C++ 11新特性:列表初始化,右值引用与移动语义
  • 《TCP/IP网络编程》学习笔记 | Chapter 9:套接字的多种可选项
  • 【JavaEE】JUC的常见类
  • Android 开发指南:初学者入门