在Mac和Windows上,可以在容器内部使用host.docker.internal (Docker 18.03+)。
Linux上是否有一种不需要传递env变量或使用各种CLI命令提取它就能开箱即用的方法?
在Mac和Windows上,可以在容器内部使用host.docker.internal (Docker 18.03+)。
Linux上是否有一种不需要传递env变量或使用各种CLI命令提取它就能开箱即用的方法?
当前回答
对于linux,我可以使用我试图连接到的服务名,例如,我的一个容器(php-fpm)试图连接到mysql,所以我使用mysql作为主机名,因为这是我的docker-compose中的服务名
其他回答
使用docker0接口ip(比如172.17.0.1)可能是一个很好的解决方案。
只要确保您需要访问的服务侦听外部连接即可。一个典型的例子是Mysql,默认绑定到127.0.0.1,导致无法访问,直到你允许外部连接。绑定到0.0.0.0)
对于linux系统,从docker引擎的主版本20.04开始,您现在也可以通过host.docker.internal与主机通信。这不会自动工作,但你需要提供以下运行标志:
--add-host=host.docker.internal:host-gateway
请点击这里查看答案:https://stackoverflow.com/a/61424570/3757139
请参见下面的答案,添加到docker-compose文件- https://stackoverflow.com/a/67158212/243392
如果你正在使用Docker Compose + Linux,你必须手动添加它(至少现在)。在docker-compose上使用extra_hosts。yaml文件:
version: '3.7'
services:
fpm:
build:
context: .
extra_hosts:
- "host.docker.internal:host-gateway"
不要忘记更新Docker,因为这只适用于Docker v20.10+。
来源:https://github.com/docker/for-linux/issues/264#issuecomment-784985736
tldr;通过静态IP 172.17.0.1访问主机
对主机进行HTTP请求:
IP addr show | grep "\binet\b.执行以下命令获取静态IP地址。* \ bdocker0 \ b”| awk的{打印$ 2}| 1 - d ' / ' - f 添加新的IP到允许的主机 使用刚刚在请求中找到的IP地址:req = requests.get('http://172.17.0.1:8000/api/YOUR_ENDPOINT')
一种解决方案是使用特殊的容器将流量重定向到主机。您可以在这里找到这样一个容器:https://github.com/qoomon/docker-host。其思想是从容器中获取默认路由,并将其安装为传入连接的NAT网关。
一个假想的用法:
docker-host:
image: qoomon/docker-host
cap_add: [ 'NET_ADMIN', 'NET_RAW' ]
restart: on-failure
environment:
- PORTS=999
some-service:
image: ...
environment:
SERVER_URL: "http://docker-host:999"
command: ...
depends_on:
- docker-host