免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 33951 | 回复: 0
打印 上一主题 下一主题

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

论坛徽章:
2
IT运维版块每日发帖之星
日期:2016-04-15 06:20:0015-16赛季CBA联赛之福建
日期:2016-08-08 13:37:03
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 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。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP