技术小黑屋

为终端设置Shadowsocks代理

做开发的同学,应该都会经常接触终端,有些时候我们在终端会做一些网络操作,比如下载gradle包等,由于一些你懂我也懂的原因,某些网络操作不是那么理想,这时候我们就需要设置代理来自由地访问网络。

Shadowsocks是我们常用的代理工具,它使用socks5协议,而终端很多工具目前只支持http和https等协议,对socks5协议支持不够好,所以我们为终端设置shadowsocks的思路就是将socks协议转换成http协议,然后为终端设置即可。仔细想想也算是适配器模式的一种现实应用吧。

想要进行转换,需要借助工具,这里我们采用比较知名的polipo来实现。polipo是一个轻量级的缓存web代理程序。闲话休叙,让我们开始动手吧。

准备工作

安装

Fedora安装

1
sudo yum install polipo

Mac下使用Homebrew安装

1
brew install polipo

Ubuntu安装

1
sudo apt-get install polipo

修改配置(Linux)

如下打开配置文件

1
sudo vim /etc/polipo/config

设置ParentProxy为Shadowsocks,通常情况下本机shadowsocks的地址如下

1
2
3
4
# Uncomment this if you want to use a parent SOCKS proxy:

socksParentProxy = "localhost:1080"
socksProxyType = socks5

设置日志输出文件

1
2
logFile=/var/log/polipo
logLevel=4

修改配置(Mac)

设置每次登陆启动polipo

1
ln -sfv /usr/local/opt/polipo/*.plist ~/Library/LaunchAgents

修改文件/usr/local/opt/polipo/homebrew.mxcl.polipo.plist设置parentProxy

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
  <dict>
    <key>Label</key>
    <string>homebrew.mxcl.polipo</string>
    <key>RunAtLoad</key>
    <true/>
    <key>KeepAlive</key>
    <true/>
    <key>ProgramArguments</key>
    <array>
        <string>/usr/local/opt/polipo/bin/polipo</string>
        <string>socksParentProxy=localhost:1080</string>
    </array>
    <!-- Set `ulimit -n 20480`. The default OS X limit is 256, that's
         not enough for Polipo (displays 'too many files open' errors).
         It seems like you have no reason to lower this limit
         (and unlikely will want to raise it). -->
    <key>SoftResourceLimits</key>
    <dict>
      <key>NumberOfFiles</key>
      <integer>20480</integer>
    </dict>
  </dict>
</plist>

修改的地方是增加了<string>socksParentProxy=localhost:1080</string>

启动(Linux)

先关闭正在运行的polipo,然后再次启动

1
2
sudo service polipo stop
sudo service polipo start

启动(Mac)

1
2
launchctl unload ~/Library/LaunchAgents/homebrew.mxcl.polipo.plist
launchctl load ~/Library/LaunchAgents/homebrew.mxcl.polipo.plis

注意:请确保Shadowsocks正常工作。

验证及使用

安装完成就需要进行验证是否work。这里展示一个最简单的验证方法,打开终端,如下执行

1
2
3
4
07:56:24-androidyue/var/log$ curl ip.gs
当前 IP:125.39.112.15 来自:中国天津天津 联通
08:09:23-androidyue/var/log$ http_proxy=http://localhost:8123 curl ip.gs
当前 IP:210.140.193.128 来自:日本日本

如上所示,为某个命令设置代理,前面加上http_proxy=http://localhost:8123 后接命令即可。

注:8123是polipo的默认端口,如有需要,可以修改成其他有效端口。

设置别名

bash中有一个很好的东西,就是别名alias. Linux用户修改~/.bashrc,Mac用户修改~/.bash_profile文件,增加如下设置

1
alias hp="http_proxy=http://localhost:8123"

然后Linux用户执行source ~/.bashrc,Mac用户执行source ~/.bash_profile

测试使用

1
2
3
4
5
20:39:39-androidyue~$ curl ip.gs
当前 IP:125.39.112.14 来自:中国天津天津 联通
20:39:44-androidyue~$ hp curl ip.gs
当前 IP:210.140.193.128 来自:日本日本 
20:39:48-androidyue~$ 

当前会话全局设置

如果嫌每次为每一个命令设置代理比较麻烦,可以为当前会话设置全局的代理。即使用export http_proxy=http://localhost:8123即可。 如果想撤销当前会话的http_proxy代理,使用 unset http_proxy 即可。 示例效果如下

1
2
3
4
5
6
7
8
21:29:49-androidyue~$ curl ip.gs
当前 IP:125.39.112.14 来自:中国天津天津 联通
21:29:52-androidyue~$ export http_proxy=http://localhost:8123
21:30:07-androidyue~$ curl ip.gs
当前 IP:210.140.193.128 来自:日本日本 
21:30:12-androidyue~$ unset http_proxy
21:30:37-androidyue~$ curl ip.gs
当前 IP:125.39.112.14 来自:中国天津天津 联通

如果想要更长久的设置代理,可以将export http_proxy=http://localhost:8123加入.bashrc或者.bash_profile文件

设置Git代理

复杂一些的设置Git代理

1
2
3
4
5
6
7
8
git clone https://android.googlesource.com/tools/repo --config http.proxy=localhost:8123

Cloning into 'repo'...
remote: Counting objects: 135, done
remote: Finding sources: 100% (135/135)
remote: Total 3483 (delta 1956), reused 3483 (delta 1956)
Receiving objects: 100% (3483/3483), 2.63 MiB | 492 KiB/s, done.
Resolving deltas: 100% (1956/1956), done.

其实这样还是比较复杂,因为需要记忆的东西比较多,下面是一个更简单的实现

首先,在.bashrc或者.bash_profile文件加入这一句。

1
gp=" --config http.proxy=localhost:8123"

然后执行source操作,更新当前bash配置。

更简单的使用git的方法

1
2
3
4
5
6
7
8
git clone  https://android.googlesource.com/tools/repo $gp

Cloning into 'repo'...
remote: Counting objects: 135, done
remote: Finding sources: 100% (135/135)
remote: Total 3483 (delta 1956), reused 3483 (delta 1956)
Receiving objects: 100% (3483/3483), 2.63 MiB | 483 KiB/s, done.
Resolving deltas: 100% (1956/1956), done.

开始自由快速的开发吧。

以上。


知乎 Live 推荐

我将要在知乎上进行我的第二场 Live,题为《我学安卓的那些套路》,来分享我学习安卓的经验与心得。覆盖的内容如下:

  • Android 需要打好哪些编程基础?
  • 除了编程基础,我们还需要补充哪些能力?
  • 作为 Android 程序员,如何把握好技术的宽度和深度?
  • Android 每块知识学到什么程度,怎么做到?
  • 如何从日常的工作中获取最大的收益?
  • Android 那么多库,我该选择哪些,怎么学,学到什么程度?
  • 对于初学者或大学生的建议有哪些?

如果你想听一听我的经验或者有疑惑,欢迎参与。

参与地址:https://www.zhihu.com/lives/802899577341620224