升级到Docker引擎1.10(从1.08)后,我注意到我的反向代理配置不再起作用了.
我的所有应用程序(包括反向代理的Nginx)都是容器化的,并通过容器名称进行通信.以下是Nginx中虚拟主机部分的示例:
server {
server_name jobs;
location / {
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_pass http://jenkins:8080;
}
}
现在,我只能通过IP ping Nginx容器中的Jenkins容器,但不能再通过容器名称来ping.由于更新,重新部署等IP不断变化,是否有更好的联网方式避免在反向代理配置中定义IP?
最佳答案
您可以查看
docker network connect
和docker run
附带的network-scope alias.
启动带别名的容器允许您的Nginx在其配置中将代理反向代理.
在运行时,该别名将解析为稍后启动的容器.
请参阅“Docker Networking: Auto-discovering host names in a bridge network”中的示例.
请注意,will need a key-value store在docker 1.10网络中管理容器.
注意(2016年7月)与docker 1.12及其swarm mode,它变得更加简单.
参见例如“The beautiful networking stack in Docker Swarm mode”
docker swarm将为您定义覆盖网络和键值存储!容器会看到彼此.
另一个具体的例子:“NGINX as a Reverse Proxy for Docker Swarm Clusters”
原文地址:https://www.jb51.cc/docker/436640.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。