CentOS下shadowsocks-libev一键安装脚本

技术 秋水逸冰 1872828浏览 1182评论

本脚本适用环境:
系统支持:CentOS
内存要求:≥128M
日期:2018 年 06 月 01 日

关于本脚本:
一键安装 libev 版的 Shadowsocks 最新版本。该版本的特点是内存占用小(600k左右),低 CPU 消耗,甚至可以安装在基于 OpenWRT 的路由器上。
友情提示:如果你有问题,请先参考这篇《Shadowsocks Troubleshooting》后再问。

默认配置:
服务器端口:自己设定(如不设定,默认从 9000-19999 之间随机生成)
密码:自己设定(如不设定,默认为 teddysun.com)
加密方式:自己设定(如不设定,默认为 aes-256-gcm)

Shadowsocks for Windows 客户端下载:
https://github.com/shadowsocks/shadowsocks-windows/releases

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

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

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

Congratulations, Shadowsocks-libev server install completed!
Your Server IP        :your_server_ip
Your Server Port      :your_server_port
Your Password         :your_password
Your Encryption Method:your_encryption_method

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

卸载方法:
使用 root 用户登录,运行以下命令:

./shadowsocks-libev.sh uninstall

其他事项:
客户端配置的参考链接:https://teddysun.com/339.html

安装完成后即已后台启动 Shadowsocks-libev ,运行:

/etc/init.d/shadowsocks status

可以查看进程是否启动。
本脚本安装完成后,会将 Shadowsocks-libev 加入开机自启动。

使用命令:
启动:/etc/init.d/shadowsocks start
停止:/etc/init.d/shadowsocks stop
重启:/etc/init.d/shadowsocks restart
查看状态:/etc/init.d/shadowsocks status

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

更新日志

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

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

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

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

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

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

2017 年 02 月 13 日:
1、更新:升级版本到 3.0.2。

2017 年 02 月 12 日:
1、更新:升级版本到 3.0.1(请下载最新的脚本来安装)。

2016 年 11 月 05 日:
1、新增:判断是否已安装,若已安装,则获取版本号与最新版比较,然后可以升级覆盖安装;
2、修正:未安装时获取最新版本号的问题。

2016 年 09 月 23 日:
1、修正:偶尔自动获取版本号失败的问题;
2、新增:自动判断如果 VPS 存在 IPv6 地址,则在配置文件里添加监听 IPv6 地址。

2016 年 09 月 17 日:
1、重构代码,自动获取 Github 上最新版来安装,不再手动修改版本号;
2、自动检测本机是否已经安装,若已安装则正常退出(若要安装新版,则需先卸载);
3、改为下载 tar.gz 包来安装,不用依赖 unzip 命令。

2016 年 09 月 12 日:
1、更新:升级版本到 2.5.2。

2016 年 09 月 11 日:
1、更新:升级版本到 2.5.1。

2016 年 08 月 29 日:
1、更新:升级版本到 2.5.0;
2、修正:由于安装时文件名的更新,卸载时文件名改为一致。

2016 年 07 月 14 日:
1、更新:升级版本到 2.4.7。

2016 年 07 月 05 日:
1、修正:新增的依赖 xmlto、asciidoc;
2、修正:由于安装时文件名的更新,卸载时文件名改为一致。

2016 年 05 月 12 日:
1、新增:在 CentOS 7 下的防火墙规则设置。

2015 年 08 月 01 日:
1、新增:自定义服务器端口功能(如不设定,默认为 8989)。

2015 年 04 月 30 日:
1、修正:配置文件 /etc/shadowsocks-libev/config.json 同时启用 IPv4 与 IPv6 支持:

{
    "server":["[::0]","0.0.0.0"],
    "server_port":your_server_port,
    "local_address":"127.0.0.1",
    "local_port":1080,
    "password":"your_password",
    "timeout":600,
    "method":"aes-256-cfb"
}

2、Shadowsocks libev 版不能通过修改配置文件来多端口(只能开启多进程),如果你需要多端口请安装 Python 或 Go 版;

特别说明:
1、已安装旧版本的 shadowsocks 需要升级的话,需下载本脚本的最新版,直接运行即可自动升级

./shadowsocks-libev.sh

参考链接:
https://github.com/shadowsocks/shadowsocks-libev

转载请注明:秋水逸冰 » CentOS下shadowsocks-libev一键安装脚本

发表我的评论
取消评论

请输入正确答案后提交评论 *超出时限。 请再次填写验证码。

表情

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址

网友最新评论 (1182)

  1. 请问,服务器可以配置多个端口使用吗?万一哪个被墙了,就可以随时切换一个。
    getbusydying10年前(2014-09-15)回复
    • 可以,具体就是新增配置文件,启动多实例。但多说一句,如果被墙,基本上是整个 IP 被墙,所以这个时候换端口也没用。
      秋水逸冰10年前(2014-09-15)回复
  2. 新出了RC4-MD5 加密,什么时候更新这里的脚本呢0 0~
    bakashen10年前(2014-09-10)回复
    • 脚本创建的默认加密方式是 aes-256-cfb ,也是作者所推荐的。 如果你想改为 rc4-md5 ,自行修改配置文件 /etc/shadowsocks/config.json 中的 method 字段的值,然后 /etc/init.d/shadowsocks restart 重启一下即可。
      秋水逸冰10年前(2014-09-10)回复
  3. 请问SS的账户密码可以修改吗 怎么修改
    wirelessxu10年前(2014-09-04)回复
    • 其实你把本文的评论认真看完的话就不需要问这个问题了。 修改配置文件 /etc/shadowsocks/config.json 中的 password 字段的值,然后 /etc/init.d/shadowsocks restart 重启一下即可。
      秋水逸冰10年前(2014-09-04)回复
  4. make[2]: Leaving directory `/root/shadowsocks-libev-master/libev' Making all in src make[2]: Entering directory `/root/shadowsocks-libev-master/src' /bin/sh ../libtool --tag=CC --mode=link gcc -g -O2 -Wall -Werror -Wno-deprecat ed-declarations -fno-strict-aliasing -std=gnu99 -D_GNU_SOURCE -I../libev -I../li basyncns -I../libipset/include -I../libcork/include -DUDPRELAY_LOCAL -g -O2 -sta tic -o ss-local ss_local-utils.o ss_local-jconf.o ss_local-json.o ss_local-encr ypt.o ss_local-udprelay.o ss_local-cache.o ss_local-acl.o ss_local-local.o ../l ibev/libev.la ../libipset/libipset.la ../libcork/libcork.la -lcrypto -lm libtool: link: gcc -g -O2 -Wall -Werror -Wno-deprecated-declarations -fno-strict -aliasing -std=gnu99 -D_GNU_SOURCE -I../libev -I../libasyncns -I../libipset/incl ude -I../libcork/include -DUDPRELAY_LOCAL -g -O2 -o ss-local ss_local-utils.o ss _local-jconf.o ss_local-json.o ss_local-encrypt.o ss_local-udprelay.o ss_local-c ache.o ss_local-acl.o ss_local-local.o ../libev/.libs/libev.a ../libipset/.libs /libipset.a ../libcork/.libs/libcork.a -lcrypto -lm ../libcork/.libs/libcork.a(libcork_la-error.o): In function `cork_error_get': /root/shadowsocks-libev-master/libcork/core/error.c:92: undefined reference to ` __sync_val_compare_and_swap_4' /root/shadowsocks-libev-master/libcork/core/error.c:88: undefined reference to ` __sync_val_compare_and_swap_4' /root/shadowsocks-libev-master/libcork/core/error.c:88: undefined reference to ` __sync_val_compare_and_swap_4' collect2: ld returned 1 exit status make[2]: *** [ss-local] Error 1 make[2]: Leaving directory `/root/shadowsocks-libev-master/src' make[1]: *** [all-recursive] Error 1 make[1]: Leaving directory `/root/shadowsocks-libev-master' make: *** [all] Error 2 Shadowsocks-libev install failed! Please visit https://teddysun.com/357.html 小菜鸟,不知道怎么破...
    anniextra10年前(2014-09-04)回复
  5. collect2: ld returned 1 exit status make[2]: *** [ss-local] Error 1 make[2]: Leaving directory `/root/shadowsocks-libev-master/src' make[1]: *** [all-recursive] Error 1 make[1]: Leaving directory `/root/shadowsocks-libev-master' make: *** [all] Error 2 这个报错,怎么破???
    anniextra10年前(2014-09-04)回复
    • 系统换为 CentOS 6.5 即可。 脚本不适用于 CentOS 5.x 的,原因是 gcc 版本太低,编译就会报错。
      秋水逸冰10年前(2014-09-04)回复
  6. 无法使用udp转发,请问要加什么参数,在哪里加?
    olympic10年前(2014-09-03)回复
    • 要加个-u的参数,但是不知道在哪里加,请教一下。
      olympic10年前(2014-09-03)回复
    • 本文的参考链接:https://github.com/madeye/shadowsocks-libev 作者有详细说明【Usage】部分。
      秋水逸冰10年前(2014-09-03)回复
      • 已找到方法,谢谢楼主。 在/etc/rc.d/init.d/shadowsocks文件中编辑第72行最后加个-u,试验成功了。 daemon $DAEMON -c $CONF -f $PID -u
        olympic10年前(2014-09-23)回复
  7. 部署后安卓客户端无法启用udp转发,其他都正常。
    olympic10年前(2014-08-29)回复
    • 脚本只是在服务器上安装和部署 Shadowsocks,具体问题请移步作者 Github 页面咨询。
      秋水逸冰10年前(2014-08-29)回复
  8. 问一下,如果在AWS上面搭建,选什么系统最好
    Qizmo10年前(2014-08-26)回复
    • AWS 没玩过,你选自带的 Linux 发行版就行。
      秋水逸冰10年前(2014-08-26)回复
  9. # wget --no-check-certificate https://raw.githubusercontent.com/teddysun/shadowsocks_install/master/shadowsocks-libev.sh -bash: wget: command not found 。。。 ......又错了
    狂舞小薰10年前(2014-08-25)回复
    • 没有安装 wget 导致的问题,执行:yum install -y wget 然后再试试看。
      秋水逸冰10年前(2014-08-25)回复
  10. 我成功安装了服务器, 而且能连上服务器, 但不能上互联网看网站
    Andy10年前(2014-08-22)回复
    • 首先确认你的服务器能否浏览网页。一般情况下,以 DNS 设置不正确居多,自己 google 一下网上的解决办法即可。
      秋水逸冰10年前(2014-08-22)回复
  11. 厉害啊,能否搞一个centos 6 64位下的openvpn 一键安装脚本呢,拜托了
    newbie10年前(2014-08-20)回复
  12. 请教:怎么变更密码呢?现在想修改一下
    hallo10年前(2014-08-11)回复
    • 修改配置文件 /etc/shadowsocks/config.json 中的 password 字段的值,然后 /etc/init.d/shadowsocks restart 重启一下即可。
      秋水逸冰10年前(2014-08-11)回复
      • 多谢指点!!
        hallo10年前(2014-08-11)回复
  13. 不好意思啊 我检查发现我 Centos 错安装了 Debian 的一键shadosocks脚本 导致了用了一段时间系统就自动重启 是我的失误~
    immjun10年前(2014-08-05)回复
  14. Centos 6.5 1G openvz 用这个脚本 安装完成后 shadowsocks 可以正确连上 测试shadowsocks也能开机重启自启动 可以我怎么也找不到 /etc/init.d/shadowsocks 提示 -bash: /etc/init.d/shadowsocks: No such file or directory 导致我不能手动关闭或者启动 另外连上了一段时间(大改1小时左右) 会导致整个系统重启 以前系统不会有自动重启的情况. 想问一下会是什么问题呢?
    immjun10年前(2014-08-05)回复
  15. shadowsocks-libev一键安装脚本最新版有Tcp_Fast_Open功能吗?
    狂三10年前(2014-08-04)回复
    • 目前只有 Python 版有此功能。
      秋水逸冰10年前(2014-08-05)回复
      • 已经换PYTHON版了,有没有什么办法确认Tcp_Fast_Open是否正在运行呢?
        狂三10年前(2014-08-05)回复
        • 要开启此功能需要 Linux 内核为 3.7+,需要手动修改下配置文件 /etc/shadowsocks.json 中的 fast_open 从 false 改为 true,具体说明参考这里
          秋水逸冰10年前(2014-08-06)回复
          • 我执行了这个echo 3 > /proc/sys/net/ipv4/tcp_fastopen,可是tcp_fastopen里面没出现3,是空白的,直接改也没效果,求助
            狂三10年前(2014-08-06)回复
            • 如果你的 VPS 符合开启此功能的所有条件,却无法开启 tcp_fastopen,请求助于作者 clowwindy
              秋水逸冰10年前(2014-08-06)回复