由于Ubuntu Server是不带用户界面的,所以要为Server配置Shadowsocks还是稍显麻烦。本文就是我配置Shadowsocks的一些经验,以待参考。

安装shadowsocks

由于shadowsocks是基于python开发的,所以必须安装python:

1
sudo apt-get install python

接着安装python的包管理器pip:

1
sudo apt-get install python-pip

安装完毕之后,通过pip直接安装shadowsocks:

1
sudo pip install shadowsocks

配置shadowsocks

新建一个配置文件shawdowsocks.json,然后配置相应的参数:

1
2
3
4
5
6
7
8
{
"server": "{your-server}",
"server_port": 40002,
"local_port": 1080,
"password": "{your-password}",
"timeout": 600,
"method": "aes-256-cfb"
}

上面的参数需要你的shawdowsocks服务提供商为你提供,当然你也可以自己搭建一个。如何搭建个人的shawdowsocks不在本文讨论范围之内,请参阅其他教程。

配置完成后就可以启动shawdowsocks服务:

1
sudo sslocal -c shawdowsocks.json -d start

配置全局代理

启动shawdowsocks服务后,发现并不能翻墙上网,这是因为shawdowsocks是socks 5代理,需要客户端配合才能翻墙。

为了让整个系统都走shawdowsocks通道,需要配置全局代理,可以通过polipo实现。

首先是安装polipo:

1
sudo apt-get install polipo

接着修改polipo的配置文件/etc/polipo/config

1
2
3
4
5
6
7
8
9
10
11
12
13
14
logSyslog = true
logFile = /var/log/polipo/polipo.log

proxyAddress = "0.0.0.0"

socksParentProxy = "127.0.0.1:1080"
socksProxyType = socks5

chunkHighMark = 50331648
objectHighMark = 16384

serverMaxSlots = 64
serverSlots = 16
serverSlots1 = 32

重启polipo服务:

1
sudo /etc/init.d/polipo restart

为终端配置http代理:

1
export http_proxy="http://127.0.0.1:8123/"

接着测试下能否翻墙:

1
curl www.google.com

如果有响应,则全局代理配置成功。

注意事项

服务器重启后,下面两句需要重新执行:

1
2
sudo sslocal -c shawdowsocks.json -d start
export http_proxy="http://127.0.0.1:8123/"