【LVS + Keepalived 群集】

news2024/11/15 21:45:42

目录

  • 一、Keepalived 案列分析
  • 二、Keeoalived 工具介绍
    • 1、keepalived 实现原理剖析
    • 2、VRRP (虚拟路由冗余协议)是指对路由器的一种备份解决方案
    • 3、keepalived 案例讲解
    • 4、keepalived 的安装与启动
    • 5、Keepalived及其工作原理
      • Keepalived体系主要模块及其作用
  • 三、LVS+Keepalived 高可用群集
    • 1.配置负载调度器(主、备相同)
      • (1)配置keeplived 主DR服务器
      • (2)配置keeplived 备DR服务器
      • (3)启动 ipvsadm 服务
      • (4)调整 proc 响应参数,关闭Linux 内核的重定向参数响应
    • 2.配置节点服务器(192.168.102.10,192.168.102.20)
      • 配置节点服务器1
      • 配置节点服务器2
    • 使用浏览器进行测试
  • 四、keepalived的抢占与非抢占模式
  • 五、nginx 的keepalived配置
    • 1、配置调度器1 (192.168.102.50)
    • 2、配置调度器2 (192.168.102.40)


一、Keepalived 案列分析

企业应用中,单台服务器承担应用存在单点故障的危险

单点故障一旦发生,企业服务将发送中断,造成极大的危害
在这里插入图片描述

二、Keeoalived 工具介绍

专门为LVS 和 HA 设计的一款健康检查工具

支持故障自动切换
支持节点的健康状态检查

1、keepalived 实现原理剖析

keepalived 采用VRRP热备份协议实现Linux 服务器的多机热备功能
在这里插入图片描述

2、VRRP (虚拟路由冗余协议)是指对路由器的一种备份解决方案

由多台路由器组成一个热备组,通过共用的虚拟IP地址对外提供服务

每个热备组内同时只有一台主路由器提供服务,其他路由器处于几余状态

若当前在线的路由器失效,则其他路由器会根据设置的优先级自动接替虚拟IP地址,继续提供服务

3、keepalived 案例讲解

双机热备的故障切换是由虚拟IP地址的飘逸来实现,使用于各种应用服务器

实现基于web 服务的双机热备

飘移地址:192.168.10.72
主,备服务器:192.168.10.73、192.168.10.74
提供的应用服务:web

在这里插入图片描述

4、keepalived 的安装与启动

在LVS 群集环境中应用时,也需要ipvsadm 管理工具

使用yum 进行安装 keepalived

启动keepalived 服务

5、Keepalived及其工作原理

Keepalived 是一个基于VRRP协议来实现的LVS服务高可用方案,可以解决静态路由出现的单点故障问题。

在一个LVS服务集群中通常有主服务器(MASTER)和备份服务器(BACKUP)两种角色的服务器,但是对外表现为一个虚拟IP(VIP),主服务器会发送VRRP通告信息给备份服务器,当备份服务器收不到VRRP消息的时候,即主服务器异常的时候,备份服务器就会接管虚拟IP,继续提供服务,从而保证了高可用性。

Keepalived体系主要模块及其作用

keepalived体系架构中主要有三个模块,分别是core、check和vrrp。

●core模块:为keepalived的核心,负责主进程的启动、维护及全局配置文件的加载和解析。

●vrrp模块:是来实现VRRP协议的。(调度器之间的健康检查和主备切换)

●check模块:负责健康检查,常见的方式有端口检查及URL检查。(节点服务器的健康检查)

三、LVS+Keepalived 高可用群集

主DR 服务器:192.168.102.50
备DR 服务器:192.168.102.40
Web 服务器1:192.168.102.10
Web 服务器2:192.168.102.20
vip:192.168.102.188
客户端:192.168.102.200

1.配置负载调度器(主、备相同)

关闭防火墙

systemctl stop firewalld.service
setenforce 0

安装服务

yum -y install ipvsadm keepalived

开启ipvsadm服务

modprobe ip_vs
cat /proc/net/ip_vs

(1)配置keeplived 主DR服务器

进入keepalived 目录,给里面的内容备份

cd /etc/keepalived/
cp keepalived.conf keepalived.conf.bak

进入配置文件里修改

vim keepalived.conf
global_defs {						#定义全局参数
--10行--修改,邮件服务指向本地
	smtp_server 127.0.0.1
--12行--修改,指定服务器(路由器)的名称,主备服务器名称须不同,主为LVS_01,备为LVS_02
	router_id LVS_01
--14行--注释掉,取消严格遵守VRRP协议功能,否则VIP无法被连接
	#vrrp_strict
}

vrrp_instance VI_1 {				#定义VRRP热备实例参数
--20行--修改,指定热备状态,主为MASTER,备为BACKUP
    state MASTER
--21行--修改,指定承载vip地址的物理接口
    interface ens33
--22行--修改,指定虚拟路由器的ID号,每个热备组保持一致	
    virtual_router_id 10
	#nopreempt		#如果设置非抢占模式,两个节点state必须为BACKUP,并加上配置 nopreempt
--23行--修改,指定优先级,数值越大优先级越高,这里设置主为100,备为90
    priority 100
    advert_int 1					#通告间隔秒数(心跳频率)
    authentication {				#定义认证信息,每个热备组保持一致
		auth_type PASS				#认证类型
--27行--修改,指定验证密码,主备服务器保持一致
        auth_pass abc123
    }
    virtual_ipaddress {				#指定群集vip地址
        192.168.102.188
    }
}
--36行--修改,指定虚拟服务器地址(VIP)、端口,定义虚拟服务器和Web服务器池参数
virtual_server 192.168.102.188 80 {
    delay_loop 6					#健康检查的间隔时间(秒)
    lb_algo rr						#指定调度算法,轮询(rr)
--39行--修改,指定群集工作模式,直接路由(DR)
    lb_kind DR
    persistence_timeout 0			#连接保持时间(秒)
    protocol TCP					#应用服务采用的是 TCP协议
--43行--修改,指定第一个Web节点的地址、端口
    real_server 192.168.102.10 80 {
        weight 1					#节点的权重
--45行--删除,添加以下健康检查方式		
        TCP_CHECK {
			connect_port 80			#添加检查的目标端口
			connect_timeout 3		#添加连接超时(秒)
			nb_get_retry 3			#添加重试次数
			delay_before_retry 3	#添加重试间隔
		}
	}

	real_server 192.168.102.20 80 {		#添加第二个 Web节点的地址、端口
        weight 1
        TCP_CHECK {
			connect_port 80
			connect_timeout 3
			nb_get_retry 3
			delay_before_retry 3
		}
	}
##删除后面多余的配置##
}

在这里插入图片描述

在这里插入图片描述

修改完后重新启动服务

systemctl start keepalived
systemctl enable keepalived.service

查看虚拟网卡 vip

ip addr	

查看到在主的上面增加了一个虚拟网卡 vip
在这里插入图片描述

(2)配置keeplived 备DR服务器

关闭防火墙

systemctl stop firewalld.service
setenforce 0

安装服务

yum -y install ipvsadm keepalived

开启ipvsadm服务

modprobe ip_vs
cat /proc/net/ip_vs

进入keepalived 目录,给里面的内容备份

cd /etc/keepalived/
cp keepalived.conf keepalived.conf.bak

进入配置文件里修改

vim keepalived.conf

在这里插入图片描述在这里插入图片描述

修改完后重新启动服务

systemctl start keepalived
systemctl enable keepalived.service

查看虚拟网卡 vip

ip addr	

在这里插入图片描述

(3)启动 ipvsadm 服务

192.168.102.50 主调度器

ipvsadm-save > /etc/sysconfig/ipvsadm
systemctl start ipvsadm
ipvsadm -ln
#如没有VIP 的分发策略,则重启 keepalived 服务,systemctl restart keepalived

在这里插入图片描述

192.168.102.40 备调度器

ipvsadm-save > /etc/sysconfig/ipvsadm
systemctl start ipvsadm
ipvsadm -ln

在这里插入图片描述

(4)调整 proc 响应参数,关闭Linux 内核的重定向参数响应

vim /etc/sysctl.conf

加入配置文件

net.ipv4.conf.all.send_redirects = 0
net.ipv4.conf.default.send_redirects = 0
net.ipv4.conf.ens33.send_redirects = 0

重新加载

sysctl -p

2.配置节点服务器(192.168.102.10,192.168.102.20)

配置节点服务器1

关闭防火墙

systemctl stop firewalld
setenforce 0

安装一个服务器

yum -y install httpd
systemctl start httpd

在节点服务器1 上写入网页内容

echo 'this is benet web!' > /var/www/html/index.html

在这里插入图片描述
创建一个虚拟网卡

cd /etc/sysconfig/network-scripts/
cp ifcfg-lo ifcfg-lo:0		
vim ifcfg-lo:0
DEVICE=lo:0
ONBOOT=yes
IPADDR=192.168.102.188
NETMASK=255.255.255.255

注意:子网掩码必须全为1

启动虚拟网卡,并添加路由,将发送给vip地址的包从虚拟网卡回环地址发送(将访问vip的数据限制在本地以免arp混乱)
单独启动网卡设置

ifup lo:0
ifconfig lo:0

添加到rc.local 开机自动加载上面的限制命令 (永久添加)

vim /etc/rc.d/rc.local
route add -host 192.168.102.188 dev lo:0

在这里插入图片描述

加入权限

chmod +x /etc/rc.d/rc.local

调整内核的 ARP 响应参数以阻止更新 VIP 的 MAC 地址,避免发生冲突

vim /etc/sysctl.conf
net.ipv4.conf.lo.arp_ignore = 1			#系统只响应目的IP为本地IP的ARP请求
net.ipv4.conf.lo.arp_announce = 2		#系统不使用IP包的源地址来设置ARP请求的源地址,而选择发送接口的IP地址
net.ipv4.conf.all.arp_ignore = 1
net.ipv4.conf.all.arp_announce = 2
net.ipv4.conf.lo.arp_ignore = 1
net.ipv4.conf.lo.arp_announce = 2
net.ipv4.conf.all.arp_ignore = 1
net.ipv4.conf.all.arp_announce = 2

刷新配置

sysctl -p

配置节点服务器2

关闭防火墙

systemctl stop firewalld
setenforce 0

安装一个服务器

yum -y install httpd
systemctl start httpd

在节点服务器2 上写入网页内容

echo 'this is dai web!' > /var/www/html/index.html

在这里插入图片描述
创建一个虚拟网卡

cd /etc/sysconfig/network-scripts/
cp ifcfg-lo ifcfg-lo:0		
vim ifcfg-lo:0
DEVICE=lo:0
ONBOOT=yes
IPADDR=192.168.102.188
NETMASK=255.255.255.255

注意:子网掩码必须全为1

启动虚拟网卡,并添加路由,将发送给vip地址的包从虚拟网卡回环地址发送(将访问vip的数据限制在本地以免arp混乱)
单独启动网卡设置

ifup lo:0
ifconfig lo:0

添加到rc.local 开机自动加载上面的限制命令 (永久添加)

vim /etc/rc.d/rc.local
route add -host 192.168.102.188 dev lo:0

在这里插入图片描述

加入权限

chmod +x /etc/rc.d/rc.local

调整内核的 ARP 响应参数以阻止更新 VIP 的 MAC 地址,避免发生冲突

vim /etc/sysctl.conf
net.ipv4.conf.lo.arp_ignore = 1			#系统只响应目的IP为本地IP的ARP请求
net.ipv4.conf.lo.arp_announce = 2		#系统不使用IP包的源地址来设置ARP请求的源地址,而选择发送接口的IP地址
net.ipv4.conf.all.arp_ignore = 1
net.ipv4.conf.all.arp_announce = 2
net.ipv4.conf.lo.arp_ignore = 1
net.ipv4.conf.lo.arp_announce = 2
net.ipv4.conf.all.arp_ignore = 1
net.ipv4.conf.all.arp_announce = 2

刷新配置

sysctl -p

使用浏览器进行测试

在客户端访问 http://192.168.102.188/
再在主服务器关闭 keepalived 服务后再测试, systemctl stop keepalived

在这里插入图片描述

Keepalived通过什么判断哪台主机为主服务器,通过什么方式配置浮动IP?

答案:
Keepalived首先做初始化先检查state状态,master为主服务器,backup为备服务器。
然后再对比所有服务器的priority,谁的优先级高谁是最终的主服务器。
优先级高的服务器会通过ip命令为自己的电脑配置一个提前定义好的浮动IP地址。

四、keepalived的抢占与非抢占模式

抢占模式即MASTER从故障中恢复后,会将VIP从BACKUP节点中抢占过来。非抢占模式即MASTER恢复后不抢占BACKUP升级为MASTER后的VIP
非抢占式俩节点state必须为bakcup,且必须配置nopreempt。
注意:这样配置后,我们要注意启动服务的顺序,优先启动的获取master权限,与优先级没有关系了。

五、nginx 的keepalived配置

1、配置调度器1 (192.168.102.50)

安装nginx

vim /etc/yum.repos.d/nginx.repo
[nginx-stable]
name=nginx stable repo
baseurl=http://nginx.org/packages/centos/7/$basearch/
gpgcheck=0
enabled=1
yum install -y nginx

进入nginx的配置文件里添加内容,实现4层代理

cd /etc/nginx
vim nginx.conf
stream{
    upstream backend{
         server 192.168.102.10:80;
         server 192.168.102.20:80;

    }
        server{
             listen 8080;
             proxy_pass backend;
         }
}

在这里插入图片描述

配置完后重新启动服务,并查看端口有没有打开
在这里插入图片描述

使用别的客户端主机访问 192.168.102.50 看有没有实现转发
在这里插入图片描述
在keepalived 的目录里写下一个脚本

#!/bin/bash
if !  killall -0 nginx
then
    systemctl stop keepalived
fi

给脚本加上权限

chmod +x nginx.sh 

进入 keepalived 的配置文件里修改

vim keepalived.conf
! Configuration File for keepalived

global_defs {
   notification_email {
     acassen@firewall.loc
     failover@firewall.loc
     sysadmin@firewall.loc
   }
   notification_email_from Alexandre.Cassen@firewall.loc
   smtp_server 127.0.0.1
   smtp_connect_timeout 30
   router_id LVS_01
   #vrrp_skip_check_adv_addr
   #vrrp_strict
   #vrrp_garp_interval 0
   #vrrp_gna_interval 0
}

vrrp_script chk_nginx {
      script "/etc/keepalived/nginx.sh"
      interval 2
      weight 2
}

vrrp_instance VI_1 {
    state MASTER
    interface ens33
    virtual_router_id 51
    priority 100
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
        192.168.102.188
    }
   track_script {
          chk_nginx
     }

}

2、配置调度器2 (192.168.102.40)

安装nginx

vim /etc/yum.repos.d/nginx.repo
[nginx-stable]
name=nginx stable repo
baseurl=http://nginx.org/packages/centos/7/$basearch/
gpgcheck=0
enabled=1
yum install -y nginx

进入nginx的配置文件里添加内容,实现4层代理

cd /etc/nginx
vim nginx.conf
stream{
    upstream backend{
         server 192.168.102.10:80;
         server 192.168.102.20:80;

    }
        server{
             listen 8080;
             proxy_pass backend;
         }
}

在这里插入图片描述

配置完后重新启动服务,并查看端口有没有打开
在这里插入图片描述

使用别的客户端主机访问 192.168.102.40 看有没有实现转发
在这里插入图片描述

在keepalived 的目录里写下一个脚本

#!/bin/bash
if !  killall -0 nginx
then
    systemctl stop keepalived
fi

给脚本加上权限

chmod +x nginx.sh 

进入nginx的配置文件里添加内容,实现4层代理

cd /etc/nginx
vim nginx.conf
stream{
    upstream backend{
         server 192.168.102.10:80;
         server 192.168.102.20:80;

    }
        server{
             listen 8080;
             proxy_pass backend;
         }
}

进入 keepalived 的配置文件里修改

vim keepalived.conf
! Configuration File for keepalived

global_defs {
   notification_email {
     acassen@firewall.loc
     failover@firewall.loc
     sysadmin@firewall.loc
   }
   notification_email_from Alexandre.Cassen@firewall.loc
   smtp_server 127.0.0.1
   smtp_connect_timeout 30
   router_id LVS_02
   #vrrp_skip_check_adv_addr
   #vrrp_strict
   #vrrp_garp_interval 0
   #vrrp_gna_interval 0
}

vrrp_script chk_nginx {
      script "/etc/keepalived/nginx.sh"
      interval 2
      weight 2

}

vrrp_instance VI_1 {
    state BACKUP
    interface ens33
    virtual_router_id 51
    priority 90
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
        192.168.102.188
    }
   track_script {
          chk_nginx
     }

}

使用客户机访问 192.168.102.188 看有没有通过脚本的模式来实现负载均衡
在这里插入图片描述

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

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

相关文章

SQL锁总结

一、概述 介绍 锁是计算机协调多个进程或线程并发访问某一资源的机制。在数据库中,除传统的计算资源(CPU、RAM、I/O)的争用以外,数据也是一种供许多用户共享的资源。如何保证数据并发访问的一致性、有效性是所有数据库必须解决的一个问题,锁…

springboot3嵌入式容器源码解析

问题分析 不同于使用springmvc,在我们使用springboot时无需配置tomcat就可以直接使用,这就说明springboot已经在我们启动项目时将tomcat配置好了,接下来我们就来看看springboot底层是怎么实现的。 源码解析 ServletWebServerFactoryAutoConfiguratio…

【Python爬虫】整站40万条房价数据并行抓取,可更换抓取城市

目录 前言一、获取索引一级位置:区域信息二级位置:板块信息三级位置:地铁信息(搜索地铁周边房源信息) 二、获取索引页最大页数三、抓取房源信息Tag四、分配任务,并行抓取五、将抓取结果存储到excel中&#…

go map源码探索(查找、插入、删除、扩容、遍历)

文章目录 概要一、Go map结构二、Go map初始化2.1、不带容量初始化2.2、带容量初始化 三、Go map查找四、Go map插入4.1、插入源码分析4.2、溢出桶申请策略 五、删除源码分析六、扩容与迁移源码分析6.1、扩容条件6.1.1、当前负载因子大于6.56.1.2、有过多的溢出桶 6.2、扩容6.3…

LVS+Keepalivedd

Keepalived 一、Keepalived及其工作原理二、实验非抢占模式的设置 三、脑裂现象四、Nginx高可用模式 一、Keepalived及其工作原理 keepalived是一个基于VRRP协议来实现的LVS服务高可用方案,可用解决静态路由出现的单点故障问题。 在一个LVS服务集群中通常有主服务器…

11.枚举和注解|Java学习笔记

文章目录 枚举 enumeration enum自定义实现枚举自定义类实现枚举总结 使用enum关键字实现枚举实现方法Enum类方法enum实现接口 注解注解的理解JDK的元Annotation(元注解) 枚举 enumeration enum 从一个需求引入: 要求创建季节(Season) 对象&…

matlab 使用预训练神经网络和SVM进行苹果分级(带图形界面)支持其他物品图片分级或者分类

目录 数据集: 实验代码:alexnet版 如果你的matlab不是正版,先看这里: 数据集结构: 训练代码: 训练结果: 图形界面: 界面展示: 其他: 输出结果: 实验…

代码规范

一 、代码规范 程序员写代码,不仅仅是实现功能 1. 名称 在Python开发过程中会创建文件夹/文件/变量等,这些在命名有一些潜规则(编写代码时也要注意pep8规范)。 文件夹,小写 & 小写下划线连接,例如&a…

jmeter 在linux服务器中执行性能测试、监听服务器资源指标

jmeter监控服务器资源 资源准备jmeter安装(Windows 版)jmeter安装(linux 版)ServerAgent安装(linux 版)配置脚本并执行测试 资源准备 下载apache-jmeter-5.5文件;下载ServerAgent-2.2.3文件; jmeter安装&…

ZooKeeper的集群部署和启动与关闭

ZooKeeper是一个分布式应用程序协调服务。一个ZooKeeper集群可以存在多个Follower和Observer服务器,但只允许存在一台Leader服务器。如果Leader服务器宕机,那么ZooKeeper集群的其它服务器会投票选举出一个新的Leader服务器,为防止投票数不过半…

2023最新社交圈子即时聊天通信小程序+前端UNIAPP

🎈 限时活动领体验会员:可下载程序网创项目短视频素材 🎈 🎉 有需要的朋友记得关赞评,阅读文章底部来交流!!! 🎉 ✨ 源码介绍 2023最新多端社交圈子系统源码 | 陌生人社交…

[openeuler]Yocto embedded 联合sig例会 (2022-12-15)

Yocto & embedded 联合sig例会 (2022-12-15)_哔哩哔哩_bilibili

【C/C++】详解 函数重载和应用

创作不易&#xff0c;本篇文章如果帮助到了你&#xff0c;还请点赞 关注支持一下♡>&#x16966;<)!! 主页专栏有更多知识&#xff0c;如有疑问欢迎大家指正讨论&#xff0c;共同进步&#xff01; &#x1f525;c系列专栏&#xff1a;C/C零基础到精通 &#x1f525; 给大…

【零基础学JS - 11 】javaScript中的if..else表达式

&#x1f468;‍&#x1f4bb; 作者简介&#xff1a;程序员半夏 , 一名全栈程序员&#xff0c;擅长使用各种编程语言和框架&#xff0c;如JavaScript、React、Node.js、Java、Python、Django、MySQL等.专注于大前端与后端的硬核干货分享,同时是一个随缘更新的UP主. 你可以在各个…

[操作系统]4.文件管理

因为复习时间来不及了 还是老规矩,知识点覆盖不完全,具体内容请参考黑书,知识脉络来自王道操作系统 关于文件操作系统 1.文件系统基础 (1)文件的定义 文件时操作系统中的重要概念,是以计算机硬盘为基础载体存储在假期上的信息的集合 (2)文件的属性 文件的属性可以理解为文…

json-server 详解

这几天在写react的前端项目,想着后端接口没有,在网上也找不到比较合适的接口,所以在github和npm上翻了许久关于前端简单生成后端接口的工具,终于被找到了这个神仙工具json-server JSON-Server 是一个 Node 模块&#xff0c;运行 Express 服务器&#xff0c;你可以指定一个 jso…

CENTOS上的网络安全工具(二十四)Windows下的Hadoop+Spark编程环境构建

前面我们搭建了hadoop集群&#xff0c;spark集群&#xff0c;也利用容器构建了spark的编程环境。但是一般来说&#xff0c;就并行计算程序的开发&#xff0c;一刚开始一般是在单机上的&#xff0c;比如hadoop的single node。但是老师弄个容器或虚拟机用vscode远程访问式开发&am…

APM代码阅读(一):串口驱动

文章目录 前言一、AP_RangeFinder_TeraRanger_Serial.h二、AP_RangeFinder_TeraRanger_Serial.cpp三、AP_RangeFinder.cppinitdetect_instance_add_backendupdate 四、 AP_RangeFinder_Backend_Serial.cpp 前言 APM 4.2.3 以测距传感器的串口驱动为例进行阅读 其他的传感驱动都…

【Applied Algebra】扩域(Galois域)上的乘加法表构造

【Applied Algebra】扩域(Galois域)上的乘法表构造 在之前的文章里,我们讨论了扩域上(Galois域)的计算及其实现,但是侧重的是扩域中元素之间运算的细节实现,而如果想描述整个域的结构,就需要构造乘法表和加法表;实现仍然是基于c和符号计算库GiNaC; 运算表及其设计 考虑 F p n …

Zookeeper 基础知识汇总

一、zookeeper 概述 中文教程&#xff1a;https://www.docs4dev.com/docs/zh/zookeeper/r3.5.6/reference/zookeeperOver.html 1.1 概述 ZooKeeper 是⼀种分布式协调服务&#xff0c;⽤于管理⼤型主机。在分布式环境中协调和管理服务是 ⼀个复杂的过程。ZooKeeper 通过其简单的…