Debian下shadowsocks-libev一键安装脚本

技术 秋水逸冰 721165浏览 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. UP 我安装了你的SS一键包 然后安装了LinuxEye的LNMP环境包后就不能连接了 请问是为什么
    aoe9年前(2015-03-21)回复
    • 看看是不是端口冲突了?默认是 8989 端口。照理说,是不会冲突的。
      秋水逸冰9年前(2015-03-22)回复
  2. 你好,这个我在VPS上安装完毕后,并不能开机自启,只能每次开机后手动启动。而且我在/etc/rc.local中添加"/etc/init.d/shadowsocks start",然后手动执行/etc/rc.local报错:“/bin/sh: 0: illegal option”请问这是为什么呢?
    XuQK9年前(2015-03-14)回复
    • 感谢提醒,这是启动脚本里的一个 bug,现已修复了这个问题。你只需先卸载,然后下载最新脚本再安装一次即可。 无需再往 /etc/rc.local 里手动添加了。
      秋水逸冰9年前(2015-03-14)回复
  3. 謝謝站長的腳本,但是在搬瓦工的Debian7.0上,用這個腳本安裝完後,客戶端可以連上服務器,但是上不了網, 試了Python那個腳本就沒問題,不知道是為什麼
    新手9年前(2015-03-11)回复
    • 我也不知道是什么原因。我在写这个脚本测试的时候用的就是搬瓦工的 Debian 7,连接完全没问题。
      秋水逸冰9年前(2015-03-11)回复
  4. 求debian下shadowsocks-python的一键安装包。。。 太懒了。。。
    gladuo9年前(2015-03-08)回复
  5. 现在我想搭一个能走ipv6和ipv4的怎么办,谢谢
    -,-9年前(2015-03-06)回复
    • 默认搭建完毕后是监听地址 0.0.0.0,如果你使用 Shadowsocks 的 go 版,并使用多端口配置,则监听地址是:: (这样的话就完全支持 ipv6 和 ipv4 了) 如果你本地网络支持 ipv6 那就可以走 ipv6(本地客户端的服务器 IP 设为 ipv6)
      秋水逸冰9年前(2015-03-06)回复
      • 以前是::就可以了,貌似现在新版改成需要使用["[::0]","0.0.0.0"]
        Tom9年前(2015-03-08)回复
        • 你所写的[“[::0]”,”0.0.0.0″],格式似乎不是很标准,能否麻烦写得具体一点。。。
          eijud9年前(2015-04-28)回复
  6. 搞好了,谢谢了
    -,-9年前(2015-03-05)回复
  7. 想问下ubuntu debian centos都试过都说成功但是就是上不上 是怎么回事
    -,-9年前(2015-03-05)回复
  8. 又来麻烦你了, 我用亚马逊的aws 来搭建Shadowsocks,系统是ubuntu 输入 wget --no-check-certificate https://raw.githubusercontent.com/teddysun/shadowsocks_install/master/shadowsocks-libev-debian.sh chmod +x shadowsocks-libev-debian.sh 两段指令都OK,但是输入最后一段./shadowsocks-libev-debian.sh 2>&1 | tee shadowsocks-libev-debian.log 时报错。 报错信息是:this script must be run as root! 亚马迅 的主机是用密钥登陆的,我怎么启用root 方式登陆 ,请指教。万分感谢!
    amex9年前(2015-02-27)回复
    • 使用 root 用户登录,或者在登录后 su 临时切换到 root 即可
      秋水逸冰9年前(2015-02-28)回复
      • 谢谢!已经完全搞定,非常强大,速度很快啊
        amex9年前(2015-03-01)回复
  9. 已经找到开启UDP转发的办法 nohup /usr/local/bin/ss-server -c /etc/shadowsocks/config.json > /dev/null 2>&1 & 改成 nohup /usr/local/bin/ss-server -u -c /etc/shadowsocks/config.json > /dev/null 2>&1 & 并把开机启动命令也改下就可以了,手机SS客户端现在勾选UDP转发也能用了,但路由器一勾选UPD转发还是无法解析国外的网站域名,不知道是什么原因,继续研究ing
    skywing9年前(2015-02-23)回复
  10. 用你这个脚本在VPS搭建了SS,非常好用,电脑手机都用客户端用得很好,我现在在搞OPENWRT路由自动翻墙,按照这个教程操作的,路由器已经正常工作,就是UDP转发不好用,你安装的这个版本支持UDP转发吗? 我看好像较新版本的SS都支持这个功能,为什么我一使用UDP转发DNS就会解析不了呢?你有配置过路由器自动翻墙吗?交流交流
    skywing9年前(2015-02-23)回复
  11. 完全不懂,唉~~
    wang9年前(2015-02-23)回复
  12. Linux 完全不懂,但按照教程在debian 7 下安装一键脚本成功。请问博主,请否把如何修改端口,口令,加密方式以及增加用户的命令写一写。谢谢。
    Ya9年前(2015-02-11)回复
    • 这个写命令实现不如自己顺手就改了来得快。
      秋水逸冰9年前(2015-02-11)回复
      • 我的意思就是叫博主再教一较小白如何修改端口,口令,加密方式这些如何操作。
        Ya9年前(2015-02-11)回复
        • 就是改一下配置文件,然后重启,实在不行用 sftp 登录进去把配置文件下载回来改好在上传覆盖也行啊。 这个过程真心不用再赘述了。如果想在 ssh 里用命令行改,那至少要去简单学一下 vim 或者 nano 的操作,除此之外,也没有什么难度。
          秋水逸冰9年前(2015-02-11)回复
          • 已经成功。谢谢。
            Ya9年前(2015-02-12)回复
          • 另,新手入门的话,建议学习 CentOS还是Debian?
            Ya9年前(2015-02-12)回复
            • 什么系统看个人喜好。我选的是 CentOS。 先学学 Linux 基础吧。
              秋水逸冰9年前(2015-02-12)回复
  13. 我想求助一下 我发现我有个ssserver进程是杀不掉的. 杀掉就自动起来 root 1868 0.0 1.0 49080 10280 ? Ss 12:30 0:00 /usr/bin/python /usr/local/bin/ssserver -c /etc/shadowsocks/config.json -d start root 1890 0.0 0.0 10464 920 pts/0 S+ 12:30 0:00 grep --color=auto ssserver 就是1890这个进程 1868 是我自己开启的,1890 自己的 sudo kill all 啥都不行,杀了就启动 这样的情况下 我使用客户端完全没有反应 是为啥
    ikik9年前(2015-01-20)回复
    • 1890 其实是 grep 进程。这跟你的启动脚本有关吧。何况,你这根本不是我所写的脚本。
      秋水逸冰9年前(2015-01-20)回复
  14. 秋大,我按照你的这个一键安装脚本安装ss,手动启动ss-server总是失败,错误信息截图http://pan.baidu.com/s/1pJyVqeJ 我的环境是搬瓦工64Mvps,debian 6,烦请秋大指教
    cc9年前(2015-01-07)回复
    • 看了截图,有两种可能: 1,本脚本在安装完成后,会自动启动,如果安装的日志里有 Shadowsocks-libev start success! 那就表示已经启动成功了,这时候再启动同样的,就会出错; 2,修改过配置文件 /etc/shadowsocks/config.json ,但该的不对,也就无法启动。
      秋水逸冰9年前(2015-01-07)回复
      • 秋大,又来麻烦你了 我debian下始终无法成功,现在已经重装成CentOS。 然后用了你CentOS 下 shadowsocks-libev 一键安装脚本教程里的方法,已经成功开启服务端,但是问题是windows下shadowsocks-gui始终无法连接。 我昨晚尝试了先将config.json里的server ip改成0.0.0.0,然后忘记重启服务,居然神奇的可以使用了,手机端的影梭也正常可用。 今天白天我尝试配置多端口使用,发现本地端又蛋疼地连不上了,改回原配置后依然连不上。 之后重复昨晚的方法,未成功,期间还尝试改成0.0.0.0后重启服务,改server port,完全关闭防火墙,始终无效,所以又来请教一下你。
        cc9年前(2015-01-21)回复
        • 卸载掉,换 Python 或者 go 版,才能用多用户多端口。
          秋水逸冰9年前(2015-01-21)回复
          • 现在问题是我把配置改回原来单用户的内容,也还是连不上 刚刚贴的连接错误信息怎么没了
            cc9年前(2015-01-21)回复
            • 仔细检查配置内容,少了逗号多了逗号什么的。还不行就卸载装别的版本。那错误信息没什么用,我删掉了。
              秋水逸冰9年前(2015-01-21)回复
              • 我试试装其他版本吧,先谢谢了
                cc9年前(2015-01-22)回复
      • 秋大,我找到原因了 你的CentOS 下 shadowsocks-libev 一键安装脚本中config.json文件写入了一行"local_address":"127.0.0.1",而我把这行去掉后再重启服务就一切正常了,不知道是什么原因
        cc9年前(2015-01-23)回复
        • 我在所有的vps上测试过这种配置,这是官方的配置,测试下来也是没问题的。 其实 local_address 这一行完全不写也是可以的。
          秋水逸冰9年前(2015-01-23)回复
          • 我也不知道是不是我系统的其他地方配置有问题,反正我这么删了以后它居然奇迹般地能够正常连接了,如果有人遇到和我一样的问题也许可以借鉴
            cc9年前(2015-01-24)回复
          • 再次谢过
            cc9年前(2015-01-24)回复
  15. 秋大,请问我安装ss一键包成功了,电脑端连接正常可以访问,手机端无法使用,显示连接正常,就是无法访问网络
    xuzizzz9年前(2014-12-22)回复
    • 安装梭影,给予root权限再试试。我在手机上就是这么干的,否则只能以 vpn 方式连接。
      秋水逸冰9年前(2014-12-23)回复
      • 已经给root权限了,就是不行。。。。我的另一个ip的就可以,感觉vps如果是10开头的ip貌似都有问题~
        xuzizzz9年前(2014-12-23)回复
        • vps的ip如果是以10开头,那就是内网ip,所以肯定有问题啊。
          秋水逸冰9年前(2014-12-23)回复
          • 会吗?按理说也不应该啊,我架在上面的博客可以访问呢
            xuzizzz9年前(2014-12-24)回复
            • 亚马逊的 EC2 用我的这个脚本是搭建不起来的,我也没在这上面测试过。 如果要搭梯子,最好还是不要和有网站的混在一起,以免受牵连。
              秋水逸冰9年前(2014-12-25)回复
              • 我已经安装完成 但是通过shadowsocks 不能访问任何网站 国内的也不能访问。请问是怎么回事?http://pan.baidu.com/s/1qWHQ32s
                草其月9年前(2015-01-19)回复
                • 你这是 Amazon 的 EC2 吗?我看截图里的 IP 是内网 IP,那么需要修改一下配置文件里的 server 的值,改为其内网 IP 即可。
                  秋水逸冰9年前(2015-01-19)
              • ############################################################# # Install Shadowsocks-libev server for Debian or Ubuntu # # Intro: https://teddysun.com/358.html # # Author: Teddysun # # Github: https://github.com/shadowsocks/shadowsocks-libev # ############################################################# ./shadowsocks-libev-debian.sh: line 39: curl: command not found Error: Get shadowsocks-libev latest version failed 前面两个命令都没问题,就这个怎么都不行,麻烦帮忙看下,感谢~
                hs8年前(2016-09-18)回复