docker运行redis sentinel遇到问题,客户端查询到的master是docker内网ip
我在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。