Debian下shadowsocks-libev一键安装脚本

技术 秋水逸冰 738830浏览 514评论

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

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

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

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

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

wget --no-check-certificate -O shadowsocks-libev-debian.sh https://raw.githubusercontent.com/teddysun/shadowsocks_install/master/shadowsocks-libev-debian.sh
chmod +x shadowsocks-libev-debian.sh
./shadowsocks-libev-debian.sh 2>&1 | tee shadowsocks-libev-debian.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/358.html
Enjoy it!

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

./shadowsocks-libev-debian.sh uninstall

其他事项:
客户端配置的参考链接:https://teddysun.com/339.html
本脚本安装完成后,已将 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)
CentOS 下 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。
2、修复:在 Debian 7 下默认没有 libudns-dev 依赖包的问题。

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、修正:Shadowsocks 服务改为强制默认开机启动。

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 版;

2015 年 03 月 09 日:
1、新增:启动脚本/etc/init.d/shadowsocks,使用更简单。
2、修正:优化安装过程。

2014 年 10 月 31 日:
1、修正:写入自启动命令到 /etc/rc.local 中的错误。

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

./shadowsocks-libev-debian.sh

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

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

发表我的评论
取消评论

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

表情

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

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

网友最新评论 (514)

  1. 谢谢您的教程,安装过程都很顺利,也都成功了。但是在客户端配置好之后,Chrome 提示无法连接到代理服务器,不知道是什么问题。是因为服务的iptables把端口禁了吗?
    Zenyo10年前(2014-12-18)回复
    • 想知道是不是防火墙的原因,就先把防火墙关了,能连上就说明是防火墙的原因。 如果还是连不上,就要考虑别的原因了,比如插件配置是否正确之类的。
      秋水逸冰10年前(2014-12-19)回复
  2. 老大,我的vps是ramnode$15那个,我用你的脚本,前两行命令运行之后都没问题,运行第三行命令的结果是是shadowsocks-libev install failed,我看了一下,期间archive.ubuntu.com的部分文件和security.ubuntu.com的大部分文件没有下载成功,最后checking for gcc, checking for cc, checking for cl.exe都提示:no。configure: error: in /root/shadowsocks-libev-master: cofigure: error: no acceptable C compiler found in $PATH make: ***No targets specified and no makefile found. stop。运行结果很长,我只把我认为可能导致失败的内容贴上来了,请老大帮忙!
    Nobody10年前(2014-12-12)回复
    • 这个意思很明显就是系统没有安装成功 gcc 编译器,导致编译失败。检查一下 apt-get -y update 这个命令能否正常运行。
      秋水逸冰10年前(2014-12-12)回复
      • 果然是老大说的原因,-bash: apt-get -y: command not found,老大我是小白,请问接下来我应该怎么做?
        Nobody10年前(2014-12-13)回复
        • 应该是安装的系统问题,看看你的环境变量PATH里有没有/usr/bin这个目录,如果没有就加进去。root用户执行以下命令: PATH="$PATH:/usr/bin" export PATH apt-get -y update
          秋水逸冰10年前(2014-12-14)回复
          • 按照老大的指点,安装成功,完美运行!感谢老大!好人一生平安!
            Nobody10年前(2014-12-14)回复
  3. 这是啥意思 root@ip-172-31-14-225:~# /usr/local/bin/ss-server -c /etc/shadowsocks/config.json 2014-11-21 09:53:10 INFO: initialize ciphers... aes-256-cfb 2014-11-21 09:53:10 ERROR: bind: Cannot assign requested address 2014-11-21 09:53:10 ERROR: Could not bind 2014-11-21 09:53:10 ERROR: bind() error..
    幽灵传说10年前(2014-11-21)回复
  4. bandwagonhost openvz vps128m内存, 用这一键安装脚本好象不行啊
    king10年前(2014-11-18)回复
  5. Shadowsocks-libev install failed! Please visit https://teddysun.com/358.html and contact. 求大神帮忙
    alfred10年前(2014-11-09)回复
    • 你的系统到底是 CentOS 还是 debian 的,你要搞清楚,另外,如果是 CentOS ,请换成 CentOS 6.x 的,不支持 5
      秋水逸冰10年前(2014-11-10)回复
  6. 脚本写的不错。。但建议在脚本执行之前可以加一行 apt-get update (我在linode下测试过该脚本。。没有update之前一些包是会出现404的。。)
    艳文10年前(2014-11-06)回复
    • 点击博主的链接,原来是曾经整理过很多资料的大神。
      smartsun10年前(2014-11-06)回复
    • @艳文,谢谢提示~安装到最后一步一直fail,get update一下就好了,同建议博主加上这一行。感谢博主写出这么赞的脚本,不知方便了多少人!
      guoxiong10年前(2014-11-09)回复
  7. 感谢你的分享,非常感谢!!!!!!! 直接用debina的脚本在Ubuntu14.04 64位系统上通过 安装成功。博主好厉害!
    蓝色的风吹过10年前(2014-11-01)回复
  8. 额,看来评论没通过~ :(
    签个名先10年前(2014-10-30)回复
  9. 秋水大大,补充下,俺的系统是Debian7.7。用脚本安装完成后,查看/etc/rc.local文件,看见自启动命令添加在exit 0 这行“后边”,手动改到exit 0这行上面,重启VPS后,能自动启动成功。还请秋水大大能抽空修正脚本。抱拳~
    老李10年前(2014-10-29)回复
  10. 谢谢秋水大大的分享,只是在俺的Debian系统上,添加自启动未成功。老菜鸟的俺,多方搜索下,找到了琉璃兄弟分享的一篇文章(http://zztsj.blogspot.com/2014/07/shadowsocks-libev-ubuntudebian.html),其中提到应该在 exit 0 这行“上边”添加:nohup /usr/local/bin/ss-server -c /etc/shadowsocks/config.json -u > /dev/null 2>&1 & (-u是开启UDP转发,测试成功),还请秋水大大在空闲的时候,能够修正下脚本,谢谢啦~
    老李10年前(2014-10-29)回复
    • 脚本已经修正了自启动的问题。 如果有兴趣的话,可以帮忙测试一下,看看是否完全没问题了。
      秋水逸冰10年前(2014-10-31)回复
      • 秋水大大费心了,下午俺就马上测试~完了给秋水大大回复。。。抱拳~
        老李10年前(2014-10-31)回复
      • 报告秋水大大,刚才俺重装VPS后,再次安装,其他都正常,就是自启动的问题还是没解决,/etc/rc.local文件未写入任何东西。
        老李10年前(2014-10-31)回复
        • 从截图来看,/etc/rc.local 文件中居然存在两个 exit 0 关键字,所以才会出现无法插入自启动命令的问题。 没办法,重新修改了下,初始状态下的 /etc/rc.local 文件末尾一行便是 exit 0, 因此改为插入自启动命令到文件末尾最后一行之前了。
          秋水逸冰10年前(2014-10-31)回复
          • 谢谢秋水大,经过测试,现在的脚本那是非常非常的完美~谢谢啦秋水大。。。抱拳~
            老李10年前(2014-10-31)回复
      • 执行前后,文件无变化,截图: http://www.laibude.com/update/QQ%E6%88%AA%E5%9B%BE20141031163722.png
        老李10年前(2014-10-31)回复
  11. 这个脚本能用在debian7吗?
    king10年前(2014-10-27)回复
  12. 有没有一键安装 L2TP/IPsec debian的 谢谢
    wind10年前(2014-10-26)回复
  13. 请问一下这是怎么回事,用的Debian 7,安装到最后显示下列 configure: error: in `/root/shadowsocks-libev-master': configure: error: no acceptable C compiler found in $PATH See `config.log' for more details make: *** No targets specified and no makefile found. Stop.
    岸上鱼10年前(2014-10-23)回复
    • 意思就是你的系统 $PATH 里缺少 C 编译器。 sudo apt-get install -y gcc
      秋水逸冰10年前(2014-10-23)回复
  14. 我在ec2的ubuntu14.04LTS版本安装之后: 1. 在/ect/rc.local文件里没有: nohup /usr/local/bin/ss-server -c /etc/shadowsocks/config.json > /dev/null 2>&1 &, 需要手动加在exit 0前面 2. 在/ect/shadowsocks/config.json文件里面的server ip是ec2的public ip,导致ss-server不能执行,用ec2 instance的private ip代换,就可以执行了。 3. 我ec2打开了8989端口,iptables 接收所有 traffic, accept all, input, output. 4. 可我在自己的机器用shadowsocks-gui for windows实验,浏览器就始终在哪里读取,不显示页面,拿不到数据。 怎么回事? 我怎样在这台server上测试,测试客户端?
    woody2k10年前(2014-10-20)回复
    • 把配置文件里的 server IP 换成 0.0.0.0 并重启后再试试。
      秋水逸冰10年前(2014-10-21)回复
      • 我和woody2k一样,使用了EC2(ubuntu 14.04).server IP修改为"0.0.0.0"也成功运行了. 在shadowsocks的客户端,始终显示和服务器无法建立链接. 同意用你的脚本在EC2(centos6.5)上,没有出现任何问题. 请抽空帮忙看看是咋一会儿.如果怕麻烦建虚拟服务器,我发我在用的给您. 先谢谢了!
        suhaha10年前(2014-12-04)回复
        • EC2的环境我没测试过,据说跟普通的 vps 不一样。精力(金钱?)有限,脚本并不完美,碰到这种情况,要么换 vps ,要么自行搜索解决方法吧。
          秋水逸冰10年前(2014-12-04)回复
  15. 请问下 Error: connect ECONNREFUSED怎么解决?用的FF+autoproxy+SS-gui 0.62
    pan10年前(2014-10-20)回复
    • 把配置文件 /etc/shadowsocks/config.json 里的 server 的值改为 0.0.0.0 后重启再试试。
      秋水逸冰10年前(2014-10-20)回复
      • 试验可行,谢谢。
        pan10年前(2014-10-21)回复