Hello! 欢迎来到小浪云!


云服务器docker如何访问宿主机ip


avatar
小浪云 2024-09-23 50


docker容器默认是通过桥接方式与宿主机共享网络的。在默认情况下,容器无法直接访问宿主机的IP地址,但可以通过以下几种方式让docker容器访问宿主机的IP:

1. 使用特殊DNS名称 `host.docker.internal`

docker提供了一个特殊的DNS名称`host.docker.internal`,它可以在容器内解析为宿主机的内部IP地址。在docker版本18.03及以上,你可以在容器内使用`host.docker.internal`来访问宿主机。

docker run -d --name mycontainer myimage

在容器内部,你可以通过如下方式访问宿主机的IP:

import socket  host_ip = socket.gethostbyname('host.docker.internal')

2. 使用 `–add-host` 参数

在启动容器时,可以使用`–add-host`参数将宿主机的IP映射到一个自定义的主机名。例如:

docker run --add-host host.docker.internal:$(ip route | awk '/default/ {print $3}') -d myimage

这个命令会将宿主机的默认网关IP(通常就是宿主机的IP)映射到`host.docker.internal`。

3. 端口映射

将宿主机的端口映射到容器的端口,容器可以通过映射后的端口与外界通信。在启动容器时使用`-p`或`–publish`标志来指定端口映射:

docker run -p 8080:80 myimage

上面的命令将宿主机的8080端口映射到容器的80端口。这样,你可以通过访问宿主机的IP和端口8080来访问容器中运行的服务。

### 4. 直接使用宿主机网络

如果你的容器需要直接使用宿主机的网络,可以在启动容器时使用`–network host`选项。这会使容器共享宿主机的网络命名空间,但请注意,这可能会导致端口冲突。

docker run --network host myimage

5. 使用 docker Compose 或 docker Networking

如果你使用docker Compose,可以在`docker-compose.yml`文件中指定网络模式。同样,也可以使用docker自定义网络来让容器之间以及容器与宿主机之间进行通信。

version: '3'  services:    myservice:      networks:        - hostnet  networks:    hostnet:      external:        name: host

在这里,`host`网络模式意味着服务将使用宿主机的网络。

注意事项

– 使用`host.docker.internal`时,确保你的docker版本是18.03或以上。

– 端口映射是最常用的方式,因为它不依赖于docker的特定版本。

– 直接使用宿主机网络(`–network host`)可能会带来安全风险,因为它允许容器访问宿主机上的所有网络接口和端口。

使用哪种方式取决于具体的使用场景和需求。

相关阅读