基于CentOS7.5构建LVS-DR 群集,并启用Nginx负载均衡,一键完成。

news/2024/7/10 2:08:31 标签: lvs, nginx, 负载均衡

在两台服务器上的步骤:

  1. 安装必要软件:在两台服务器上,安装必要的软件,包括ipvsadmkeepalived。使用以下命令安装软件:

 sudo yum install ipvsadm keepalived -y
  1. 禁用防火墙或配置规则:禁用防火墙或根据实际需要配置允许LVS流量通过的防火墙规则。

  2. 编辑/etc/sysctl.conf文件:打开/etc/sysctl.conf文件并取消以下行的注释,使其生效:

 net.ipv4.ip_forward = 1
 net.ipv4.ip_nonlocal_bind = 1
 net.ipv4.conf.all.arp_ignore = 1
 net.ipv4.conf.all.arp_announce = 2

保存文件后执行以下命令使其生效:

 sudo sysctl -p
  1. 编辑/etc/keepalived/keepalived.conf文件:在两台服务器上,编辑/etc/keepalived/keepalived.conf文件,配置Keepalived的主备模式和虚拟IP。以下是一个示例配置文件:

 global_defs {
   router_id LVS_DEMO
 }
 ​
 vrrp_script check_nginx {
   script "killall -0 nginx"
   interval 2
   weight -30
 }
 ​
 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
   }
   track_script {
     check_nginx
   }
 }

在上述示例配置文件中,stateMASTER表示当前服务器为主节点,stateBACKUP则表示备节点。interface需要根据实际网络接口名称进行配置。

  1. 启动和启用Keepalived服务:在两台服务器上,启动和启用Keepalived服务。使用以下命令分别在两台服务器上执行:

 sudo systemctl start keepalived
 sudo systemctl enable keepalived

仅在主节点上的步骤:

  1. 安装和配置Nginx:在主节点服务器上,安装和配置Nginx作为负载均衡器。使用以下命令安装Nginx:

 sudo yum install nginx -y

然后,配置Nginx的负载均衡器。打开/etc/nginx/nginx.conf文件,按照以下示例配置添加一个HTTP部分:

 http {
   upstream backend {
     server 192.168.0.101:80;
     server 192.168.0.102:80;
   }
 ​
   server {
     listen 80;
     location / {
       proxy_pass http://backend;
     }
   }
 }

以上示例配置假设服务器1的IP地址为192.168.0.101,服务器2的IP地址为192.168.0.102。根据实际情况调整配置。

  1. 启动和启用Nginx服务:在主节点服务器上,启动和启用Nginx服务。使用以下命令执行:

 sudo systemctl start nginx
 sudo systemctl enable nginx

现在,您已经成功地在CentOS 7.5上构建了一个LVS-DR负载均衡集群,并使用Nginx作为负载均衡器。通过访问虚拟IP地址192.168.0.100,您应该能够通过负载均衡器访问到后端服务器。

请注意,上述步骤中的IP地址和配置仅供参考。您需要根据您的实际网络设置和需求进行适当的调整。

一键完成

下面是一个Shell脚本,可以自动化执行上述步骤来构建LVS-DR负载均衡集群并配置Nginx。

 #!/bin/bash
 ​
 PRIMARY_SERVER="192.168.0.101"
 SECONDARY_SERVER="192.168.0.102"
 VIRTUAL_IP="192.168.0.100"
 ​
 # 安装必要软件
 sudo yum install ipvsadm keepalived nginx -y
 ​
 # 禁用防火墙或配置规则
 sudo systemctl stop firewalld
 sudo systemctl disable firewalld
 ​
 # 编辑 /etc/sysctl.conf 文件
 sudo sed -i '/net.ipv4.ip_forward/s/#//g' /etc/sysctl.conf
 sudo sed -i '/net.ipv4.ip_nonlocal_bind/s/#//g' /etc/sysctl.conf
 sudo sed -i '/net.ipv4.conf.all.arp_ignore/s/#//g' /etc/sysctl.conf
 sudo sed -i '/net.ipv4.conf.all.arp_announce/s/#//g' /etc/sysctl.conf
 sudo sysctl -p
 ​
 # 配置 keepalived
 sudo cp /etc/keepalived/keepalived.conf /etc/keepalived/keepalived.conf.backup
 sudo cat <<EOF | sudo tee /etc/keepalived/keepalived.conf
 global_defs {
   router_id LVS_DEMO
 }
 ​
 vrrp_script check_nginx {
   script "killall -0 nginx"
   interval 2
   weight -30
 }
 ​
 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 {
     $VIRTUAL_IP
   }
   track_script {
     check_nginx
   }
 }
 EOF
 ​
 # 启动和启用 keepalived 服务
 sudo systemctl start keepalived
 sudo systemctl enable keepalived
 ​
 # 配置 Nginx
 sudo cp /etc/nginx/nginx.conf /etc/nginx/nginx.conf.backup
 sudo cat <<EOF | sudo tee /etc/nginx/nginx.conf
 http {
   upstream backend {
     server $PRIMARY_SERVER:80;
     server $SECONDARY_SERVER:80;
   }
 ​
   server {
     listen 80;
     location / {
       proxy_pass http://backend;
     }
   }
 }
 EOF
 ​
 # 启动和启用 Nginx 服务
 sudo systemctl start nginx
 sudo systemctl enable nginx

请根据您的实际网络设置和需求,将变量 PRIMARY_SERVERSECONDARY_SERVERVIRTUAL_IP 的值替换为正确的IP地址。

将脚本保存为 lvs_dr_setup.sh,然后在命令行中运行以下命令来执行脚本:

 bash lvs_dr_setup.sh

脚本将自动安装必要的软件,禁用防火墙,配置sysctl参数,设置Keepalived和Nginx的配置文件,并启动和启用相关的服务。


http://www.niftyadmin.cn/n/4992301.html

相关文章

大数据组件-Flume集群环境搭建

&#x1f947;&#x1f947;【大数据学习记录篇】-持续更新中~&#x1f947;&#x1f947; 个人主页&#xff1a;beixi 本文章收录于专栏&#xff08;点击传送&#xff09;&#xff1a;【大数据学习】 &#x1f493;&#x1f493;持续更新中&#xff0c;感谢各位前辈朋友们支持…

IDEA 设置提示信息

IDEA 设置提示信息 File->Settings->Editor->Code Completion 取消勾选 Math case

【线性代数/机器学习】矩阵的奇异值与奇异值分解(SVD)

文章目录 一、引言二、奇异值三、奇异值分解的定义四、如何进行奇异值分解参考资料 一、引言 我们知道&#xff0c;对于一个 n n n\times n nn的矩阵 A A A&#xff0c;如果 A A A有 n n n个线性无关的特征向量&#xff0c;则 A A A可以相似对角化&#xff0c;即存在可逆矩阵…

存量时代的面经

spring-series,感谢这个项目的作者,还有springboot_learn 这个项目 Spring, 说来惭愧,接触spring 已经接近十年了 通过这个项目,我把spring重写的学习了一遍 1,早上先debug 的一个项目的源码是 springboot_security 在这里插入代码片/****: Creating filter chain:org…

【爬虫】实验项目三:验证码处理与识别

目录 一、实验目的 二、实验预习提示 三、实验内容 实验要求 基本要求&#xff1a; 改进要求A&#xff1a; 改进要求B&#xff1a; 四、实验过程 基本要求 五、源码如下 六、资料 一、实验目的 部分网站可能会使用验证机制来阻止用户无效登录或者是验证用户不是用程…

解决小程序中textarea ios端样式不兼容的方法

问题描述 &#xff0c;今天在调试小程序的时候有个需求需要textarea与标题对其&#xff0c;微信开发工具和安卓系统都没有问题 但是ios系统textarea存在内边距。出现不兼容的情况 解决方法&#xff1a;我们看官网的textarea的属性 textarea | uni-app官网 disable-default-p…

Arco Design Pro 配置

垂直菜单更改为水平菜单 打开 src/config/setting.json{"theme": "light","colorWeak": false,"navbar": true,"menu": true,"topMenu": true,"hideMenu": false,"menuCollapse": false,&qu…

菜鸟教程《Python 3 教程》笔记(14):函数

菜鸟教程《Python 3 教程》笔记&#xff08;14&#xff09; 14 函数14.1 参数传递14.1.1 可更改(mutable)与不可更改(immutable)对象14.1.2 python 传不可变对象实例 14.2 参数14.2.1 必需参数14.2.2 关键字参数14.2.3 默认参数14.2.4 不定长参数 14.3 匿名函数14.4 强制位置参…