某些用例要求你在本机不支持代理的程序中代理流量。上一篇博客讨论了如何在 Windows 上实现这一功能,但在 Linux 甚至 Docker 容器上也有很多使用代理的案例,以增加灵活性。
在这篇博文中,我们将讨论如何使用xjasonlyu/tun2socksDocker 容器为 Docker 容器使用代理。
tun2socks是一款轻量级的便携式网络隧道工具,它允许你通过代理服务器路由流量。它由 Go 语言编写,可作为独立可执行文件或 Docker 容器使用。
在本指南中,我将重点介绍如何在 Docker 中使用它,这样你就可以将任何其他 Docker 容器连接到它,并让它使用代理服务器。
首先,我们需要创建一个初始 Docker 容器来进行代理。
docker run -d --name tun2socks \
-e EXTRA_COMMANDS='echo "nameserver 1.1.1.1" > /etc/resolv.conf;ip rule add iif lo ipproto udp dport 53 lookup main;' \
-e PROXY=http://<user>:<pass>@rp.proxyscrape.com:6060 \
-v '/dev/net/tun:/dev/net/tun' --cap-add=NET_ADMIN \
xjasonlyu/tun2socks
In this example, I am using Proxyscrape residential proxies, but you can also use premium proxies or any other proxies as well.
Now that we have created the container that does the proxying, we can use any container we want to use this container’s network by just adding the --network=container:tun2socks flag.
要测试一切工作是否正常,可以使用我创建的测试容器来返回 IPinfo 位置数据。
dockerrun--rm--network=container:tun2socks hibenji/checkip
当然,你可以在创建初始容器时使用旋转代理,也可以创建多个 tun2socks 容器,如果需要的话,所有容器都有粘性会话。
这种在 Docker 中使用代理的方法带来了无限可能。现在,您几乎可以将代理与任何 Docker 容器结合使用,即使是那些没有内置代理支持的容器。这可以增强容器化应用程序的功能,让您执行一些在没有这种网络控制水平的情况下可能很困难或不可能完成的任务。
感谢您的阅读,希望您能有所收获!
本文由ProxyScrape 用户 Benji 撰写。