+-
Docker 1.10通过主机名从主机访问容器
我有Docker版本1.10与嵌入式DNS服务.

我在docker-compose文件中创建了两个服务容器.它们可以通过主机名和IP相互访问,但是当我想从主机到达其中一个时,它不起作用,它只适用于IP但不适用于主机名.

那么,是否可以通过Docker 1.10中的主机名从主机访问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网络检查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": {}
    }
]
最佳答案
这就是我的工作.

我编写了一个名为dnsthing的Python脚本,该脚本监听Docker事件API以启动或停止容器.它维护一个主机样式的文件,其中包含容器的名称和地址.容器名为< container_name>.< network> .docker,例如,如果我运行此命令:

docker run --rm --name mysql -e MYSQL_ROOT_PASSWORD=secret  mysql

我明白了:

172.17.0.2 mysql.bridge.docker

然后我运行指向此hosts文件的dnsmasq进程.具体来说,我使用以下配置运行dnsmasq实例:

listen-address=172.31.255.253
bind-interfaces
addn-hosts=/run/dnsmasq/docker.hosts
local=/docker/
no-hosts
no-resolv

我像这样运行dnsthing脚本:

dnsthing -c "systemctl restart dnsmasq_docker" \
  -H /run/dnsmasq/docker.hosts --verbose

所以:

> dnsthing将/run/dnsmasq/docker.hosts更新为容器
停止/启动
>更新后,dnsthing运行systemctl restart dnsmasq_docker
> dnsmasq_docker使用上面的配置绑定运行dnsmasq
到地址为172.31.255.253的本地网桥接口.
>我的系统上的“主”dnsmasq进程,由.维护
NetworkManager使用此配置
/etc/NetworkManager/dnsmasq.d/dockerdns:

server=/docker/172.31.255.253

这告诉dnsmasq在.docker中传递所有主机请求
域到docker_dnsmasq服务.

这显然需要一些设置来将所有内容放在一起,但是
之后,似乎只是工作:

$ping -c1  mysql.bridge.docker
PING mysql.bridge.docker (172.17.0.2) 56(84) bytes of data.
64 bytes from 172.17.0.2: icmp_seq=1 ttl=64 time=0.087 ms

--- mysql.bridge.docker ping statistics ---
1 packets transmitted, 1 received, 0% packet loss, time 0ms
rtt min/avg/max/mdev = 0.087/0.087/0.087/0.000 ms
点击查看更多相关文章

转载注明原文:Docker 1.10通过主机名从主机访问容器 - 乐贴网