linux基于 openEuler 构建 LVS-DR 群集--一、用命令行完成 二、使用脚本完成

embedded/2025/2/13 1:15:19/

目录

 一·、用命令行完成

        1、在nginx上(两台都是一样的配置)

       2、 在LVS上

                1.)绑定VIP  (与nginx上一致)      

                2)安装ipvsadm 

                3)配置LVS-DR 

        3、在CLINT上

                1)验证 (验证成功如下)

​编辑

        2)故障排查步骤:

二、使用脚本完成

      1、在nginx上(与一一样)

lvs%E4%B8%8A%E7%94%A8%E8%84%9A%E6%9C%AC%EF%BC%88%E5%89%8D%E6%8F%90%E5%AE%89%E8%A3%85%E5%A5%BDipvsadm%EF%BC%89-toc" name="tableOfContents" style="margin-left:80px">      2、在lvs上用脚本(前提安装好ipvsadm)

3、验证(与一一样)


IP地址如图:

 一·、用命令行完成

主要思路如下

        在nginx上:1、安装nginx   2、绑定VIP        3、arp抑制 

        在LVS上:1.、绑定VIP        2、安装ipvsadm        3、配置ipvsadm       

        在CLINT上 :1、验证

        1、在nginx上(两台都是一样的配置)

                1)安装nginx

#下载nginx
[root@openeuler ~]# yum install nginx -y#列出 Nginx 默认网页目录的内容
[root@openeuler ~]# ls /usr/share/nginx/html/
404.html  50x.html  index.html  nginx-logo.png#这个命令的目的是创建一个新的首页文件,内容包含当前主机的 IP 地址
[root@openeuler ~]# echo "web test page,ip is `hostname -I`." > /usr/share/nginx/html/#启用并启动 Nginx 服务
[root@openeuler ~]# systemctl enable --now nginx#访问本地 Nginx 服务
[root@openeuler ~]# curl localhost
web test page,ip is 192.168.131.19 .#出现这个代表访问成功

                2)绑定VIP

#网络需增加 VIP 的相关配置
[root@openeuler ~]# nmcli connection add type dummy ifname dummy2 ipv4.method manual ipv4.addresses 192.168.131.9/32

     

                3)arp的抑制

#完成网络配置后,修改相应的 arp 内核配置,具体命令如下
[root@openeuler ~]# cat >> /etc/sysctl.conf << EOF
> net.ipv4.conf.all.arp_ignore = 1
> net.ipv4.conf.all.arp_announce = 2
> net.ipv4.conf.dummy2.arp_ignore = 1
> net.ipv4.conf.dummy2.arp_announce = 2
> EOF
#配置完成后,使用命令 sysctl -p 使其生效
[root@openeuler ~]# sysctl -p | tail -4
net.ipv4.conf.all.arp_ignore = 1
net.ipv4.conf.all.arp_announce = 2
net.ipv4.conf.dummy2.arp_ignore = 1
net.ipv4.conf.dummy2.arp_announce = 2

        nginx上配置完成!

       2、 在LVS上

                1.)绑定VIP  (与nginx上一致)      
                2)安装ipvsadm 
[root@client ~]# yum install ipvsadm -y
                3)配置LVS-DR 

在没有配置前可以先查看(如下是为空的结果)

[root@client ~]# ipvsadm -L
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags-> RemoteAddress:Port           Forward Weight ActiveConn InActConn
#添加配置vip与nginx两个IP
[root@client ~]# ipvsadm -A -t 192.168.131.9:80 -s rr
[root@client ~]# ipvsadm -a -t 192.168.131.9:80 -r 192.168.131.19
[root@client ~]# ipvsadm -a -t 192.168.131.9:80 -r 192.168.131.20
#查看具体配置
[root@client ~]# ipvsadm -Ln

        3、在CLINT上

                1)验证 (验证成功如下)

        如果不成功如下

        2)故障排查步骤:

               1、 检查网络连通性

                2、检查防火墙:是否有防火墙规则阻止了 80 端口的流量,也可以直接关闭防火墙(四台操作机都要关防火墙)

                2、检查服务状态:确保nginx正在运行,并且正在监听 80 端口。

二、使用脚本完成

      1、在nginx上(与一一样)

lvs%E4%B8%8A%E7%94%A8%E8%84%9A%E6%9C%AC%EF%BC%88%E5%89%8D%E6%8F%90%E5%AE%89%E8%A3%85%E5%A5%BDipvsadm%EF%BC%89" name="%C2%A0%20%C2%A0%20%C2%A0%202%E3%80%81%E5%9C%A8lvs%E4%B8%8A%E7%94%A8%E8%84%9A%E6%9C%AC%EF%BC%88%E5%89%8D%E6%8F%90%E5%AE%89%E8%A3%85%E5%A5%BDipvsadm%EF%BC%89">      2、在lvs上用脚本(前提安装好ipvsadm)

在代码里的VIP\RIP1\RIP2改

#!/bin/sh
#
# Startup script handle the initialisation of LVS
# chkconfig: - 28 72
# description: Initialise the Linux Virtual Server for DR
#
### BEGIN INIT INFO
# Provides: ipvsadm
# Required-Start: $local_fs $network $named
# Required-Stop: $local_fs $remote_fs $network
# Short-Description: Initialise the Linux Virtual Server
# Description: The Linux Virtual Server is a highly scalable and highly
# available server built on a cluster of real servers, with the load
# balancer running on Linux.
# description: start LVS of DR
LOCK=/var/lock/ipvsadm.lock
VIP=192.168.131.9
RIP1=192.168.131.19
RIP2=192.168.131.20
DipName=ens33
. /etc/rc.d/init.d/functions
start() {
PID=`ipvsadm -Ln | grep ${VIP} | wc -l`
if [ $PID -gt 0 ];
then
echo "The LVS-DR Server is already running !"
else
#Set the Virtual IP Address
/sbin/ifconfig ${DipName}:10 $VIP broadcast $VIP netmask
255.255.255.255 up
/sbin/route add -host $VIP dev ${DipName}:10
#Clear IPVS Table
/sbin/ipvsadm -C
#Set Lvs
/sbin/ipvsadm -At $VIP:80 -s rr
/sbin/ipvsadm -at $VIP:80 -r $RIP1:80 -g
/sbin/ipvsadm -at $VIP:80 -r $RIP2:80 -g
/bin/touch $LOCK
#Run Lvs
echo "starting LVS-DR Server is ok !"
fi
}
stop() {
#clear Lvs and vip
/sbin/ipvsadm -C
/sbin/route del -host $VIP dev ${DipName}:10
/sbin/ifconfig ${DipName}:10 down >/dev/null
rm -rf $LOCK
echo "stopping LVS-DR server is ok !"
}
status() {
if [ -e $LOCK ];
then
echo "The LVS-DR Server is already running !"
else
echo "The LVS-DR Server is not running !"
fi
}
case "$1" in
start)
start
;;
stop)
stop
;;
restart)
stop
start
;;
status)
status
;;
*)
echo "Usage: $1 {start|stop|restart|status}"
exit 1
esac
exit 0

 


[root@openeuler ~]# vim /etc/init.d/lvs_dr
#赋予脚本可执行权限
[root@openeuler ~]# chmod +x /etc/init.d/lvs_dr
#将服务添加到 chkconfig 管理
[root@openeuler ~]# chkconfig --add lvs dr
#设置服务开机自启动
[root@openeuler ~]# chkconfig lvs_dr on
# 启动服务
[root@openeuler ~]# systemctl start lvs_dr
#查看服务状态
[root@openeuler ~]# systemctl status lvs_dr

3、验证(与一一样)


http://www.ppmy.cn/embedded/161737.html

相关文章

华为小艺助手接入DeepSeek,升级鸿蒙HarmonyOS NEXT即可体验

小艺助手接入DeepSeek的背景与意义 随着人工智能技术的不断发展&#xff0c;大模型成为推动智能交互升级的关键力量。DeepSeek在自然语言处理等领域具有出色的表现&#xff0c;其模型在语言理解、生成等方面展现出强大的能力。华为小艺助手接入DeepSeek&#xff0c;旨在借助其先…

LeetCode数学相关算法题(1)【C语言版】

2520. 统计能整除数字的位数 给你一个整数 num &#xff0c;返回 num 中能整除 num 的数位的数目。 如果满足 nums % val 0 &#xff0c;则认为整数 val 可以整除 nums 。 示例 1&#xff1a; 输入&#xff1a;num 7 输出&#xff1a;1 解释&#xff1a;7 被自己整除&…

黑马Redis详细笔记(实战篇---短信登录)

目录 一.短信登录 1.1 导入项目 1.2 Session 实现短信登录 1.3 集群的 Session 共享问题 1.4 基于 Redis 实现共享 Session 登录 一.短信登录 1.1 导入项目 数据库准备 -- 创建用户表 CREATE TABLE user (id BIGINT AUTO_INCREMENT PRIMARY KEY COMMENT 用户ID,phone …

自动驾驶---如何打造一款属于自己的自动驾驶系统

在笔者的专栏《自动驾驶Planning决策规划》中&#xff0c;主要讲解了行车的相关知识&#xff0c;从Routing&#xff0c;到Behavior Planning&#xff0c;再到Motion Planning&#xff0c;以及最后的Control&#xff0c;笔者都做了相关介绍&#xff0c;其中主要包括算法在量产上…

React进行路由跳转的方法汇总

在 React 中进行路由跳转有多种方法&#xff0c;具体取决于你使用的路由库和版本。以下是常见的路由跳转方法汇总&#xff0c;主要基于 react-router-dom 库。 1. 使用 useNavigate 钩子&#xff08;适用于 react-router-dom v6&#xff09; useNavigate 是 react-router-dom…

【蓝桥杯】大纲

1.算法类 1.1.枚举算法[1-3] 就是把所有可能的情况都一一列举出来,然后从中找到符合要求的答案。 比如从 1 到 100 找能被 5 整除的数,就一个一个试,这就是枚举。 1.2.排序算法 冒泡排序[2] 像气泡往上冒一样,每次比较相邻的两个数,如果顺序不对就交换,一趟一趟地…

Kafka 的消费offset原来是使用ZK管理,现在新版本是怎么管理的?

目录 基于 ZooKeeper 管理消费 offset 原理 缺点 新版本基于内部主题管理消费 offset 原理 优点 示例代码(Java) 在 Kafka 早期版本中,消费者的消费偏移量(offset)是存储在 ZooKeeper 中的,但由于 ZooKeeper 并不适合高频读写操作,从 Kafka 0.9 版本开始,消费偏…

DeepSeek之Api的使用(将DeepSeek的api集成到程序中)

一、DeepSeek API 的收费模式 前言&#xff1a;使用DeepSeek的api是收费的 免费版&#xff1a; 可能提供有限的免费额度&#xff08;如每月一定次数的 API 调用&#xff09;&#xff0c;适合个人开发者或小规模项目。 付费版&#xff1a; 超出免费额度后&#xff0c;可能需要按…