我有嵌入式DNS服务的Docker版本1.10。
我在我的docker-compose文件中创建了两个服务容器,它们可以通过主机名和IP访问,但是当我想从主机访问其中一个时,它不起作用,它只能通过IP访问,而不能通过主机名访问。
那么,是否可以通过Docker 1.10中的主机名从主机访问Docker容器?
- 更新日期:**
docker-compose.yml
version: '2'
services:
service_a:
image: nginx
container_name: docker_a
ports:
- 8080:80
service_b:
image: nginx
container_name: docker_b
ports:
- 8081:80
然后我用命令启动它docker-compose up --force-recreate
当我跑步时:
docker exec -i -t docker_a ping -c4 docker_b
-它工作正常docker exec -i -t docker_b ping -c4 docker_a
-它工作正常ping 172.19.0.2
-它工作(172.19.0.2
是docker_b
的ip)ping docker_a
-失败
docker network inspect test_default
的结果为
[
{
"Name": "test_default",
"Id": "f6436ef4a2cd4c09ffdee82b0d0b47f96dd5aee3e1bde068376dd26f81e79712",
"Scope": "local",
"Driver": "bridge",
"IPAM": {
"Driver": "default",
"Options": null,
"Config": [
{
"Subnet": "172.19.0.0/16",
"Gateway": "172.19.0.1/16"
}
]
},
"Containers": {
"a9f13f023761123115fcb2b454d3fd21666b8e1e0637f134026c44a7a84f1b0b": {
"Name": "docker_a",
"EndpointID": "a5c8e08feda96d0de8f7c6203f2707dd3f9f6c3a64666126055b16a3908fafed",
"MacAddress": "02:42:ac:13:00:03",
"IPv4Address": "172.19.0.3/16",
"IPv6Address": ""
},
"c6532af99f691659b452c1cbf1693731a75cdfab9ea50428d9c99dd09c3e9a40": {
"Name": "docker_b",
"EndpointID": "28a1877a0fdbaeb8d33a290e5a5768edc737d069d23ef9bbcc1d64cfe5fbe312",
"MacAddress": "02:42:ac:13:00:02",
"IPv4Address": "172.19.0.2/16",
"IPv6Address": ""
}
},
"Options": {}
}
]
5条答案
按热度按时间5lhxktic1#
作为answered here,有一个软件解决方案,称为DNS代理服务器。
whitzsjs2#
为了专门解决这个问题,我创建了一个简单的“etc/hosts”域注入tool,用于解析主机上本地Docker容器的名称。
您将能够使用
container name
、hostname
、container id
和víanetwork aliases
访问容器,这些变量已为每个网络声明。容器在启动时自动注册,在暂停、停用或停止时自动删除。
zzlelutf3#
我是这么做的。
我写了一个名为dnsthing的Python脚本,它监听Docker事件API来启动或停止容器,它维护一个
hosts
样式的文件,其中包含容器的名称和地址,容器被命名为<container_name>.<network>.docker
,例如,如果我运行以下命令:我得到这个:
然后运行一个指向
hosts
文件的dnsmasq
进程,具体来说,使用以下配置运行一个dnsmasq示例:我运行
dnsthing
脚本,如下所示:因此:
dnsthing
在容器停止/开始时更新/run/dnsmasq/docker.hosts
dnsthing
将运行systemctl restart dnsmasq_docker
dnsmasq_docker
使用上述配置运行dnsmasq
,绑定到地址为172.31.255.253
的本地网桥接口。/etc/NetworkManager/dnsmasq.d/dockerdns
中的以下配置:它告诉dnsmasq将
.docker
域中主机的所有请求传递给docker_dnsmasq
服务。这显然需要一点设置才能把所有的东西放在一起,但在那之后,它似乎只是工作:
oipij1gg4#
最简单的方法是将条目添加到主机文件中
127.0.0.1 docker_a docker_b
添加到/etc/hosts文件docker-machine ip default
的ip8fsztsew5#
与@larsks类似,我也写了一个Python脚本,但将其实现为服务,如下所示:https://github.com/nicolai-budico/dockerhosts
它使用参数
--hostsdir=/var/run/docker-hosts
启动dnsmasq,并在每次运行的container列表更改时更新文件/var/run/docker-hosts/hosts
。一旦文件/var/run/docker-hosts/hosts
更改,dnsmasq将自动更新其Map,container将在一秒钟内按主机名可用。有安装和卸载脚本。您只需要允许您的系统与此dnsmasq示例交互。我在systemd-resolved中注册了: