CentOS下shadowsocks-libev一键安装脚本

技术 秋水逸冰 1872639浏览 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. 楼主你好 内部网ip卡映射的外网ip搭建的SSR是不是用不了啊?试了一下,安装过程没报错,但是用客户端连接不上。
    xiao5年前(2018-12-17)回复
  2. 进来说个谢谢~
    23235年前(2018-12-15)回复
  3. 功德无量,可惜网站被屏蔽了。。。。
    UN5年前(2018-12-13)回复
  4. 楼主功德无量!诚心感谢!
    fox5年前(2018-11-30)回复
  5. 版本:2018 年 06 月 01 日版本 Operating system: Centos 6 x86 提示端口占用,查看服务只有ss [root@C ~]# ss-server 2018-11-28 07:25:03 INFO: UDP relay enabled 2018-11-28 07:25:03 INFO: initializing ciphers... aes-256-cfb 2018-11-28 07:25:03 INFO: using nameserver: 8.8.8.8 2018-11-28 07:25:03 INFO: tcp server listening at 0.0.0.0:443 2018-11-28 07:25:03 ERROR: bind: Address already in use 2018-11-28 07:25:03 ERROR: failed to listen on any address [root@C ~]# netstat -anp Active Internet connections (servers and established) Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name tcp 0 0 0.0.0.0:443 0.0.0.0:* LISTEN 6758/ss-server tcp 0 0 0.0.0.0:29627 0.0.0.0:* LISTEN 568/sshd tcp 0 0 23.106.145.91:29627 115.204.230.160:52737 ESTABLISHED 622/sshd tcp 0 0 :::29627 :::* LISTEN 568/sshd udp 0 0 0.0.0.0:443 0.0.0.0:* 6758/ss-server Active UNIX domain sockets (servers and established) Proto RefCnt Flags Type State I-Node PID/Program name Path unix 2 [ ACC ] STREAM LISTENING 146790106 1/init @/com/ubuntu/upstart unix 2 [ ] DGRAM 146790361 143/udevd @/org/kernel/udev/udevd unix 3 [ ] DGRAM 146790365 143/udevd unix 3 [ ] DGRAM 146790364 143/udevd
    CJ5年前(2018-11-28)回复
    • 根据提示,443 端口已被占用,你需要先看看是被谁占用了,然后结束它,并重启 SS 即可。 不过,似乎你的 SS 已经在 443 端口正常工作了。 你不能直接运行 ss-server 命令。可以运行 ss-server -h 来看看帮助先。
      秋水逸冰5年前(2018-12-08)回复
      • 关于bind:Address already in use 的原因是你通过脚本安装SS后,此时SS是正在运行状态,你再重复使用SS-Server这条命令就会提示报错,你可以试试先stop SS,然后在执行SS-server 命令。 然后其实,这个报错并不影响你的SS运行,其实已经正常启动,并监听了
        5年前(2019-01-16)回复
  6. [Error] libsodium-1.0.16 install failed. 大神,为啥我一直提示错误,我还尝试额libsodium自己编译 也还会错误
    snake5年前(2018-11-25)回复
  7. https://raw.githubusercontent.com/teddysun/shadowsocks_install/mas 报400
    liH6年前(2018-11-21)回复
    • 你好,这是因为你没有复制完全部命令导致的。
      秋水逸冰6年前(2018-11-23)回复
  8. shadowsocks-libev脚本执行时出现编译问题 checking for ares_library_init in -lcares... no configure: error: The c-ares library libraries not found. make: *** No targets specified and no makefile found. Stop.
    yooooger6年前(2018-11-06)回复
    • 手动安装 c-ares-devel 后再试一次。 yum install -y c-ares-devel
      秋水逸冰6年前(2018-11-10)回复
  9. 在centOS7 x64下的确有问题,显示ERROR: bind: Address already in use,但是通过netstat -anp排查该端口下只有ss-server在运行,通过kill pid杀掉ss后再运行ss-server命令会显示监听状态无报错,但是运行/etc/init.d/shadowsocks status得到状态是Shadowsocks-libev is stopped,而且netstat -anp发现端口下并无ss运行。烦请博主检查脚本。
    Need Help6年前(2018-10-25)回复
  10. 使用一键安装脚本后,通过ss-server命令查看运行状态,还是会报bind: Address already in use这个错误, # ss-server 2018-10-16 14:22:48 INFO: UDP relay enabled 2018-10-16 14:22:48 INFO: initializing ciphers... aes-256-cfb 2018-10-16 14:22:48 INFO: using nameserver: 8.8.8.8 2018-10-16 14:22:48 INFO: tcp server listening at 0.0.0.0:1838 2018-10-16 14:22:48 ERROR: bind: Address already in use 2018-10-16 14:22:48 ERROR: bind() error
    群众6年前(2018-10-16)回复
    • 端口已被占用,请通过以下命令排查是被谁占用的 netstat -anp
      秋水逸冰6年前(2018-10-20)回复
  11. 你好,安装ss后,用ss-server命令,会提示bind: Address already in use,这个字面意思似乎是端口被占用了?可是我并没有运行更多的服务,可否指点下原因?
    群众6年前(2018-10-16)回复
  12. 将fast_open项更改为true后无法再连接SS,改回false后又恢复正常
    fqfq6年前(2018-10-11)回复
    • Fast Open 需要内核支持,如果内核不支持强行开启是不行的
      秋水逸冰6年前(2018-10-14)回复
  13. 多次在阿里云国际版上测试发现,centos7+博主的bbr,安装ss-libev后能正常使用,但是重启系统后,ss-libev进程不会自动启动,手动启动之后只要客户端一连接ss-libev进程就会停止,通过ISO安装原版centos7后问题依旧,但是安装ssr和ss-python却并不会有这个问题
    cjp_jx6年前(2018-10-11)回复
    • 我也是这样 请问解决了吗?
      udsb5年前(2018-12-03)回复
  14. configure: error: in `/root/libsodium-1.0.16': configure: error: no acceptable C compiler found in $PATH See `config.log' for more details [Error] libsodium-1.0.16 install failed. 提示这个安装失败
    kkk6年前(2018-10-07)回复
    • yum -y install epel-release yum -y update yum -y install gcc automake autoconf libtool make m2crypto autoconf libtool curl curl-devel zlib-devel openssl-devel perl perl-devel cpio expat-devel gettext-devel pcre-devel asciidoc xmlto git 参考 https://www.v2ex.com/amp/t/325885
      sean6年前(2018-11-13)回复
  15. 大神,在centos6下更新了6月1日的脚本之后,只要开启obfs,就没有办法开机启动了,必须手动启动才可以,这个有办法解决吗?
    yyysuo6年前(2018-08-17)回复