shadowsocks借助nginx实现后端负载均衡

2020-03-25 13:07:46 -0400

shadowsocks借助nginx实现负载均衡,自动切换“零”宕机

现在服务器(vps)的入门配置一般内存在512M,甚至有更小的256M、128M,小到“发指”,被戏称为“小鸡”。随着vps的价格一路狂跌,再遇上打折促销,加上季付年付等优惠手段,你完全能在1、2美元左右淘到一个512M内存的vps。当我们手上的vps越来越多,就可以将他们通过负载均衡统一起来,实现自动切换0宕机的ss/ssr“系统”。

1、准备工作

首先你手里需要2个或以上小鸡装了ss/ssr。这里演示我们有4个装有ss/ssr的小鸡,取名为小鸡A、B、C、D,搭建在各自上面的ss/ssr的ip和端口分别为:1.1.1.1:10000、2.2.2.2:20000、3.3.3.3:30000、4.4.4.4:40000;再准备一个服务器搭建nginx做负载均衡用,取名为小鸡E,这台服务器最好是国内的,可以感知小鸡A、B、C、D是否被墙。特别注意:需要负载均衡的小鸡之间(同一组,下面有讲),ss/ssr的账号密码协议加密混淆什么的都得一样。ssr可以兼容ss,如果使用ss软件,小鸡的ss和ssr可以混用;如果使用ssr软件,小鸡都必须是ssr,且除ip和端口外,所有设置必须相同。

2、安装nginx

在小鸡E上安装nginx,推荐使用Ubuntu/Debian系统,Centos当然也可以,但是Centos默认yum源里面没有nginx。下面演示的Centos系统为7版本。

Ubuntu/Debian

apt-get update
apt-get install nginx -y
service nginx start

Centos7

yum update
sudo rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm
yum install nginx -y
service nginx start

安装完毕后,在浏览器中输入小鸡E的ip地址,能打开网站即为成功。否则检查nginx是否启动,阿里腾讯等服务商需要额外检查防火墙是否开放80端口。

3、配置负载均衡

创建并打开一个自定义的配置文件

mkdir -p /etc/nginx/tcpconf.d
vi /etc/nginx/tcpconf.d/ssrproxy.conf

写入如下配置:

stream {
    upstream group1 {
        server 1.1.1.1:10000;
        server 2.2.2.2:20000;
    }
    server {
        listen 10000;
        listen 10000 udp;
        proxy_pass group1;
    }
    upstream group2 {
        server 3.3.3.3:30000;
        server 4.4.4.4:40000;
    }
    server {
        listen 20000;
        listen 20000 udp;
        proxy_pass group2;
    }
}

解释:这里一共有两组:group1和group2,使用小鸡E的10000端口来转发流量到小鸡A(1.1.1.1)或小鸡B(2.2.2.2),使用小鸡E的20000端口转发流量到小鸡C(3.3.3.3)或小鸡D(4.4.4.4)。形如1.1.1.1:10000这样的,就是你的小鸡A、B、C、D们上的ss/ssr的ip地址和端口了,不能错了。每个组都有一个或多个流量转发的对象,比如group1里有1.1.1.1和2.2.2.2,不是说流量同时转发到这两个服务器,而是通过nginx的负载均衡,自动轮询并转发流量到合适的服务器。

之后我们找到nginx的主配置文件,将上面自定义配置加载进nginx里。主配置文件一般在/etc/nginx/nginx.conf或者/etc/nginx/conf/nginx.conf里。

echo "include /etc/nginx/tcpconf.d/*.conf;" >> /etc/nginx/nginx.conf

重启一下nginx使配置生效

service nginx restart

4、如何使用

在ss/ssr客户端填写配置中,ip地址就是小鸡E的ip地址,端口就是小鸡E用来转发流量的端口,其他配置不变。借助负载均衡,你无需手动切换客户端的服务器,就能实现自动切换到可用的服务器了。

例如:假设小鸡E(负责负载均衡的服务器)的ip为5.5.5.5,填写的ip就是5.5.5.5。端口如果填写10000,相当于使用小鸡A和小鸡B;端口如果填写20000,相当于使用小鸡C和小鸡D。如果你想要所有的小鸡都在一个自动切换里,就把所有小鸡的ip和地址填写在同一组里。

一些说明

如果单纯用来中转,可以看看本站这篇文章:

«Newer      Older»
Comment:
Name:

Back to home

Subscribe | Register | Login | N