Shadowsocks 一键安装脚本(四合一)

技术 1313122 次围观 1222 次吐槽

本脚本适用环境

系统支持:CentOS 6+,Debian 7+,Ubuntu 12+
内存要求:≥128M
日期  :2018 年 06 月 01 日

关于本脚本

1、一键安装 Shadowsocks-Python, ShadowsocksR, Shadowsocks-Go, Shadowsocks-libev 版(四选一)服务端;
2、各版本的启动脚本及配置文件名不再重合;
3、每次运行可安装一种版本;
4、支持以多次运行来安装多个版本,且各个版本可以共存(注意端口号需设成不同);
5、若已安装多个版本,则卸载时也需多次运行(每次卸载一种);

友情提示:如果你有问题,请先阅读这篇《Shadowsocks Troubleshooting》之后再询问。

默认配置

服务器端口:自己设定(如不设定,默认从 9000-19999 之间随机生成)
密码:自己设定(如不设定,默认为 teddysun.com)
加密方式:自己设定(如不设定,Python 和 libev 版默认为 aes-256-gcm,R 和 Go 版默认为 aes-256-cfb)
协议(protocol):自己设定(如不设定,默认为 origin)(仅限 ShadowsocksR 版)
混淆(obfs):自己设定(如不设定,默认为 plain)(仅限 ShadowsocksR 版)
备注:脚本默认创建单用户配置文件,如需配置多用户,请手动修改相应的配置文件后重启即可。

客户端下载

常规版 Windows 客户端
https://github.com/shadowsocks/shadowsocks-windows/releases

ShadowsocksR 版 Windows 客户端
https://github.com/shadowsocksrr/shadowsocksr-csharp/releases

使用方法

使用root用户登录,运行以下命令:

wget --no-check-certificate -O shadowsocks-all.sh https://raw.githubusercontent.com/teddysun/shadowsocks_install/master/shadowsocks-all.sh
chmod +x shadowsocks-all.sh
./shadowsocks-all.sh 2>&1 | tee shadowsocks-all.log

安装完成后,脚本提示如下

Congratulations, your_shadowsocks_version install completed!
Your Server IP        :your_server_ip
Your Server Port      :your_server_port
Your Password         :your_password
Your Encryption Method:your_encryption_method

Your QR Code: (For Shadowsocks Windows, OSX, Android and iOS clients)
 ss://your_encryption_method:[email protected]_server_ip:your_server_port
Your QR Code has been saved as a PNG file path:
 your_path.png

Welcome to visit:https://teddysun.com/486.html
Enjoy it!

卸载方法

若已安装多个版本,则卸载时也需多次运行(每次卸载一种)

使用root用户登录,运行以下命令:

./shadowsocks-all.sh uninstall

启动脚本

启动脚本后面的参数含义,从左至右依次为:启动,停止,重启,查看状态。

Shadowsocks-Python 版:
/etc/init.d/shadowsocks-python start | stop | restart | status

ShadowsocksR 版:
/etc/init.d/shadowsocks-r start | stop | restart | status

Shadowsocks-Go 版:
/etc/init.d/shadowsocks-go start | stop | restart | status

Shadowsocks-libev 版:
/etc/init.d/shadowsocks-libev start | stop | restart | status

各版本默认配置文件

Shadowsocks-Python 版:
/etc/shadowsocks-python/config.json

ShadowsocksR 版:
/etc/shadowsocks-r/config.json

Shadowsocks-Go 版:
/etc/shadowsocks-go/config.json

Shadowsocks-libev 版:
/etc/shadowsocks-libev/config.json

更新日志

2018 年 06 月 01 日:
1、修正:在启用了插件 simple-obfs 的情况下,libev 版启动失败的问题;
2、修正:在使用 /etc/init.d/shadowsocks-libev restart 命令重启 libev 版服务端时,偶尔出现的 “bind: Address already in use” 问题;
3、修正:移除 libev 版配置文件中的 local_address 字段;
4、修改:不再默认使用 root 用户启动,改为使用 nobody 用户启动 libev 版服务端 ss-server;
5、升级:mbedtls 到版本 2.9.0;
6、修改:libev 版启动脚本中的 -u 参数(即同时启用 TCP 和 UDP 模式),改到配置文件里配置为 “mode”: “tcp_and_udp”;
7、修改:libev 版配置文件的内置 NameServers 为 8.8.8.8,默认是从 /etc/resolv.conf 中取得。

2018 年 02 月 07 日:
1、修改:将默认端口从 8989 改为从 9000-19999 之间随机生成。

2018 年 02 月 06 日:
1、修改:ShadowsocksR 版为 ShadowsocksRR 最新版;
2、新增:ShadowsocksR 版的协议(protocol)增加了 4 个,分别为:

auth_chain_c
auth_chain_d
auth_chain_e
auth_chain_f

2017 年 12 月 29 日:
1、升级:libsodium 到 1.0.16。

2017 年 11 月 25 日:
1、如果 Linux 内核版本大于 3.7.0,则配置文件默认支持 TCP fast open;
2、新增:libev 版启动时支持 verbose mode,也就是默认写 log 到 /var/log/messages 方便查看。

2017 年 11 月 12 日:
1、新增生成 ss:// 或 ssr:// 链接,以及其二维码图片。
※ 脚本会根据当前安装的版本以及输入的各项配置,自动生成 ss:// 或 ssr:// 的链接并在安装成功后显示,直接复制即可被客户端识别。同时生成其二维码图片,并保存在当前目录下,下载后用看图软件打开,也能被客户端识别。

复制二维码链接后 Shadowsocks 客户端识别示例:

复制二维码链接后 ShadowsocksR 客户端识别示例:

二维码(QR Code)参考链接:
https://github.com/shadowsocks/shadowsocks/wiki/Generate-QR-Code-for-Android-or-iOS-Clients
https://github.com/shadowsocksr-backup/shadowsocks-rss/wiki/SSR-QRcode-scheme

2017 年 10 月 22 日:
1、升级:libsodium 到 1.0.15。

2017 年 10 月 14 日:
1、新增:在安装 Shadowsocks-libev 版时可选安装 simple-obfs 服务端。
※ 脚本通过判断 autoconf 版本是否大于或等于 2.67 来一键安装 simple-obfs 服务端。并且,支持在安装过程中选择 obfs 为 http 或 tls。
※ 使用方法参考:https://teddysun.com/511.html

2017 年 09 月 16 日:
1、修正:Shadowsocks-libev 版 v3.1.0 使用 libc-ares 替换 libudns 依赖包,解决了依赖问题;
2、升级:mbedtls 到版本 2.6.0。

2017 年 07 月 27 日:
1、新增:ShadowsocksR 版可选协议(protocol)auth_chain_b 。使用该协议需更新到最新(4.7.0) ShadowsocksR 版客户端
2、修改:更新 ShadowsocksR 源码下载地址。

2017 年 07 月 23 日:
1、修正:卸载时可自行选择某个版本卸载,若该版本不存在则报错退出。

2017 年 07 月 22 日:
1、修正:默认加密方式从 aes-256-cfb 改为 aes-256-gcm(Python 和 libev 版);
2、新增:安装时可选 16 种加密方式的其中之一(Python 和 libev 版)。如下所示:

aes-256-gcm
aes-192-gcm
aes-128-gcm
aes-256-ctr
aes-192-ctr
aes-128-ctr
aes-256-cfb
aes-192-cfb
aes-128-cfb
camellia-128-cfb
camellia-192-cfb
camellia-256-cfb
chacha20-ietf-poly1305
chacha20-ietf
chacha20
rc4-md5

3、新增:安装时可选 9 种加密方式的其中之一(Go 版)。如下所示:

aes-256-cfb
aes-192-cfb
aes-128-cfb
aes-256-ctr
aes-192-ctr
aes-128-ctr
chacha20-ietf
chacha20
rc4-md5

4、新增:安装时可选 15 种加密方式的其中之一(none 是不加密,ShadowsocksR 版)。如下所示:

none
aes-256-cfb
aes-192-cfb
aes-128-cfb
aes-256-cfb8
aes-192-cfb8
aes-128-cfb8
aes-256-ctr
aes-192-ctr
aes-128-ctr
chacha20-ietf
chacha20
salsa20
xchacha20
xsalsa20
rc4-md5

5、新增:安装时可选 7 种协议(protocol)的其中之一(仅限 ShadowsocksR 版)。如下所示:

origin
verify_deflate
auth_sha1_v4
auth_sha1_v4_compatible
auth_aes128_md5
auth_aes128_sha1
auth_chain_a
auth_chain_b

6、新增:安装时可选 9 种混淆(obfs)的其中之一(仅限 ShadowsocksR 版)。如下所示:

plain
http_simple
http_simple_compatible
http_post
http_post_compatible
tls1.2_ticket_auth
tls1.2_ticket_auth_compatible
tls1.2_ticket_fastauth
tls1.2_ticket_fastauth_compatible

2017 年 02 月 24 日:
1、恢复: 通过 Github API 自动获取 Shadowsocks-libev 的最新 release 版本的功能(v3.0.3)。

2017 年 02 月 13 日:
1、升级: Shadowsocks-libev 版到版本 3.0.2;
2、升级: Shadowsocks-go 版到版本 1.2.1(基于 Github 最新代码,用 go 1.8 编译完成的 x86 和 x86_64 二进制文件);
3、修复:在 Debian 7 下默认没有 libudns-dev 依赖包的问题。

2017 年 02 月 12 日:
1、升级: Shadowsocks-libev 版到版本 3.0.1。

2017 年 01 月 27 日:
1、升级: Shadowsocks-go 版到版本 1.2.1 (仅适用于 x86_64 系统)

更多单版本 Shadowsocks 服务端一键安装脚本

Shadowsocks Python 版一键安装脚本(CentOS,Debian,Ubuntu)
ShadowsocksR 版一键安装脚本(CentOS,Debian,Ubuntu)
CentOS 下 Shadowsocks-libev 一键安装脚本
Debian 下 Shadowsocks-libev 一键安装脚本
Shadowsocks-go 一键安装脚本(CentOS,Debian,Ubuntu)

注意:以上单版本不可与该四合一版本混用。

转载请注明:秋水逸冰 » Shadowsocks 一键安装脚本(四合一)

发表评论
取消评论
  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址
表情

已有评论 (1222)

  1. 请问一下大神我第一条就没过是什么原因啊,显示:usage:wget 【option】...【url】...
    eng2个月前 (2018-08-13)回复
  2. 按照您说的输完了,提示什么 ./shadowsocks-all.sh: line 1 --2018-08-10 not found 是什么问题?
    Jourin2个月前 (2018-08-10)回复
  3. 兄弟,你的博客又被墙了
    乌云路人赵日天2个月前 (2018-08-09)回复
  4. 请问,用您的一键脚本安装完毕,以后ssr怎么更新升级呢?
    xuyun3个月前 (2018-08-06)回复
    • 基本上也很少升级了。因为,源代码已无人维护了。
      秋水逸冰3个月前 (2018-08-06)回复
  5. 秋大将来会不会考虑下下这个 https://github.com/cbeuw/GoQuiet/wiki/GoQuiet 看介绍说 是混淆插件的改善版。
    Beibei3个月前 (2018-08-05)回复
  6. 大佬,我想问下simple-obfs能更好的防被墙吗,因为对速度的影响还是挺大的。。。所以如果如果并不是很有效果,有点不想设置
    Janna3个月前 (2018-08-05)回复
    • 确实有一定的混淆作用,但我个人认为开启的意义不大。GFW 已经可以做到定向智能阻断 TCP 连接了。墙不墙的大多数还是看运气吧。
      秋水逸冰3个月前 (2018-08-06)回复
    • fast_open打开后就没法连接是哪里的问题?
      5天前回复
  7. 支持楼主这个脚本,我用其他大佬的SSR网速贼慢,这个网速很快,支持你
    imhd3个月前 (2018-08-05)回复
  8. 我使用亚马逊云搭建ssr 一切都顺利就是最后ssr无法使用 连接不上怎么会是
    大熊3个月前 (2018-08-04)回复
  9. 你好,这个非常好用!感谢!请问安装好之后,再用什么命令可以显示最后一次的配置页面,以及如何判断是否运行正常呢?因为vultr刚发邮件,说把VPS重启了,然后现在再也连不上,不知道是什么原因?麻烦你有空解答一下,感谢!
    tomi3个月前 (2018-08-03)回复
    • 请仔细查看文章的查看状态那里,根据安装的版本不同,使用的命令也不同。
      秋水逸冰3个月前 (2018-08-03)回复
  10. ./shadowsocks-all.sh: line 269: 450 Segmentation fault apt-get -y update > /dev/null 2>&1 有错误诶 无法进行下去啊..
    sbaer95273个月前 (2018-08-03)回复
  11. 可不可以把资源文件放在支持ipv6的服务器上。。。纯ipv6环境下脚本无法使用
    inori3个月前 (2018-07-30)回复
  12. 服务器正常,服务器可以ping通,shadow-python运行正常,服务器ping谷歌正常,就是连不上了,上周开始突然连不上,服务器重启过了,shadow卸载重装了,防火墙默认关闭的,依旧连不上,应该怎么排查问题啊
    test3个月前 (2018-07-30)回复
  13. 真不好意思,之前没用过ssr,不知道参数设置在软件里,嘿嘿嘿
    adbe3个月前 (2018-07-27)回复
  14. 你好,非常感谢慷慨的分享,我想请问一下那个ssr混淆参数可以自己设置吗?
    adbe3个月前 (2018-07-27)回复
  15. 2018-07-27 14:02:46 (12.1 KB/s) - Connection closed at byte 819104. Retrying. --2018-07-27 14:02:47-- (try: 2) https://tls.mbed.org/download/mbedtls-2.11.0-gpl.tgz Connecting to tls.mbed.org (tls.mbed.org)|79.170.91.36|:443... connected. HTTP request sent, awaiting response... 200 OK Length: 2303002 (2.2M) [application/x-gzip] Saving to: 'mbedtls-2.11.0-gpl.tgz' 0K 0% 0.00 =0.8s Cannot write to 'mbedtls-2.11.0-gpl.tgz' (Success). [Error] Download mbedtls-2.11.0-gpl.tgz failed. 网络不稳定经常遇到这种下载中断的情况,然后重新安装脚本又会找到这个不完整的文件,然后就不重新下载,但是又没办法解压,然后就再也没法继续安装了。 然后想手动删除这个不完整的文件,但是看源码又找不到文件下载到了哪里,全局搜索也搜不到。
    CnXRY3个月前 (2018-07-27)回复