使用 Docker 快速部署 Shadowsocks-libev + v2ray-plugin

转载 秋水逸冰 240900浏览 117评论

条件准备

一台墙外VPS;
一台安装好 SSH 客户端的本地电脑;
如果需要 tls 功能则需要准备一个域名以及一个 Cloudflare 账号。

一、安装 Docker

1.1 以 root 用户登录,执行一键脚本安装 Docker

以Debian系为例,升级源并安装软件

$ apt-get update && apt-get install -y wget vim

执行此命令等候自动安装 Docker

$ wget -qO- get.docker.com | bash

说明:推荐使用 KVM 架构的 VPS,OpenVZ 架构的 VPS 不支持安装 Docker,另外 CentOS 8 不支持用此脚本来安装 Docker。

1.2 对 Docker 的一些命令操作

查看 Docker 安装版本等信息

$ docker version

启动 Docker 服务

$ systemctl start docker

查看 Docker 运行状态

$ systemctl status docker

将 Docker 服务加入开机自启动

$ systemctl enable docker

下面讲解的配置从上往下,难度由简到繁,如果你想一步到位,建议跳过二,三步,直接看第四步。

二、用 Docker 部署 Shadowsocks-libev + v2ray-plugin over websocket (HTTP)

2.1 创建配置文件

在 /etc 目录下创建 shadowsocks-libev 目录

$ mkdir /etc/shadowsocks-libev

切换目录至 /etc/shadowsocks-libev

$ cd /etc/shadowsocks-libev

创建并开始编辑名为 config.json 的配置文件

$ vim config.json

以下为配置文件内容示例,添加后保存并退出

{
"server":"0.0.0.0",
"server_port":9000,
"method":"aes-256-gcm",
"timeout":300,
"password":"password0",
"fast_open":false,
"nameserver":"8.8.8.8",
"mode":"tcp_and_udp",
"plugin":"v2ray-plugin",
"plugin_opts":"server"
}

说明:server 后面默认填 0.0.0.0,请不要修改。关于更多参数用法和说明请参考:这个链接
值得注意的是,如果把 plugin_opts 改为

"plugin_opts":"server;mux=0"

后就可以用 Quantumult X。

2.2 用 Docker 结合上面的配置文件创建并启动容器

命令如下:

$ docker run -d --name ss-libev --restart always -p 9000:9000 -p 9000:9000/udp -v /etc/shadowsocks-libev:/etc/shadowsocks-libev teddysun/shadowsocks-libev

参数解释:
docker run:开始运行一个容器
-d 参数:容器以后台运行并输出容器ID
–name 参数:给容器分配一个识别符,方便将来的启动,停止,删除等操作
–restart 参数:配置容器启动类型,always 即为 docker 服务重新启动时自动启动本容器
-p 参数:容器的 9000 端口映射到本机的 9000 端口。默认是 TCP 映射,当需要 UDP 映射时候,那就再追加一次 UDP 的映射。冒号后面是容器端口,冒号前面是宿主机端口,可以写成一致,也可以写成不一致
-v 参数:挂载卷(volume),冒号后面是容器的路径,冒号前面是宿主机的路径,可以写成一致,也可以写成不一致
teddysun/shadowsocks-libev:这是从 docker hub 下载回来的镜像完整路径名

2.3 后期容器处理常用命令

前面 docker run 后面 –name ss-libev 中的 ss-libev 为 $name,其代表容器识别符,也就是 $name=ss-libev。
查看容器在线状态及大小

$ docker ps -as

查看容器的运行输出日志

$ docker logs $name

重新启动容器,一般在修改除端口外的配置后使用使修改生效

$ docker restart $name

停止容器的运行

$ docker stop $name

移除容器

$ docker rm $name

查看 docker 容器占用 CPU,内存等信息

$ docker stats --no-stream

三、用 Docker 部署 Shadowsocks-libev + v2ray-plugin over websocket (HTTPS)

3.1 用 acme.sh 脚本申请 SSL 证书

此处需要用到一个你拥有的域名。参考:这篇文章。下面默认你已经获取到 Clouflare API key,并且也已经安装好 acme.sh 脚本。

3.2 创建配置文件

在 /etc 目录下创建 shadowsocks-libev 目录

$ mkdir /etc/shadowsocks-libev

切换目录至 /etc/shadowsocks-libev

$ cd /etc/shadowsocks-libev

创建 config.json 的配置文件

$ vim config.json

以下为配置文件内容示例,添加后保存并退出

{
"server":"0.0.0.0",
"server_port":9000,
"password":"password0",
"timeout":300,
"method":"aes-256-gcm",
"fast_open":false,
"nameserver":"8.8.8.8",
"mode":"tcp_and_udp",
"plugin":"v2ray-plugin",
"plugin_opts":"server;tls;host=mydomain.me;cert=/etc/shadowsocks-libev/plugin.crt;key=/etc/shadowsocks-libev/plugin.key"
}

说明:server 后面的 0.0.0.0 不要修改,plugin_opts 后面的配置除了域名外也不要修改

3.3 安装证书到 Shadowsocks-libev 配置文件的目录 /etc/shadowsocks-libev

假设你的是域名是 mydomain.me,且已经在 Cloudflare 上设置好 A 记录解析
CF_Key 的值替换成你自己的 Cloudflare API Key

$ export CF_Key="xxxxxxxxxxxxxxxxxxxxxxxxxxx"

CF_Email 的值替换成你自己的 Cloudflare 注册邮箱账号名

$ export CF_Email="[email protected]"

用 acme.sh 脚本申请证书

$ acme.sh --issue --dns dns_cf -d mydomain.me -k ec-256

安装证书到 Shadowsocks-libev 配置文件的目录 /etc/shadowsocks-libev

$ acme.sh --installcert -d mydomain.me --fullchain-file /etc/shadowsocks-libev/plugin.crt --key-file /etc/shadowsocks-libev/plugin.key --ecc

3.4 用 Docker 结合上面的配置文件创建并启动容器

$ docker run -d --name ss-libev --restart always -p 9000:9000 -p 9000:9000/udp -v /etc/shadowsocks-libev:/etc/shadowsocks-libev teddysun/shadowsocks-libev

四、用 Docker 部署 Shadowsocks-libev + v2ray-plugin over websocket (HTTP) + TLS + caddy + CDN

4.1 申请 SSL 证书以及安装证书

参考上面的 3.1 和 3.3 章节。

4.2 创建配置文件

在 /etc 目录下创建 shadowsocks-libev 目录

$ mkdir /etc/shadowsocks-libev

切换目录至 /etc/shadowsocks-libev

$ cd /etc/shadowsocks-libev

创建 config.json 的配置文件

$ vim config.json

以下为配置文件内容示例,添加后保存并退出

{
"server":"127.0.0.1",
"server_port":9000,
"password":"password0",
"timeout":300,
"method":"aes-256-gcm",
"fast_open":false,
"nameserver":"8.8.8.8",
"mode":"tcp_and_udp",
"plugin":"v2ray-plugin",
"plugin_opts":"server;path=/ray"
}

说明:因为要监听本地,所以 server 后面地址填 127.0.0.1, 9000 端口不对外开放,此处只是在 websocket 的配置上加了个 path 参数(后面的值可以更改,比如可以改为 path=/teddysun),tls 则要由 caddy 来提供。

4.3 用 Docker 结合上面的配置文件创建并启动容器

命令如下:

$ docker run -d --name ss-libev --restart always --net host -v /etc/shadowsocks-libev:/etc/shadowsocks-libev teddysun/shadowsocks-libev

说明:此处不用端口映射,直接使用

--net host

参数配置,让容器跟宿主机共用网络。

4.4 安装 caddy

执行下面一条命令安装 caddy v1.0.5,并把它放到 /usr/bin 目录下(此为 Linux x86_64 系统示例)

$ wget -O /usr/bin/caddy https://dl.lamp.sh/files/caddy_linux_amd64
$ chmod 755 /usr/bin/caddy

如果是 Linux x86 系统,则执行如下命令

$ wget -O /usr/bin/caddy https://dl.lamp.sh/files/caddy_linux_386
$ chmod 755 /usr/bin/caddy

4.5 配置 caddy 目录

在/root目录下创建 caddy 目录并切换至此

$ cd /root && mkdir caddy && cd caddy

安装证书和 key 到 /root/caddy 目录下

$ acme.sh --installcert -d mydomain.me --fullchain-file /root/caddy/caddy.crt --key-file /root/caddy/caddy.key --ecc

4.6 创建 caddy 配置文件

创建文件并开始编辑 caddy 配置文件 caddy.conf

$ vim caddy.conf

下面是 caddy 配置文件示例,添加后保存并退出

mydomain.me:443 {
  gzip
  tls /root/caddy/caddy.crt /root/caddy/caddy.key
  log /root/caddy/caddy.log
  proxy / https://www.baidu.com
  proxy /ray 127.0.0.1:9000 {
    websocket
    header_upstream -Origin
  }
}

说明:此处只要关注路径和端口号,9000 是 /etc/shadowsocks-libev/config.json 里配置的,/ray 是配置文件内 plugin_opts 后面的 path=/ray,请注意替换。另 caddy 需要监听 443 端口,请确保 VPS 的 443 端口没有被占用。

4.7 运行 caddy

后台运行 caddy

$ nohup caddy -conf /root/caddy/caddy.conf &

可以查看 caddy 运行产生的日志

$ cat /root/caddy/caddy.log

确认 caddy 运行状态,下面的命令有输出则表示正常

$ ps -ef | grep -v grep | grep caddy

4.8 开启 Cloudflare 的 CDN 保护,开启 SSL/TLS 的 Full 模式

如下图所示,第 1 步,开启 CDN

如下图所示,第 2 步,开启 Full 模式

五、客户端配置

5.1 Windows 客户端

先到这个链接下载 v2ray-plugin-windows-amd64 的安装包,下载完成后解压到 shadowsocks-windows 的安装目录下,并重命名为 v2ray-plugin.exe 即可。
选项说明:
插件程序:v2ray-plugin
如果选的是第一种,Shadowsocks-libev + v2ray-plugin over websocket (HTTP),插件选项这里可以留空
如果选的是第二种,Shadowsocks-libev + v2ray-plugin over websocket (HTTPS),插件选项这里填 tls;host=mydomain.me
如果选的是第三种,Shadowsocks-libev + v2ray-plugin over websocket (HTTP) + TLS + caddy + CDN,插件选项这里填 tls;host=mydomain.me;path=/ray
值得注意的是:如果你把 plugin_opts 改为

"plugin_opts":"server;mux=0"

后就可以用 Quantumult X 来使用这个节点,但 Windows 客户端不能直接使用了。

5.2 Android 客户端

先到这个链接下载插件并安装,其余的配置都跟上面 Windows 客户端一致。

5.3 iOS 客户端

请使用 Shadowrocket,也就是俗称的小火箭,添加如下配置使用。
填写服务器,端口,密码,选择算法,插件选择 v2ray-plugin

点击插件 v2ray-plugin

设置插件 v2ray-plugin,开启 TLS,填写路径,服务器则填写你的域名

六、写在最后

本文为网友【毕世平】所总结,我只是在其基础上稍作修改。如有不对的地方,欢迎在评论里指出。

参考链接:

https://shiping.date/6.html

转载请注明:秋水逸冰 » 使用 Docker 快速部署 Shadowsocks-libev + v2ray-plugin

发表我的评论
取消评论

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

表情

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

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

网友最新评论 (117)

  1. 请问cloudflare中若更改IP地址,域名不变,还需要用acme.sh脚本再一次给域名重新申请证书吗?
    CY4年前(2019-12-05)回复
  2. 请问这个要怎么办?在用acme.sh脚本申请证书并自动续更那里,3.3 复制/安装证书这一步,输入命令后,返回结果是: [Wed Dec 4 04:57:24 EST 2019] Installing key to:/root/ssl/web.key /root/.acme.sh/acme.sh: line 5242: /root/ssl/web.key: No such file or directory, debian9/10,32/64位系统都试过,都是这个情况
    fx4年前(2019-12-04)回复
  3. 欢迎回来.....
    陈狗子4年前(2019-12-03)回复
  4. 你好,按照由繁到简单,我先后使用了第一种和第二种方式,这两种方式手机的移动电信卡皆可联网,而使用第三种方式只有电信可以通,移动不可,请问这一般都有什么原因呢?(移动卡开启或关闭云朵都不通)
    willoong4年前(2019-12-02)回复
  5. 第三种方案的windows客户端如何配置,上不了网
    kirlf4年前(2019-12-01)回复
  6. 我重装了系统,直接用你的docker镜像部署了,最简单的不用v2ray-plugin可以上网,查看容器状态,里面有我设置的端口0.0.0.0:17911->17911/tcp, 0.0.0.0:17911->17911/udp,然后我删除了容器,按照第一种方案http的,重新配置了一个新的容器,不能上网,查看容器状态,发现端口下面空白,没有映射的端口,试了几回都这样
    kirlf4年前(2019-12-01)回复
    • 可以了,删掉容器,删掉配置文件,重新启动了下系统,重新创建配置文件和容器后可以了
      kirlf4年前(2019-12-01)回复
  7. 我用你的一键安装shadowsocks-libev脚本配置好后可以正常上网,我现在按第一种方案开始配置,按着步骤一步一步来,配置好了,端口、密码和脚本安装的一样的,就是不能上网了,不知道什么原因,还是和客户端配置有关吗?因为端口、密码一样,电脑客户端的配置是用的同一个配置
    kirlf4年前(2019-12-01)回复
  8. 配置好,服务器出现这个错误是为啥 ERROR: bind: Address not available ERROR: failed to bind address
    mencao4年前(2019-11-30)回复
  9. 您好,我不太懂安卓的操作,请问可以详细点吗
    ninin4年前(2019-11-30)回复
  10. 大神好,cloudfare API key在Cloudflare哪选项上查看?
    请教大神4年前(2019-11-29)回复
    • 你好,请参考这个链接实现 https://ssu.tw/index.php/archives/8/
      毕世平4年前(2019-11-29)回复
  11. 感谢这么好的教程! 第二种方案按照教程成功创建。 第三种方案有个问题,发现每次vps重启后,caddy无法后台自启,都必须手动执行一遍nohup caddy -conf /root/caddy/caddy.conf &才行,发现原帖用的的配置文件名是Caddyfile,不知是我哪个步骤做的不对,还是确实需要手动添加自启指令才行,是的话请问如何添加,本人纯粹是代码一步步验证型,几乎没有linux知识,再次感谢各位辛苦付出!
    CY4年前(2019-11-29)回复
    • 确实,在linux重启后确实需要再重新执行这样的一边指令才能启动。有下面一个解决方案,可以考虑使用。 cd /etc/systemd/system && vim caddy.service //切换到此目录下,创建并开始编辑服务文件 //以下是文件内容,请添加至文件 [Unit] Description=Caddy Service After=network.target [Service] ExecStart=/usr/local/bin/caddy -conf /root/caddy/caddy.conf Restart=on-abort LimitNOFILE=1048576 [Install] WantedBy=multi-user.target //以上是文件内容,添加至文件 systemctl daemon-reload //重载服务 systemctl start caddy //启动caddy.service服务 systemctl status caddy //查看caddy服务运行状况 systemctl enable caddy //将此服务加入开机自启动 参考链接是:https://ssu.tw/index.php/archives/6/
      毕世平4年前(2019-11-29)回复
  12. "nameserver":"8.8.8.8",这个8.8.8.8要修改吗? proxy /ray 127.0.0.1:9000,/ray 是配置文件内 plugin_opts 后面的 path=/ray,请注意替换,我没改,还是path=/ray,那这里就不需要改吧
    kirlf4年前(2019-11-28)回复
    • "nameserver":"8.8.8.8",这个8.8.8.8代表着域名解析服务器,可以不改,当然你也可以设置成1.1.1.1 你配置文件里"plugin_opts":"...;path=/ray"的话,caddy.conf配置里也要写成/ray,两者保持一致,但建议修改不要用这个分流路径。
      毕世平4年前(2019-11-29)回复
      • /ray这个随便填什么吗?
        kirlf4年前(2019-12-01)回复
        • 是的,这个是分流路径,可以随便填,比如填 /a1s2d3 ,都可以的,但是要保证你的ss配置文件里的这个分流路径要和caddy配置文件里写的一样。
          毕世平4年前(2019-12-02)回复
  13. 哇!第一次见
    通过好4年前(2019-11-28)回复
  14. 请问使用docker和直接在vps部署对速度有影响吗?
    makee4年前(2019-11-28)回复
  15. Android 小飞机怎么配置?就一句话跟windows相同,没搞清楚个套路
    eyre4年前(2019-11-28)回复
    • 先安装个 v2ray-plugin 插件 apk 程序,然后打开小飞机后里面插件那里就有 v2ray-plugin 可选了,配置方法跟 Windows 客户端一样。
      Teddysun4年前(2019-11-28)回复
      • 按照第四种配好了,但是速度慢了不只一点点超级卡,问题有可能是什么引起的?
        eyre4年前(2019-11-29)回复
        • 特殊时期这么干就好了,平时不建议这么干,因为开 CDN 确实会严重拖慢速度
          秋水逸冰4年前(2019-11-29)回复
          • 我只翻墙,不搭建网站,选第二种方式安全吗?
            rainy4年前(2019-12-15)回复