CentOS下shadowsocks-libev一键安装脚本

技术 秋水逸冰 1873132浏览 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. 作者表明最新版使用RC4-MD5 加密,速度快好几倍,如果用在路由器上会带来显著性能提升。求升级啊~ http://www.v2ex.com/t/132519
    s5s510年前(2014-10-13)回复
    • 安装都是编译 Github 上的最新源码来安装的,你改一下配置文件里的加密方式再重启一下就行了。
      秋水逸冰10年前(2014-10-13)回复
      • 问题是很多人只会无脑装……配置文件都搞不定……
        lol9年前(2015-01-01)回复
  2. 请问下秋水兄看看什么问题: 默认配置服务器端,配合openwrt的路由客户端(ss-local、redsocks、pdns)正常的,而改了加密方式aes-256-cfb为rc4-md5,分别在server端 vi /etc/shadowsocks/config.json和client端 vi /etc/config/shadowsocks.json修改过,并重启server端和client端的shadowsocks,就连不上国外地址,如y2, 而百度等国内没问题,这什么情况?
    ryan10年前(2014-10-11)回复
    • libev 版和 Python 版功能并不是完全一致的,所以建议你把加密方式换回来再试试。具体的原因你去问作者吧。
      秋水逸冰10年前(2014-10-11)回复
  3. [root@ip-172-31-14-16 ec2-user]# /etc/init.d/shadowsocks status ss-server 已停 [root@ip-172-31-14-16 ec2-user]# /etc/init.d/shadowsocks start shadowsocks-server is already running! [root@ip-172-31-14-16 ec2-user]# /etc/init.d/shadowsocks status ss-server 已停 用goagentx 就显示 2014-10-10 19:51:22 ERROR: getpeername: Invalid argument
    micheal10年前(2014-10-10)回复
    • 你想问什么?Shadowsocks不是已经在运行了么。
      秋水逸冰10年前(2014-10-10)回复
      • 没有 SS服务属于停止状态,并且goagentx(不是goagent)一直提示错误。 [ec2-user@ip-172-31-14-16 ~]$ /etc/init.d/shadowsocks status shadowsocks is stopped 重启SS服务会提示成功,但是你在查询运行状态就是停止。。。
        micheal10年前(2014-10-11)回复
        • 建议重新编译安装 shadowsocks ,在 CentOS 6.5 下。
          秋水逸冰10年前(2014-10-11)回复
      • [root@ip-172-31-14-16 ec2-user]# /etc/init.d/shadowsocks start shadowsocks start success [root@ip-172-31-14-16 ec2-user]# /etc/init.d/shadowsocks status shadowsocks is stopped [root@ip-172-31-14-16 ec2-user]# [root@ip-172-31-14-16 ec2-user]# /etc/init.d/shadowsocks restart /etc/init.d/shadowsocks: line 32: kill: (26495) - 没有那个进程 shadowsocks stop failed shadowsocks start success
        micheal10年前(2014-10-11)回复
        • 遇到的问题和你一样 不知道你怎么解决的
          leo10年前(2014-11-04)回复
  4. 服务器支持ipv6,本地网络支持ipv6,但是通过ipv6连接超时,是服务端配置的问题吗?
    haywire10年前(2014-10-09)回复
    • 配置文件默认只配置ipv4,因此你需要手动改一下 /etc/shadowsocks/config.json 中的 server 的值,改为ipv6,再重启下试试。
      秋水逸冰10年前(2014-10-09)回复
  5. WARNING: certificate common name `www.github.com' doesn't match requested host name `raw.githubusercontent.com'. HTTP request sent, awaiting response... 404 Not Found 2014-10-06 21:01:53 ERROR 404: Not Found. Exit code: 8 这个是什么情况
    zhidai10年前(2014-10-07)回复
  6. pc用firefox, shadowsocksgui 能用 火狐扩展autoproxy代替吗?
    king10年前(2014-10-03)回复
    • 推荐autoproxy插件用于Firefox。
      秋水逸冰10年前(2014-10-03)回复
      • 有autoproxy 就不用安装 shadowsocksgui?
        king10年前(2014-10-03)回复
        • shadowsocksgui是客户端,用于连接服务端的,所以必须要开启了后,才能用autoproxy的。
          秋水逸冰10年前(2014-10-04)回复
  7. shadowsocks已经发布了RC4-MD5版本,大哥能不能放个整合了shadowsocks最新版本的一键安装包啊
    hunter10年前(2014-09-30)回复
    • rc4-md5只是种加密方式,安装完成后,可以自行修改配置文件里的加密方式。本脚本每次安装都是取最新版本进行安装的。
      秋水逸冰10年前(2014-09-30)回复
      • 谢谢
        hunter10年前(2014-09-30)回复
      • 那具体怎么修改配置文件呢
        zhidai10年前(2014-10-07)回复
        • 修改 /etc/shadowsocks/config.json 中的 method 的值,保存后,重启 Shadowsocks 即可。
          秋水逸冰10年前(2014-10-07)回复
  8. 您好,我安装了您的这个,好久没用了,不记得当时的配置了,请问怎么查看 谢谢
    lkainan10年前(2014-09-28)回复
    • 查看配置文件 /etc/shadowsocks/config.json 即可。
      秋水逸冰10年前(2014-09-28)回复
      • 谢谢
        lkainan10年前(2014-09-28)回复
        • 可以创建多用户不?
          lkainan10年前(2014-09-28)回复
          • 如何配置多用户?详见:这里 备注:Shadowsocks 已经支持多用户,在配置文件中增加不同的端口,对应不同的密码即可。
            秋水逸冰10年前(2014-09-28)回复
            • hao de 谢谢
              lkainan10年前(2014-09-30)回复
  9. 怎么加-u,就是支持udp
    Yafei10年前(2014-09-25)回复
    • 在 /etc/init.d/shadowsocks 文件中编辑第 72 行最后加个-u,已经有人试验成功了。如下: daemon $DAEMON -c $CONF -f $PID -u
      秋水逸冰10年前(2014-09-25)回复
  10. 我给shadowsocks配置多两个多口,防火墙也添加了一个端口 重启防火墙出现下面这个 请问怎么解决? iptables: Applying firewall rules: FATAL: Module ip_tables not found. iptables-restore v1.4.7: iptables-restore: unable to initialize table 'nat'
    ranbo10年前(2014-09-23)回复
    • 防火墙规则写的不对。修改 /etc/sysconfig/iptables 中的内容,有篇 文章 中的 iptables 规则仅供参考。
      秋水逸冰10年前(2014-09-23)回复
      • 防火墙里多打开一个端口 直接把8989那行复制到下面,改成别的端口,这样不行的吗/
        ranbo10年前(2014-09-23)回复
        • 不是复制到最下面,而是复制到 8989 端口这一行的下面。这样保存后再重启 iptables 应该就可以了。
          秋水逸冰10年前(2014-09-24)回复
          • 重新设置之后可以了.现在还有个问题,请问如何设置另外几个多开的shadowsocks实例开机自启呢?
            ranbo10年前(2014-09-24)回复
            • 这样子是比较麻烦的,这里 还有一个方法,可以开启多用户。在配置文件中增加不同的端口,对应不同的密码即可。这样子开机自启动也就解决了。
              秋水逸冰10年前(2014-09-25)回复
  11. 请问下 root下 我打开/etc/shadowsocks/config.json 它提示 PERMISSION DENIED 应该怎么操作 我是小白 还请大哥帮个忙 谢谢
    ANDY10年前(2014-09-23)回复
    • 权限被拒绝,目测应该不是 root 用户登录的吧。你可以用 Winscp 登录 root,将此配置文件修改后再传上去覆盖。
      秋水逸冰10年前(2014-09-23)回复
      • 我用的是 亚马逊自己的Linux 用的是root权限 还请您帮我一下 标准小白一个 给您添麻烦了 不好意思
        ANDY10年前(2014-09-23)回复
        • 登陆时用的bitvise
          ANDY10年前(2014-09-23)回复
          • root 用户登录后,理论上是任何文件都可以修改的。 vim改不了的话,你可以用 Winscp 登录 root 后,把配置文件下载回来修改,改完再覆盖上去。 SSH 工具推荐 Winscp + putty。
            秋水逸冰10年前(2014-09-24)回复
            • 感谢您的细心指导,已经可以使用了 谢谢
              ANDY10年前(2014-09-24)回复
  12. 请问老大.怎么查看当前安装的shadowsocks的版本啊.
    sam10年前(2014-09-22)回复
    • Shadowsocks-libev 版在源代码的 README.md 文件里有版本号。 如果你想更新 Shadowsocks-libev 版,只需先卸载再安装一次就可以了。
      秋水逸冰10年前(2014-09-22)回复
      • 是不是每次用你的一键脚本. 它是自动用Shadowsocks-libev 最新的源码编译安装的啊.我是想试试最新的RC4-MD5的加密方式..呵呵
        sam10年前(2014-09-22)回复
        • 没错。每次都是在 Github 下载最新源码编译安装的。 更改加密方式只需修改配置文件 /etc/shadowsocks/config.json 中的 method 的值,再重启 Shadowsocks 即可。
          秋水逸冰10年前(2014-09-22)回复
  13. 请问我想修改服务器端端口该如何操作,代码是什么,谢谢
    kfyang10年前(2014-09-17)回复
    • 自行修改配置文件 /etc/shadowsocks/config.json 中的 server_port 字段的值,然后 /etc/init.d/shadowsocks restart 重启一下即可。 同时,如果开启了防火墙,需要对相应的端口放行。
      秋水逸冰10年前(2014-09-18)回复
      • 谢谢
        kfyang10年前(2014-09-19)回复
  14. 多次测试不行。 finishing deferred symbolic links: shadowsocks-libev-master/Changes -> debian/changelog checking for a BSD-compatible install... /usr/bin/install -c checking whether build environment is sane... configure: error: newly created file is older than distributed files! Check your system clock make: *** No targets specified and no makefile found. Stop. Shadowsocks-libev install failed! Please visit https://teddysun.com/357.html and contact.
    hdj10年前(2014-09-16)回复
    • 检查你的系统时间是否设置有误。 参考此文,问题即可解决。
      秋水逸冰10年前(2014-09-16)回复
  15. finishing deferred symbolic links: shadowsocks-libev-master/Changes -> debian/changelog checking for a BSD-compatible install... /usr/bin/install -c checking whether build environment is sane... configure: error: newly created file is older than distributed files! Check your system clock make: *** No targets specified and no makefile found. Stop. Shadowsocks-libev install failed! Please visit https://teddysun.com/357.html and contact. 前2天安装无问题,今天发现此问题,菜鸟寻求帮忙。
    hdj10年前(2014-09-16)回复