【发布时间】:2021-01-26 14:33:37
【问题描述】:
运行基于 Windows 的容器我无法从内部访问互联网。示例:
我可以在我的主机上运行以下命令:
PS C:\Developer> nslookup aka.ms
Server: cache100.ns.tdc.net
Address: 193.162.153.164
Non-authoritative answer:
Name: aka.ms
Address: 88.221.62.148
当我尝试从容器内执行此操作时:
PS C:\Developer> docker run mcr.microsoft.com/dotnet/framework/runtime:4.8-windowsservercore-ltsc2019 powershell nslookup aka.ms
*** UnKnown can't find aka.ms: Server failed
Server: UnKnown
Address: 172.28.112.1
虽然我对 aka.ms 并不特别感兴趣,但我尝试连接的所有服务都会发生此错误,因此我无法安装外部库等。
我正在运行 Docker Desktop v19.03.12。无论我是否启用了 WSL 2,都会发生这种行为,并且我的 Docker 设置都是默认设置。
注意:我前段时间经历过这种行为。那时我将以下 sn-p 添加到我的 Dockerfile 中:
RUN powershell -command certutil -generateSSTFromWU roots.sst && certutil -addstore -f root roots.sst && del roots.sst
据我了解,这将安装一个 SSH 证书,从而解决了该问题。然而,这个命令现在失败了:
PS C:\> certutil -generateSSTFromWU roots.sst
The server name or address could not be resolved 0x80072ee7 (WinHttp: 12007 ERROR_WINHTTP_NAME_NOT_RESOLVED) -- http://ctldl.windowsupdate.com/msdownload/update/v3/static/truste
dr/en/authrootstl.cab
CertUtil: -generateSSTFromWU command FAILED: 0x80072ee7 (WinHttp: 12007 ERROR_WINHTTP_NAME_NOT_RESOLVED)
CertUtil: The server name or address could not be resolved
【问题讨论】:
标签: docker docker-for-windows docker-networking windows-container