CentOS7.6 服务器负载均衡——LVS-DR实战案例

目录

1、前期环境准备

1.准备两台主机

[1. 设置主机名](#1. 设置主机名)

[2. 设置IP地址然后重启网卡](#2. 设置IP地址然后重启网卡)

[3. 关闭防火墙和selinux](#3. 关闭防火墙和selinux)

二、配置LVS服务器

[1. LVS准备VIP和路由](#1. LVS准备VIP和路由)

[2. 设置路由转发](#2. 设置路由转发)

[3. LVS设置负载均衡条目/规则](#3. LVS设置负载均衡条目/规则)

[1. 设置IPVSADM](#1. 设置IPVSADM)

[4. LVS让配置永久生效:](#4. LVS让配置永久生效:)

三、设置WEB集群

1.两个web服务器上部署web服务

[2. 给两个web服务器的lo网卡设置子网掩码为32位vip](#2. 给两个web服务器的lo网卡设置子网掩码为32位vip)

[3. 给两个web服务器设置内核参数](#3. 给两个web服务器设置内核参数)

[1. 忽略arp响应 ,不允许收](#1. 忽略arp响应 ,不允许收)

[2. 为了让vip发包出去,但允许发](#2. 为了让vip发包出去,但允许发)

四、客户端测试

1.在浏览器上搜索:192.168.200.123

[2. ipvsadm状态测试](#2. ipvsadm状态测试)


1、前期环境准备

1.准备三台主机

|----------------|--------|-------|------|
| IP地址 | 主机名 | 角色 | 内存大小 |
| 192.168.200.11 | LVS-DR | 负载均衡器 | 2G |
| 192.138.200.23 | web1 | 服务器1 | 2G |
| 192.168.200.34 | web1 | 服务器2 | 2G |

1. 设置主机名
bash 复制代码
hostnamectl set-hostname +主机名

su
2. 设置IP地址然后重启网卡
bash 复制代码
vim /etc/sysconfig/network-scripts/ifcfg-ens33

systemctl restart network
3. 关闭防火墙和selinux
bash 复制代码
systemctl stop firewalld
systemctl disable firewalld
 
 
setenforce 0
 
 
vim /etc/selinux/config 
 
注释加'#' SELINUX=enforcing
 
添加      SELINUX=disabled

二、配置LVS服务器

1. LVS准备VIP和路由
  • 添加VIP("VIP" 在网络和计算中通常指的是 "Virtual IP Address"(虚拟 IP 地址)。虚拟 IP 地址是一种用于网络负载均衡、高可用性和故障转移的技术。)
bash 复制代码
ifconfig ens33:0 192.168.200.123 broadcast 192.168.200.255 netmask 255.255.255.0 up
  • 命令解释:在 Linux 系统中使用 ifconfig 命令来配置一个虚拟网络接口(也称为别名接口或逻辑接口)的示例。具体来说,这个命令是为物理接口 ens33 添加一个别名接口 ens33:0,并为其配置 IP 地址、广播地址和子网掩码。
bash 复制代码
route add -host 192.168.200.123 dev ens33:0
  • 该命令将会把所有发往 IP 地址 192.168.200.123 的流量通过 ens33:0 接口发送。这通常用于指定主机的特定路由。
2. 设置路由转发
bash 复制代码
vi /etc/sysctl.conf

添加
net.ipv4.ip_forward = 1
net.ipv4.conf.all.send_redirects = 0
net.ipv4.conf.ens33.send_redirects = 0
net.ipv4.conf.default.send_redirects = 0
  • net.ipv4.ip_forward = 1
  • 开启路由功能
  • net.ipv4.conf.all.send_redirects = 0
  • #禁止转发重定向报文
  • net.ipv4.conf.ens33.send_redirects = 0
  • 禁止ens33转发重定向报文
  • net.ipv4.conf.default.send_redirects = 0
  • 禁止转发默认重定向报文
3. LVS设置负载均衡条目/规则
1. 设置IPVSADM

下载ipvsadm: 用于管理 IP 虚拟服务器。

bash 复制代码
yum install ipvsadm -y

启动ipvsadm服务

bash 复制代码
systemctl start ipvsadm

清理ipvs所有规则

bash 复制代码
ipvsadm -C

设置虚拟服务器,地址是192.168.200.123:80,规则轮寻

bash 复制代码
pvsadm -A -t 192.168.200.123:80 -s rr
  • -A: 表示添加一个新的虚拟服务(也就是一个新的 IPVS 规则)。
  • -t 192.168.200.123:80: 指定虚拟服务的 IP 地址和端口。在这里,192.168.200.123 是虚拟 IP 地址,80 是监听的端口。
  • -s rr: 指定负载均衡策略。rr 代表轮询(Round Robin)策略,这意味着请求会按照顺序轮流分配给后端的服务器
4. LVS让配置永久生效:
bash 复制代码
保存 IPVS 配置
ipvsadm-save > /etc/sysconfig/ipvsadm

设置ipvsadm服务自动启动
systemctl enable ipvsadm

三、设置WEB集群

1.两个web服务器上部署web服务

安装web服务

bash 复制代码
yum install nginx -y

修改主页内容

bash 复制代码
vim /usr/share/nginx/html/index.html

启动服务设置开机自启动:

bash 复制代码
systemctl start nginx

systemctl enable nginx
2. 给两个web服务器的lo网卡设置子网掩码为32位vip

web1:

bash 复制代码
ifconfig lo:0 192.168.200.123/32

web2:

bash 复制代码
ifconfig lo:0 192.168.200.123/32
3. 给两个web服务器设置内核参数
1. 忽略arp响应 ,不允许收,但为了让vip发包出去,允许发
bash 复制代码
echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore
2. 确保 ARP 请求被广播到所有网络接口
bash 复制代码
echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce

四、客户端测试

1.在浏览器上搜索:192.168.200.123
2. ipvsadm状态测试
bash 复制代码
ipvsadm -Lnc
相关推荐
Cloud_Air75414 分钟前
从零开始使用SSH链接目标主机(包括Github添加SSH验证,主机连接远程机SSH验证)
运维·ssh
李詹19 分钟前
Steam游戏服务器攻防全景解读——如何构建游戏级抗DDoS防御体系?
服务器·游戏·ddos
你熬夜了吗?22 分钟前
spring中使用netty-socketio部署到服务器(SSL、nginx转发)
服务器·websocket·spring·netty·ssl
joke_xiaoli1 小时前
tomcat Server 连接服务器 进展
java·服务器·tomcat
Hello.Reader1 小时前
基于 Nginx 的 WebSocket 反向代理实践
运维·websocket·nginx
北冥有鱼被烹1 小时前
【微知】/proc中如何查看Linux内核是否允许加载内核模块?(/proc/sys/kernel/modules_disabled)
linux·服务器
qq_273900232 小时前
CentOS系统防火墙服务介绍
linux·运维·centos
小余吃大鱼2 小时前
CentOS中在线安装Docker(超详细)
linux·docker·centos
程序员JerrySUN2 小时前
驱动开发硬核特训 · Day 19:字符设备驱动实战(控制 LED)
linux·驱动开发
小灰灰__2 小时前
Linux安装ffmpeg7.1操作说明
linux·运维·服务器