Docker Desktop for Windows: cannot access service on exposed port in windows container mode

前端 未结 4 2202
隐瞒了意图╮
隐瞒了意图╮ 2021-02-19 04:09

I am using the following Dockerfiles to create a container running Jenkins in a windows container on Windows 10 desktop running Docker Desktop for Windo

相关标签:
4条回答
  • 2021-02-19 04:45

    To complete @Kallie-Microsoft post:

    docs.docker.com have been updated with a section Limitations of Windows containers for localhost and published ports


    Docker for Windows provides the option to switch Windows and Linux containers. If you are using Windows containers, keep in mind that there are some limitations with regard to networking due to the current implementation of Windows NAT (WinNAT). These limitations may potentially resolve as the Windows containers project evolves.

    One thing you may encounter rather immediately is that published ports on Windows containers do not do loopback to the local host. Instead, container endpoints are only reachable from the host using the container’s IP and port.

    So, in a scenario where you use Docker to pull an image and run a webserver with a command like this:

    docker run -d -p 80:80 --name webserver nginx
    

    Using curl http://localhost, or pointing your web browser at http://localhost will not display the nginx web page (as it would do with Linux containers).

    In order to reach a Windows container from the local host, you need to specify the IP address and port for the container that is running the service.

    You can get the container IP address by using docker inspect with some --format options and the ID or name of the container. For the example above, the command would look like this, using the name we gave to the container (webserver) instead of the container ID:

    $ docker inspect \
      --format='{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' \
      webserver
    
    0 讨论(0)
  • 2021-02-19 04:50

    I faced the same issue, the ordering of docker run command matters.

    docker run -p <host port>:<container port> <image> Works

    docker run <image> -p <host port>:<container port> Doesn't Work

    My setup -

    Using Windows 10 , Version 2004 (OS build 19041.329) WSL 2 enabled - https://docs.microsoft.com/en-us/windows/wsl/wsl2-index Ubuntu 18.04 installed from Microsoft store and its enabled in docker.

    image

    0 讨论(0)
  • 2021-02-19 05:00

    Looks this issue does not seem to be so boring as it was. Followings docs at https://docs.docker.com/engine/reference/run/#expose-incoming-ports you can specify an IP address at the host machine where you want container's port(s) to be exposed.

    -p=[] : Publish a container's port or a range of ports to the host
                   format: ip:hostPort:containerPort | ip::containerPort | hostPort:containerPort | containerPort
                   Both hostPort and containerPort can be specified as a
                   range of ports. When specifying ranges for both, the
                   number of container ports in the range must match the
                   number of host ports in the range, for example:
                       -p 1234-1236:1234-1236/tcp
                   When specifying a range for hostPort only, the
                   containerPort must not be a range.  In this case, the container port is published somewhere within the specified hostPort range. (e.g., `-p 1234-1236:1234/tcp`)
                   (use 'docker port' to see the actual mapping)
    

    Probably that is 127.0.0.1, and it resolves an issue with access to exposed Docker container port on the Windows system. Just use -p switch with IP address when running container.

    docker run --rm -it -p 127.0.0.1:3000:3000 ubuntu:latest
    
    0 讨论(0)
  • 2021-02-19 05:02

    This is a currently a known issue on Windows. It's not possible to access a container endpoint from its own host using localhost/127.0.0.1. It is possible using Linux containers today because Docker has included a special workaround that is unique to their Moby/Linux implementation for running Linux containers on Windows.

    We're working on a fix for this, but today we recommend working around this by either:

    • Accessing container endpoints from a separate host, using the IP address of the host that is running the container, and the exposed port for the container on its host
    • OR by accessing the container on the same host, using the container's internal IP address and published port (you can use docker network inspect <network name> or docker exec <container ID> ipconfig> to get the IP address of the container endpoint itself)
    0 讨论(0)
提交回复
热议问题