服务端搭建
以下以SS指代Shadowsocks。SS分为服务器端和客户端,安装时两个都会安装上,配置文件也相同,区分服务端和客户端的是运行程序的不同。
服务端搭建主要有以下几个步骤:
- SSH登录VPS;
- 下载安装pip,shadowsocks;
- 编辑配置文件并配置开机自启动;
- 优化SS。
第一步,SSH登录VPS
方法参考之前的博文如何购买VPS及购买后的安全措施,此处不再赘述。
第二步,下载安装
Debian/Ubuntu 用户运行:
1
2
3
|
$ sudo apt-get install python-pip
$ sudo pip install shadowsocks
$ ssserver --version # 查看版本号
|
第三步,编辑配置文件和开机自启动
编辑服务端配置文件
1
2
3
|
$ cd /etc/
$ sudo mkdir shadowsocks && sudo touch shadowsocks.json # 创建SS配置文件
$ sudo vim shadowsocks.json # 使用你喜欢的编辑器打开并写入以下项,具体解释可参考官方文档
|
1
2
3
4
5
6
7
8
9
10
|
{
"server": "my_server_ip", // 这里输入本机的 IP 地址
"server_port": 8388, // 为了安全,可修改为大于 1024 的数字
"local_address": "127.0.0.1",
"local_port": 1080
"password": "mypassword", // 设置一个密码
"timeout": 300,
"method": "aes-256-cfb",
"fast_open": false
}
|
保存后建议修改文件权限为ROOT,提高安全性。配置完成后启动SS服务端
1
2
3
|
$ sudo ssserver -c /etc/shadowsocks/shadowsocks.json # 前台运行
$ sudo ssserver -c /etc/shadowsocks/shadowsocks.json -d start # 后台运行
$ sudo ssserver -c /etc/shadowsocks/shadowsocks.json -d stop # 后台停止
|
配置开机自启文件
1
2
3
|
$ cd /etc/
$ sudo vim rc.local # 在此文件的exit 0这一行之前添加下面这句内容
ssserver -c /etc/shadowsocks/shadowsocks.json -d start # 保存并退出
|
第四步,优化SS
优化内核参数
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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
$ sudo touch /etc/sysctl.d/local.conf # 创建优化文件,并写入以下内容
# max open files
fs.file-max = 51200
# max read buffer
net.core.rmem_max = 67108864
# max write buffer
net.core.wmem_max = 67108864
# default read buffer
net.core.rmem_default = 65536
# default write buffer
net.core.wmem_default = 65536
# max processor input queue
net.core.netdev_max_backlog = 4096
# max backlog
net.core.somaxconn = 4096
# resist SYN flood attacks
net.ipv4.tcp_syncookies = 1
# reuse timewait sockets when safe
net.ipv4.tcp_tw_reuse = 1
# turn off fast timewait sockets recycling
net.ipv4.tcp_tw_recycle = 0
# short FIN timeout
net.ipv4.tcp_fin_timeout = 30
# short keepalive time
net.ipv4.tcp_keepalive_time = 1200
# outbound port range
net.ipv4.ip_local_port_range = 10000 65000
# max SYN backlog
net.ipv4.tcp_max_syn_backlog = 4096
# max timewait sockets held by system simultaneously
net.ipv4.tcp_max_tw_buckets = 5000
# turn on TCP Fast Open on both client and server side
net.ipv4.tcp_fastopen = 3
# TCP receive buffer
net.ipv4.tcp_rmem = 4096 87380 67108864
# TCP write buffer
net.ipv4.tcp_wmem = 4096 65536 67108864
# turn on path MTU discovery
net.ipv4.tcp_mtu_probing = 1
# for high-latency network
net.ipv4.tcp_congestion_control = hybla
# for low-latency network, use cubic instead
# net.ipv4.tcp_congestion_control = cubic
|
保存并退出,然后执行
1
2
|
$ sudo sysctl --system
$ sudo sysctl -p /etc/sysctl.d/local.conf # 对较老的系统
|
TCP优化
在服务端的客户端的配置文件将fast_open
设置为true
,然后,执行:
1
2
3
|
$ su # 切换为ROOT用户
$ echo 3 > /proc/sys/net/ipv4/tcp_fastopen
$ ssserver -c /etc/shadowsocks/shadowsocks.json # 重启SS服务
|
至此,服务端搭建并优化完成。
客户端
SS在各大平台均有客户端软件,可在这里查看。对GUI类型,有:
1. 以Window平台,有1,2
2. Linux平台,有1
客户端的配置文件与服务器端一样,不再赘述,可参考官方文档。
参考资料
- 使用 Shadowsocks 自建翻墙服务器,实现全平台 100% 翻墙无障碍
- 官方文档
- 官方文档2