LVS 、DR模式

news2025/1/11 10:08:58

lvs

--环境

主机名IP地址功能
web1192.168.1.17

rs

web2192.168.1.18realserve
nat

内:192.168.1.16

外:192.168.1.102

directorserver,ntp
dns192.168.1.12dns

--web1、web2

 yum -y install nginx
 echo "xx" > /usr/share/nginx/html/index.html

操作相同,然后分别在浏览器访问各自的IP地址,都能看到自己写的内容

--nat

要配置两个网卡和两个IP地址,分别对内和对外(在VMware添加网络适配器)

内网:192.168.1.16

外网:192.168.1.102

--dns

配置dns服务

yum -y install bind

修改配置文件

vim /etc/named.conf

vim /etc/named.rfc1912.zones

在最后添加,

然后,

#cd /var/named/
#ls
#ll
#cp -p named.localhost xixi.zone
#vim xixi.zone 

最后检查文件并且启动服务

#named-checkconf /etc/named.conf
#named-checkconf /etc/named.rfc1912.zones
#systemctl start named
#systemctl enable named
#systemctl stop firewalld

--客户端

将配置dns服务的IP重定向到/etc/resolve

#echo "nameserver 192.168.1.12" > /etc/resolv
#crontab -e
30 3 * * * /usr/sbin/ntpdate 192.168.1.11

域名ping通即可

--nat

设置时间同步服务器

#yum -y install ntpdate
#crontab -e
* 2 * * * /usr/sbin/ntpdate cn.ntp.org.cn
#systemctl stop firewalld
#systemctl start ntpdate.service
#systemctl enable ntpdate.service

-- 对dns、web1、web2设置时间同步

使用crontab -e 命令,写入

30 3 * * * /usr/sbin/ntpdate 192.168.1.11 (这是时间同步服务器的IP地址

--nat

先下载ipvsadm

#yum -y install ipvsadm.x86_64

#配置规则

#查看所有规则
#如果已经配置好规则,重启之后也就没有了

ipvsadm -A -t 192.168.1.16:80 -s rr
ipvsadm -Ln

ens36网卡

#vim /etc/sysconfig/network-scripts/ifcfg-ens36

#cp /etc/sysconfig/network-scripts/ifcfg-ens33 /etc/sysconfig/network-scripts/ifcfg-ens36
#ipvsadm -a -t 192.168.1.102:80 -r 192.168.1.17:80 -m
#ipvsadm -a -t 192.168.1.102:80 -r 192.168.1.18:80 -m
#ipvsadm -Ln

然后浏览器访问外网地址(访问不到正常)

--web1和web2

临时修改网关,相同操作

#route del default
#route add default gw 192.168.1.16(内网IP)


 

核心  内核中的ipvs  ipvsadm

配置vip网卡

1、在编辑虚拟网络中创建桥接模式的网卡,并且桥接到有网的适配器上

2、在VMware的虚拟主机资源管理器找到虚拟主机,右键菜单,设置

3、添加新的网卡,自定义为刚才创建的桥接模式网卡

4、此时在虚拟主机中使用ifconfig无法找到新的网卡

5、ip a 能够查看到新的ens36网卡,没有路由

6、编辑网卡设置

7、重启network服务

--nat

ip转发

[root@NAT ~]# vim /etc/sysctl.conf
[root@NAT ~]# sysctl -p
net.ipv4.ip_forward = 1

在文件里添加这句话

DR模式

1、性能更优,回路不再经过ds

2、ds和调度主机(rs)为了保证用户的响应,都要求配置统一的vip

3、由于rs是直接响应client,网关一定不能设置为 ds 的dip

4、对rs的vip进行一致,让ds的vip接收请求,rs的vip不接受请求

--web1上挂载一个vip

# ifconfig lo:0 192.168.1.102 broadcast 192.168.1.102 netmask 255.255.255.255 up

# route add -host 192.168.1.102 dev ens33:0

--设置规范
# 安装ipvsadm
yum -y install ipvsadm

# 清空规则
ipvsadm -C

# 设置规则
ipvsadm -A -t 192.168.1.102:80 -s rr
ipvsadm -a -t 192.168.1.102:80 -r 192.168.1.17 -g
ipvsadm -a -t 192.168.1.10280 -r 192.168.1.18 -g

#rs不再需要指定端口,dr不支持端口映射,vip上是80端口,最终就是80端口

设置rs主机

1、在lo接口上绑定vip

[root@f ~]# ifconfig lo:0 192.168.1.102 broadcast 192.168.1.102 netmask 255.255.255.255 up

2、设置主机路由

[root@f ~]# route add -host 192.168.1.102 dev lo:0

3、抑制rs的接受请求

echo 1 > /proc/sys/net/ipv4/conf/lo/arp_ignore
echo 2 > /proc/sys/net/ipv4/conf/lo/arp_announce
echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore
echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce

4、生成脚本,对web2使用

[root@f ~]# scp arp.sh root@192.168.1.18:~

查看数据

[root@NAT ~]# ipvsadm -Ln
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  192.168.1.16:80 rr
TCP  192.168.1.102:80 rr
  -> 192.168.1.17:80              Masq    1      0          0         
  -> 192.168.1.18:80              Masq    1      0          0

dr模式的脚本

ds

#!/bin/bash
#在ens33上挂载一个ip地址
read -p "vip:" vip
read -p "mac:" mac
read -p "num" num
ifconfig $mac:$num $vip broadcast $vip netmask
255.255.255.255
# 主机路由
route add -host $vip dev $mac:$num
rs脚本
练习:对mysql的服务进行负载均衡
#安装ipvsadm
yum list installed|grep ipvsadm
if [ $? -ne 0 ] ; then
yum -y install ipvsadm
fi
#配置规则(不需要设置ip_forword)
ipvsadm -C
read -p "rule:" rule
read -p "port:" port
ipvsadm -A -t $vip:$port -s $rule
read -p "rip1:" rip1
ipvsadm -a -t $vip:$port -r $rip1 -g
read -p "rip2:" rip2
ipvsadm -a -t $vip:$port -r $rip2 -g

rs

#!/bin/bash
#在ens33上挂载一个ip地址
read -p "vip:" vip
read -p "mac:" mac
read -p "num" num
ifconfig $mac:$num $vip broadcast $vip netmask
255.255.255.255
# 主机路由
route add -host $vip dev $mac:$num
echo 1 > /proc/sys/net/ipv4/conf/lo/arp_ignore
echo 2 > /proc/sys/net/ipv4/conf/lo/arp_announce
echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore
echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2035685.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

系统编程 day10 进程2

进程创建之后: 1.任务-----子进程与父进程干的活差不多 2.父进程创建出子进程之后,子进程做的与父进程完全不同 shell程序-----bash----- 以上为进程运行的过程中,典型的两种应用场景 能够改变子进程的执行效果的函数是exec函数族 l和v&a…

【2024】k8s集群 图文详细 部署安装使用(两万字)

目录💻 一、前言二、下载依赖配置环境1、配置系统环境1.1、配置桥接网络1.1.1、parallels desktop配置1.1.2、VMware配置 1.2、配置root用户登陆 2、环境配置安装下载2.1、安装ipset和ipvsadm2.2、关闭SWAP分区 3、配置Containerd容器3.1、下载安装Containerd3.2、创…

数据结构之线性表(单链表的实现)

目录 一、单链表的原理 二、单链表的实现 1.单链表的定义 2.单链表的初始化 3.清空单链表 4.单链表是否为空 5.单链表的长度 6.获取指定位置 i 的元素 7.获取指定元素 e 的位置 8.向链表中插入指定位置的元素 9.向链表中删除指定位置的元素 10.遍历链表中的元素 …

zdppy+vue3+onlyoffice开发文档管理系统实战 20240813登录功能中Python生成验证码校验的研究

遗留的问题 1、登录功能 5、设计登录的接口 6、前后端联调,实现登录功能 7、要记录登录的Token和用户名,跳转到首页 2、注册功能 3、用户管理 4、角色管理 5、权限管理 6、分享功能 tb_user拆成基本信息和详细信息两张表。 6、前后端联调&#xff0c…

设计模式-标识映射(Identity Map)

概念 通过在映射中保存每个已经加载的对象,确保每个对象只加载一次。当要访问对象的时候,通过映射来查找他们。 从数据库加载对象时,对象与其映射的一致性、重复加载,这些都是需要得到保证的。 标识映射记录在一个业务事务中从数…

2024年中国AI大模型场景应用趋势解读

引言 >> 近年来,随着人工智能技术的飞速发展,AI大模型逐渐成为推动各行业数字化转型的重要驱动力。本文从行业现状、应用痛点、发展趋势以及投资机会等方面进行详细解读,探讨AI大模型在未来的广泛应用前景。 一、AI大模型行业应用现状…

【LLM大模型】Llama3.1 部署本地知识库应用

一. 环境介绍 高性能应用服务 HAI 拥有丰富的预装应用,可以将开源社区的前沿模型快速转化为您专有的部署实践,一键拉起,即开即用。现已支持在HAI购买页的社区应用中,找到Llama 3.1等应用的入口,简单选型后&#xff0c…

【MySQL 05】数据类型

🌈 一、数据类型的作用 如果向 MySQL 特定的类型中插入不合法的数据,MySQL 一般会将本次操作直接拦截。反过来讲,能被成功插入到 MySQL 中的数据一定合法。在 MySQL 中,数据类型本身也是一种约束,这种约束约束的是使用…

一篇文章教会你如何使用Haproxy,内含大量实战案例

1. Haproxy 介绍 HAProxy是法国开发者 威利塔罗(Willy Tarreau) 使用C语言编写的自由及开放源代码软件,是一款具备高并发(万级以上)、高性能的TCP和HTTP应用程序代理. HAProxy运行在当前的硬件上,可以支持…

Ubuntu20源码安装Moveit 与 OMPL

文章目录 一、源码安装OMPL1.1 先检查是否安装二进制ompl1.2 若已经提前安装二进制,需要先行卸载1.3 OMPL官网安装教程 一、源码安装OMPL 1.1 先检查是否安装二进制ompl //进入到如下目录下 cd /opt/ros/noetic/// 查找 find ./ -name "libompl*" find .…

Linux用户ID和组ID

在 Linux 系统中,用户和组 ID 用于识别进程和文件的访问权限。每个进程都有与之关联的实际用户 ID、实际组 ID、有效用户 ID、有效组 ID 以及附属组 ID。 实际用户 ID (Real User ID, UID) 定义:实际用户 ID 是启动进程的用户的 ID。作用:标…

文件中找TopK问题 的详细讲解

一:问题: 从一个包含10000整数的文件中找出最大的前10个数。 二:方法: 1:先直接拿文件的前10个数,建造一个小堆 2:再依次读取文件中,剩下的数,比堆顶大,则…

【MATLAB源码-第246期】基于matlab的秃鹰搜索优化算法(BES)机器人栅格路径规划,输出做短路径图和适应度曲线

操作环境: MATLAB 2022a 1、算法描述 秃鹰搜索优化算法(Bald Eagle Search, BES)是一种新颖的群体智能优化算法,受自然界中秃鹰猎食行为的启发而设计。与其他群体智能算法类似,BES试图通过模拟自然界的某些行为来解…

SSM药房管理系统---附源码18275

目录 摘要 1 绪论 1.1 研究目的意义 1.2国内外研究现状 2 药房管理系统分析 2.1 可行性分析 2.1.1 技术可行性分析 2.1.2经济可行性分析 2.1.3社会可行性分析 2.1.4操作可行性分析 2.2 系统流程分析 2.2.1数据新增流程 2.2.2数据删除流程 2.3 药房管理系统 功能分…

idea过滤器 过滤所有页面除了登录页面 !(包括白名单简洁概括)

1、创建过滤器包&#xff0c;创建LoginFilter类 2.在LoginFilter类中写过滤代码 //白名单List<String> whitelist Arrays.asList("/login.jsp");//用来存放配置文件中Action节点的属性List<Action> actionList new ArrayList<>(); public void …

这些坑都没有踩过,还敢说你做过自动化测试?

在执行冒烟测试、回归测试或多浏览器兼容性测试时&#xff0c;利用web自动化测试可以显著节省人力成本&#xff0c;因此web自动化测试的价值非常大。然而&#xff0c;任何从事过web自动化测试的人都会有这样的体会:写自动化代码相对简单&#xff0c;但维护的成本却非常高。一日…

除了 EcoVadis 审核,企业还需要应对哪些可持续发展方面的挑战?

除了 EcoVadis 审核&#xff0c;企业在可持续发展方面还可能面临以下挑战&#xff1a; 对 ESG 的认识和理解不足&#xff1a;企业的领导者和各层级员工可能对 ESG&#xff08;环境、社会治理&#xff09;的内涵、要求和重要性缺乏清晰认知&#xff0c;这会影响企业在日常运营中…

Redis的基本数据结构整理以及实战运用案例

目录 一、背景介绍 二、Redis数据结构介绍 1、String(字符串) &#xff08;1&#xff09;缓存不常变化的信息&#xff0c;如用户信息、地址信息、配置信息等 &#xff08;2&#xff09;分布式锁的使用 &#xff08;3&#xff09;原子递增递减&#xff0c;可以做一些简单的…

重启人生计划-拒绝内耗

&#x1f973;&#x1f973;&#x1f973; 茫茫人海千千万万&#xff0c;感谢这一刻你看到了我的文章&#xff0c;感谢观赏&#xff0c;大家好呀&#xff0c;我是最爱吃鱼罐头&#xff0c;大家可以叫鱼罐头呦~&#x1f973;&#x1f973;&#x1f973; 如果你觉得这个【重启人生…

算法——动态规划:完全背包问题

文章目录 一、问题描述二、解决方案1. DP 状态的设计2. 状态转移方程3. 算法复杂度4. 举例5. 实现6. 滚动数组实现 三、总结 一、问题描述 问题的抽象&#xff1a;给定 n n n 种物品和一个背包&#xff0c;第 i i i 种物品的体积为 c i c_i ci​&#xff0c;价值为 w i w_…