我有带有嵌入式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.2docker_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": {}
        }
    ]
    

    最佳答案

    这是我的工作。

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

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

    我得到这个:
    172.17.0.2 mysql.bridge.docker
    

    然后,我运行一个指向此dnsmasq文件的hosts进程。具体来说,我使用以下配置运行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,绑定(bind)
    到地址为172.31.255.253的本地网桥接口(interface)。
  • 系统上的“主要” 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 - Docker 1.10通过主机名通过其主机名访问容器,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/35828487/

    10-10 03:24