We read every piece of feedback, and take your input very seriously.
To see all available qualifiers, see our documentation.
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
This issue is not limited to a specific configuration. I have tested both Mihomo and Sing-box.
When using TUN mode on Linux, it affects running containers, making their mapped ports inaccessible. Stopping TUN mode restores normal access.
预期: docker pull 通过tun模式(当前如此); docker build 通过tun模式(当前如此); docker run的容器映射的端口可以被外部主机正常访问(当前不可用); 容器内部最好可以通过主机的tun模式。
网络上其他同样问题: Reference 1 Reference 2
外网访问内网 docker 问题 也可以说外网访问局域网内机器(非网关机器)的问题。我们这样配置好后,会发现无法从外网访问内网的 docker 服务(设置路由器端口转发)。可以通过手机流量访问测试。 我是参考该 github issue 受到了启发,最终解决了。 跳过 docker0 的 ip 范围。即跳过 docker 服务的出站数据包 sudo iptables -t mangle -A clash -p tcp -s 172.18.0.0/16 -j RETURN 然后以下是个人的推测,可能有误,仅供参考。 首先手机入站数据包经过路由器,NAT 到 docker 服务(网关机器)上。此时因为 dest ip 是内网 ip,clash 链 会跳过。DOCKER 链 接手处理,通过 DNAT 转发到了 docker0 bridge 网卡上,这几步都很正常。顺利到达 docker 容器。 随后是 docker 容器的出站数据包,此时数据包会从 docker0 bridge 发到宿主机的物理网卡 eth 网卡。这时数据包之于宿主机来说,是一个入站数据包。数据包会经过 PREROUTING 链,jump 到 clash 链,而此时的 dest ip 为手机的 ip 。会被转发到 clash 上处理,但这个数据包只在出站时转发给 clash 处理。入站的时候跳过了。估计 clash 无法处理这个数据包,可能就丢弃了。就出现了外网无法访问内网 docker 容器的问题。 所以根据 source ip 判断, 将 docker 容器的数据包也跳过。跳过后就解决了~
外网访问内网 docker 问题
也可以说外网访问局域网内机器(非网关机器)的问题。我们这样配置好后,会发现无法从外网访问内网的 docker 服务(设置路由器端口转发)。可以通过手机流量访问测试。
我是参考该 github issue 受到了启发,最终解决了。
sudo iptables -t mangle -A clash -p tcp -s 172.18.0.0/16 -j RETURN
然后以下是个人的推测,可能有误,仅供参考。
首先手机入站数据包经过路由器,NAT 到 docker 服务(网关机器)上。此时因为 dest ip 是内网 ip,clash 链 会跳过。DOCKER 链 接手处理,通过 DNAT 转发到了 docker0 bridge 网卡上,这几步都很正常。顺利到达 docker 容器。
随后是 docker 容器的出站数据包,此时数据包会从 docker0 bridge 发到宿主机的物理网卡 eth 网卡。这时数据包之于宿主机来说,是一个入站数据包。数据包会经过 PREROUTING 链,jump 到 clash 链,而此时的 dest ip 为手机的 ip 。会被转发到 clash 上处理,但这个数据包只在出站时转发给 clash 处理。入站的时候跳过了。估计 clash 无法处理这个数据包,可能就丢弃了。就出现了外网无法访问内网 docker 容器的问题。
所以根据 source ip 判断, 将 docker 容器的数据包也跳过。跳过后就解决了~
The text was updated successfully, but these errors were encountered:
如果是用mihomo的tun,可以配置 "exclude-interface:
Sorry, something went wrong.
如果是用mihomo的tun,可以配置 "exclude-interface: * docker0" 将docker的网络接口从tun中排除就能解决。
* docker0" 将docker的网络接口从tun中排除就能解决。
当前的Linux主机被回收了,等有了合适的机子再测试。 或者其他有兴趣的伙伴看到后帮忙测试一下吧。 Mac 上不需要 exclude-interface ,容器映射的端口可以被外部主机正常访问。这个选项的意思应当是不去管docker0的流量,倘若这个选项使docker build和 docker pull 不走tun,就得不偿失了。
docker build
docker pull
@nekomeowww 不知你可有时间了解这个问题。
我还没有折腾过类似的配置,可以试试看。
具体的使用场景: 一台Linux主机(用的是Ubuntu 20及以上)使用docker部署了多个服务,并有对外的端口映射。 现在部署一个新服务,使用mihomo或者singbox的tun模式(使用这个模式可以不用改docker daemon的配置和proxy环境变量)来加速docker pull image 和 docker build image;但发现已经部署的服务不能访问,停掉加速后就恢复正常。
No branches or pull requests
This issue is not limited to a specific configuration.
I have tested both Mihomo and Sing-box.
When using TUN mode on Linux, it affects running containers, making their mapped ports inaccessible.
Stopping TUN mode restores normal access.
预期:
docker pull 通过tun模式(当前如此);
docker build 通过tun模式(当前如此);
docker run的容器映射的端口可以被外部主机正常访问(当前不可用);
容器内部最好可以通过主机的tun模式。
网络上其他同样问题:
Reference 1
Reference 2
The text was updated successfully, but these errors were encountered: