免费注册 查看新帖 |

ChinaUnix.net

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 9810 | 回复: 0

docker运行redis sentinel遇到问题,客户端查询到的master是docker内网ip [复制链接]

论坛徽章:
2
IT运维版块每日发帖之星
日期:2016-04-15 06:20:0015-16赛季CBA联赛之福建
日期:2016-08-08 13:37:03
发表于 2016-08-17 13:43 |显示全部楼层
我在host1上运行docker,容器里运行了redis sentinel,并把端口6379,26379等等都暴露出来了。

我在host2上,运行redis-cli,连接sentinel查询master地址时,
返回的是docker network的内网地址(172.xxx...),而不是host1的IP。
问题是从host2无法连接到docker内网地址。

请问,是不是需要在redis配置文件中,明确写主机(host1)的IP,而不是容器的IP?


由于每次容器启动时IP地址都是随机的,所以一些集群的服务(像zookeeper,redis sentinel),
配置时用ip地址来配置是不行的,需要用容器的主机名来配置。
(docker run 可以用--name设置主机名,这样docker network内可以通过DNS解析出主机。)

我不理解的是,像redis sentinel这样,需要把master的IP返回给客户端的情况,
怎样控制返回的ip是docker内网ip,还是主机ip呢?
如果客户端在docker network中,返回内网ip即可,
如果客户端在其他主机,就需要返回主机ip。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

基于案例的 SQL 优化实战训练营

讲师:中电福富特级专家梁敬彬,参与本次课程培训,你将收获:
1. 能编写出较为高效的 SQL;
2. 能解决70%以上的数据库常见优化问题;
3. 能得到老师提供的高效的相关工具和解决方案;
4. 能举一反三,收获不仅仅是 SQL 优化。
现在购票享受8.8折优惠!
----------------------------------------
优惠时间:2019年3月20日前

大会官网>>
  

北京盛拓优讯信息技术有限公司. 版权所有 16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122
中国互联网协会会员  联系我们:huangweiwei@it168.com
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP