Ubuntu「一键」设置代理
<span style = 'color:red' >sonictl note: the DNS problem may be still there. Except proxychains
. </span>
WSL (Windows Subsystem for Linux) or Ubuntu is OK for this tutorial. Other linux can also try this.
1. Windows first
-
Proxifier --> Clash
-
Walls on UWP apps: Use Fiddler
WinConfig
tool to disable it. -
WSL:
- 使用 SSTap 直接接管 Windows 除了 Windows 系统进程以外的网络层,当然也包括 WSL
- Proxifier 并不能实现对 WSL 启用代理
- 相对最完美的方法是使用 Proxychains, 但不方便
- 直接在终端配置 proxy, 如果在WSL上使用的app不多。
2. Linux, WSL: Configure proxy in Terminal
two lines of cmds:
export ALL_PROXY="socks5://127.0.0.1080"
export all_proxy="socks5://127.0.0.1080"
这样 curl
wget
是都走代理了,包括 git
npm
yarn
.
如果需要设置 APT 走代理,需要修改 /etc/apt/apt.conf
:
echo -e "Acquire::http::Proxy \"http://127.0.0.1:1090\";" | sudo tee -a /etc/apt/apt.conf > /dev/null
echo -e "Acquire::https::Proxy \"http://127.0.0.1:1090\";" | sudo tee -a /etc/apt/apt.conf > /dev/null
3. Linux, WSL:【一键】解除、设置代理:
在 ~/.bashrc
or ~/.zshrc
里把解除代理和启用代理写成两个 function:proxy()
和 noproxy()
,每次只要执行 proxy
就可以启用代理、执行 noproxy
解除代理,近似实现「一键操作」。可在 function 中加上 curl ip.gs
来测试当前 IP。
here are the codes:
proxy () {
export ALL_PROXY="socks5://127.0.0.1:1080"
export all_proxy="socks5://127.0.0.1:1080"
echo -e "Acquire::http::Proxy \"http://127.0.0.1:1090\";" | sudo tee -a /etc/apt/apt.conf > /dev/null
echo -e "Acquire::https::Proxy \"http://127.0.0.1:1090\";" | sudo tee -a /etc/apt/apt.conf > /dev/null
curl https://ip.gs
}
noproxy () {
unset ALL_PROXY
unset all_proxy
sudo sed -i -e '/Acquire::http::Proxy/d' /etc/apt/apt.conf
sudo sed -i -e '/Acquire::https::Proxy/d' /etc/apt/apt.conf
curl https://ip.gs
}
ps: zsh是一个终端环境,和bash类似。~/.zshrc就是zsh的配置文件,你可以自行更改。
read more: Mac OSX终端走shadowsocks代理
原文:
2018-11-29 笔记本
首先虽然题目包含 Ubuntu 但是实际上苏卡卡解决的是 WSL 的代理问题的 WSL 是最好的 Linux 发行版;而且 Ubuntu 超级棒的 不出内部错误的话!苏卡卡的方案也是通用于几乎所有 Linux 的。
在 Windows 上使用全局代理亦或是透明代理真是太困难了。我之前在用 SSTap 实现全局代理;后来 Clash 和 Clash for Windows 出来以后就直接去用 Clash 了 界面漂亮才是第一生产力! 我就直接把 难看的 SSTap 丢掉了。但是 Clash 只是一个代理程序,并不能提供全局代理的方案。 好在 Windows 上实现全局代理或者分应用代理还有一个常用的方案——Proxifier,我可以通过 Proxifier 把绝大部分应用的流量转发到 Clash 上面去,Windows 给 UWP 应用做的应用隔离则可以使用 Fiddler 的 WinConfig
工具解除掉。
但关键是 WSL。之前使用 SSTap 直接接管 Windows 除了 Windows 系统进程以外的网络层,当然也包括 WSL。Proxifier 并不能实现对 WSL 启用代理了,所以用 Proxifier 就得解决 WSL 也走代理的方法。
在 Google 上找遍了「Linux 全局代理」,相对最完美的方法是使用 Proxychains,但每个指令前面都要带个 proxychains
真的太不方便了;使用 iptables
的透明代理方案在 WSL 上面也并不适用(WSL 和 Windows 两者是相互依赖的、我不想在 Ubuntu 上设置 iptables
结果把宿主 Windows 炸掉)。 既然没有,那就干脆不要了!直接在终端配置 proxy,反正目前在 WSL 上使用的应用和环境并不多。
给终端设置代理超简单的,直接一句命令搞定:
export ALL_PROXY="socks5://127.0.0.1080"
这样 curl
wget
是都走代理了,但是 git
npm
yarn
这些不知为何不跟随终端的环境变量设置。一种解决方案是分别设置:
git config --global http.proxy "socks5://127.0.0.1080"
git config --global https.proxy "socks5://127.0.0.1080"
npm config set proxy "http://127.0.0.1090"
npm config set https-proxy "http://127.0.0.1090"
yarn config set proxy "http://127.0.0.1090"
yarn config set https-proxy "http://127.0.0.1090"
但是苏卡卡发现了一个奇怪的解决方法,就是除了设置 ALL_RPOXY
以外再添加一个 all_proxy
:
export all_proxy="socks5://127.0.0.1080"
这样不仅 git
npm
yarn
这些读取环境变量不支持大小写的辣鸡,其它绝大部分终端应用程序不走代理的问题就都解决了~
不过包管理器 APT 就更麻烦了。如果需要设置 APT 走代理,需要修改 /etc/apt/apt.conf
:
echo -e "Acquire::http::Proxy \"http://127.0.0.1:1090\";" | sudo tee -a /etc/apt/apt.conf > /dev/null
echo -e "Acquire::https::Proxy \"http://127.0.0.1:1090\";" | sudo tee -a /etc/apt/apt.conf > /dev/null
敲了好一会键盘以后苏卡卡想起了一个问题——如果要解除代理应该怎么办。。。
于是苏卡卡在 .zshrc
里面把解除代理和启用代理写成了两个 function:proxy()
和 noproxy()
,每次只要执行 proxy
就可以启用代理、执行 noproxy
解除代理,近似实现「一键操作」。而且,还可以在 function 中加上 curl ip.gs
来测试当前 IP。
Talk is cheap, here are the codes:
proxy () {
export ALL_PROXY="socks5://127.0.0.1:1080"
export all_proxy="socks5://127.0.0.1:1080"
echo -e "Acquire::http::Proxy \"http://127.0.0.1:1090\";" | sudo tee -a /etc/apt/apt.conf > /dev/null
echo -e "Acquire::https::Proxy \"http://127.0.0.1:1090\";" | sudo tee -a /etc/apt/apt.conf > /dev/null
curl https://ip.gs
}
noproxy () {
unset ALL_PROXY
unset all_proxy
sudo sed -i -e '/Acquire::http::Proxy/d' /etc/apt/apt.conf
sudo sed -i -e '/Acquire::https::Proxy/d' /etc/apt/apt.conf
curl https://ip.gs
}
稍加修改也可以写进
.bashrc
之中
苏卡卡最终的版本用 read
实现了读取输入来获取代理地址、而不是直接使用预置 127.0.0.1:1080
的方案。代码开在 这里。如果各位路过的大佬有什么更高明的 Linux 全局代理或者 WSL 由 Windows 接管代理的方法,请务必点醒菜鸡苏卡卡。
本文作者 : Sukka 本文采用 CC BY-NC-SA 4.0 许可协议。转载和引用时请注意遵守协议! 本文链接 : https://blog.skk.moe/post/enable-proxy-on-ubuntu/
来源:oschina
链接:https://my.oschina.net/u/4354518/blog/3366297