keepalived+lvs+nginx高并发集群

keepalived+lvs+nginx高并发集群

简介:

keepalived+lvs+nginx高并发集群,是通过LVS将请求流量均匀分发给nginx集群,而当单机nginx出现状态异常或宕机时,keepalived会主动切换并将不健康nginx下线,维持集群稳定高可用

1.LVS

lvs是一款用于四层负载均衡的工具。常见的如HTTP协议是建立在七层协议上的,而lvs作用于四层协议上,即传输层,网络层,数据链路层和物理层。这里的传输层主要协议有TCP和UDP协议,也就是说lvs主要支持的方式是TCP和UDP。所以lvs处理请求的能力比常见的服务器要高非常多,lvs的负载均衡能力是nginx的十倍以上。

nginx本身是不支持横向扩容的,对于高并发场景下,nginx就会成为性能瓶颈。而lvs是一款负载均衡工具,通过部署多台nginx服务器,利用lvs的负载均衡能力,将请求均衡的分发到各个nginx服务器上,再由nginx服务器分发到各个应用服务器,达到负载均衡能力

2.keepalived

keepalived是一款服务器状态检测和故障切换的工具。在其配置文件中,可以配置主备服务器和该服务器的状态检测请求。也就是说keepalived可以根据配置的请求,在提供服务期间不断向指定服务器发送请求,如果该请求返回的状态码是200,则表示该服务器状态是正常的,如果不正常,那么keepalived就会将该服务器给下线掉,然后将备用服务器设置为上线状态。

操作流程

  1. 安装LVS:

    • 在每个LVS服务器上运行以下命令以安装LVS软件包:

      复制代码
      sudo apt-get install ipvsadm
  2. 配置LVS:

    • 编辑/etc/sysctl.conf文件,并确保以下行被取消注释:

      复制代码
      net.ipv4.ip_forward=1
    • 保存并退出文件后,运行以下命令使更改生效:

      复制代码
      sudo sysctl -p
  3. 配置Keepalived:

    • 在每个服务器上安装Keepalived软件包:

      复制代码
      sudo apt-get install keepalived
    • 编辑/etc/keepalived/keepalived.conf文件,并根据你的需求进行配置。以下是一个示例配置文件的部分内容:

      复制代码
      vrrp_instance VI_1 {
          state MASTER
          interface eth0
          virtual_router_id 51
          priority 100
          advert_int 1
          authentication {
              auth_type PASS
              auth_pass 1111
          }
          virtual_ipaddress {
              192.168.0.100
          }
      }

      在上述配置中,你需要根据你的网络接口、虚拟路由器ID、优先级、认证密码和虚拟IP地址进行相应的更改。

  4. 配置Nginx:

    • 在每个LVS服务器上安装Nginx软件包:

      复制代码
      sudo apt-get install nginx
    • 编辑Nginx配置文件/etc/nginx/nginx.conf,并根据你的需求进行配置。以下是一个示例配置文件的部分内容:

      复制代码
      http {
          upstream backend {
              server 192.168.0.101:80;
              server 192.168.0.102:80;
          }
          server {
              listen 80;
              location / {
                  proxy_pass http://backend;
              }
          }
      }

      在上述配置中,你需要根据你的实际后端服务器的IP地址和端口进行相应的更改。

  5. 启动服务:

    • 在每个LVS服务器上分别启动LVS、Keepalived和Nginx服务:

      复制代码
      sudo service ipvsadm start
      sudo service keepalived start
      sudo service nginx start

这些是更详细的LVS、Keepalived和Nginx配置步骤。请根据你的具体需求进行相应的配置和调整。

相关推荐
Dovis(誓平步青云)8 小时前
《滑动窗口算法:从 “暴力遍历” 到 “线性高效” 的思维跃迁》
运维·服务器·数据库·算法
迎仔8 小时前
05-计算设备运维进阶:算力中心的设备医生
运维
石去皿9 小时前
【嵌入式就业10】Linux内核深度解析:从启动流程到驱动框架的工业级实践
linux·运维·服务器
Wpa.wk9 小时前
接口自动化 - 多环境统一文件配置 +多响应统一转换处理
运维·服务器·测试工具·自动化·接口自动化·统一配置
Trouvaille ~9 小时前
【Linux】应用层协议设计实战(二):Jsoncpp序列化与完整实现
linux·运维·服务器·网络·c++·json·应用层
是枚小菜鸡儿吖9 小时前
从 0 到 1 生成自定义算子:CANN + AIGC 的自动化工作流
运维·自动化·aigc
考琪9 小时前
Nginx打印变量到log方法
java·运维·nginx
SAP工博科技9 小时前
SAP 公有云 ERP 多工厂多生产线数据统一管理技术实现解析
大数据·运维·人工智能
YongCheng_Liang9 小时前
从零开始学虚拟化:桌面虚拟化(VDI)入门指南(架构 + 产品 + 部署)
运维·云计算
杜子不疼.9 小时前
【Linux】库制作与原理(二):动态库的制作与使用
linux·运维·服务器