0

0

Linux下安装lvs和keeplived实现负载均衡

星夢妙者

星夢妙者

发布时间:2025-06-26 13:06:01

|

299人浏览过

|

来源于php中文网

原创

前言

在生产工作中,后端服务器并不可能永远都处于正常运行状态,若服务器发生宕机,为了不影响正在进行的业务以及给用户更好的体验,我们可以通过keepalived监控后台服务器运行情况,当有服务器发生故障时,会从把该服务器剔除出LVS转发策略;等到服务器恢复正常后,keepalived也会重新把该服务器加入LVS转发策略中。

Linux下安装lvs和keeplived实现负载均衡
系统介绍代码语言:javascript代码运行次数:0运行复制
<code class="javascript">虚拟VIP:192.168.1.231​ip地址:192.168.1.244  【mac地址:00:16:3E:98:07:E8 ,以下简称D1】​ip地址:192.168.1.233  【mac地址:00:16:3E:3B:60:AA,以下简称D1】​系统: centos6</code>
Linux下安装lvs和keeplived实现负载均衡
安装部署安装keepalived代码语言:javascript代码运行次数:0运行复制
<code class="javascript">D1,D2服务器都要安装keepalivedcd /data/software/rz 上传文件keepalived-1.2.13.tar.gz# tar -zvxf keepalived-1.2.13.tar.gz # cd keepalived-1.2.13# ./configure --sysconf=/data/conf/ --prefix=/data/apps/keepalived/ ​\# 如果报错!!! ​OpenSSL is not properly installed on your system. !!! ​则执行: ​# yum -y install openssl-devel</code>
代码语言:javascript代码运行次数:0运行复制
<code class="javascript">makemake install​安装完成ln -s /data/apps/keepalived/sbin/keepalived /sbin/keepalivedcp /home/data/conf/rc.d/init.d/keepalived  /etc/rc.d/init.d/cp /home/data/conf/sysconfig/keepalived /etc/sysconfig/mkdir /etc/keepalivedcp /home/data/conf/keepalived/keepalived.conf /data/conf/ln -s /data/conf/keepalived.conf  /etc/keepalived/keepalived.confrm -rf  /data/conf/keepalived /data/conf/rc.d /data/conf/sysconfig          echo "1" >/proc/sys/net/ipv4/ip_forward             # 开启路由功能</code>
安装ipvs

D1,D2服务器都要安装

检查kernel是否已经支持LVS的IPVS模块

代码语言:javascript代码运行次数:0运行复制
<code class="javascript">modprobe -l | grep ipvs</code>
Linux下安装lvs和keeplived实现负载均衡

如果有类似上面的输出则说明内核已经支持

安装ipvs

代码语言:javascript代码运行次数:0运行复制
<code class="javascript">yum -y install ipvsadm​ipvsadm --help  (看到参数信息则说明安装成功)</code>
Linux下安装lvs和keeplived实现负载均衡
防火墙规则代码语言:javascript代码运行次数:0运行复制
<code class="javascript">iptables -F -t mangle       # 清空mangle中的规则​iptables -t mangle -I PREROUTING -d 192.168.1.231 -p tcp -m tcp --dport 80 -m mac ! --mac-source 00:16:3E:3B:60:AA -j MARK --set-mark 1 【192.168.1.244服务器配置】​iptables -t mangle -I PREROUTING -d 192.168.1.231 -p tcp -m tcp --dport 80 -m mac ! --mac-source 00:16:3E:98:07:E8 -j MARK --set-mark 1 【192.168.1.233服务器配置】​ ​\# 目标ip地址是192.168.1.231并且目标端口为80的数据标记为1(排除另外一台lvs调度器 所以是排除另外一台调度器的mac地址 两台lvs的set-mark 值不同 并且规则中都排除对端的mac地址)​service iptables save</code>
Linux下安装lvs和keeplived实现负载均衡
配置keepalived代码语言:javascript代码运行次数:0运行复制
<code class="javascript">vi /etc/keepalived/keepalived.conf ​修改配置信息参考:​192.168.1.244的配置:​! Configuration File for keepalived​global_defs {    notification_email {        linmaogan@gmail.com # 故障通知邮件地址,可以多个地址        liuxing007xing@163.com    }    notification_email_from linmaogan@163.com # 故障发送人    smtp_server smtp.163.com # 由163.com发送邮件    smtp_connect_timeout 30​    #运行Keepalived服务器的一个标识    #发邮件时显示在邮件标题中的信息    router_id LVS_BACKUP  #BACKUP上修改为LVS_BACKUP,网上资料说这个值也需要修改,具体不详,之前我们线上的主备就一直是一样的 ^ ^还是修改一下吧!}​# 监测ipvsadm进程状态,每3秒执行一次vrrp_script chk_ipvsadm{    script "/data/conf/shell/chk_ipvsadm.sh"    interval 3    weight 3}​vrrp_instance VI_1 {    state MASTER    interface em1       【修改对应的网卡或eth0】    virtual_router_id 51    priority 100    advert_int 1    authentication {        auth_type PASS        auth_pass PZFKD2wSUJ3swnPN    }    virtual_ipaddress {        192.168.1.231    }}​virtual_server fwmark 80 {    delay_loop 6    lb_algo wlc    lb_kind DR    persistence_timeout 1    nat_mask 255.255.255.0   #网络掩码    persistence_timeout 50     protocol TCP    real_server 192.168.1.244 80 {        weight 5        TCP_CHECK {            connect_timeout 3            nb_get_retry 3            delay_before_retry 3            connect_port 80                #健康检查端口连接端口        }    }    real_server 192.168.1.233 80 {        weight 5        TCP_CHECK {            connect_timeout 3            nb_get_retry 3            delay_before_retry 3            connect_port 80                #健康检查端口连接端口        }    }}</code>

192.168.1.233的配置:

代码语言:javascript代码运行次数:0运行复制
<code class="javascript">! Configuration File for keepalived​global_defs {    notification_email {        linmaogan@gmail.com # 故障通知邮件地址,可以多个地址        liuxing007xing@163.com    }    notification_email_from linmaogan@163.com # 故障发送人    smtp_server smtp.163.com # 由163.com发送邮件    smtp_connect_timeout 30​    #运行Keepalived服务器的一个标识    #发邮件时显示在邮件标题中的信息    router_id LVS_BACKUP  #BACKUP上修改为LVS_BACKUP,网上资料说这个值也需要修改,具体不详,之前我们线上的主备就一直是一样的 ^ ^还是修改一下吧!}​# 监测ipvsadm进程状态,每3秒执行一次vrrp_script chk_ipvsadm{    script "/data/conf/shell/chk_ipvsadm.sh"    interval 3    weight 3}​vrrp_instance VI_1 {    state BACKUP    interface em1           【修改对应的网卡或eth0】    virtual_router_id 51    priority 80    advert_int 1    authentication {        auth_type PASS        auth_pass PZFKD2wSUJ3swnPN    }    virtual_ipaddress {        192.168.1.231    }}​virtual_server fwmark 80 {    delay_loop 6    lb_algo wlc    lb_kind DR    persistence_timeout 1    nat_mask 255.255.255.0   #网络掩码    persistence_timeout 50     protocol TCP    real_server 192.168.1.244 80 {        weight 5        TCP_CHECK {            connect_timeout 3            nb_get_retry 3            delay_before_retry 3            connect_port 80                #健康检查端口连接端口        }    }    real_server 192.168.1.233 80 {        weight 5        TCP_CHECK {            connect_timeout 3            nb_get_retry 3            delay_before_retry 3            connect_port 80                #健康检查端口连接端口        }    }}</code>

D2上配值和D1基本相同只是state MASTER改成state BACKUP,priority 100 改成 priority 80

Magic AI Avatars
Magic AI Avatars

神奇的AI头像,获得200多个由AI制作的自定义头像。

下载
配置ipvs代码语言:javascript代码运行次数:0运行复制
<code class="javascript">vi /data/conf/shell/chk_ipvsadm.sh​插入配置信息#!/bin/bash# 定时查看ipvsadm是否存在,如果不存在则启动ipvsadm,# 如果启动失败,则停止keepalivedstatus=$(ps aux|grep ipvsadm | grep -v grep | grep -v bash | wc -l)if [ "${status}" = "0" ]; then    service ipvsadm start    status2=$(ps aux|grep ipvsadm | grep -v grep | grep -v bash |wc -l)    if [ "${status2}" = "0"  ]; then    /etc/init.d/keepalived stop     fifi</code>
Real_Server上的配置

在LVS的DR模式下,用户的访问请求到达Real Server 后,是直接返回给用户的,不再经过前端的Director Server,因此,需要在每个Real server节点上增加虚拟的VIP地址,这样数据才能直接返回给用户

代码语言:javascript代码运行次数:0运行复制
<code class="javascript">chmod 777 /etc/rc.d/init.d/functions ​vi /etc/init.d/lvsrs#!/bin/bash#把以下内容保存成:lvsrs#并放置在/etc/init.d目录下#如果想启动LVS Server执行:/etc/init.d/lvsrs start#如果想停止LVS Server执行:/etc/init.d/lvsrs stopVIP=192.168.1.231  #虚拟IP,视具体情况而变. /etc/rc.d/init.d/functions   # 如果提示权限不够,那么先在命令行执行: chmod 777 /etc/rc.d/init.d/functions​case "$1" instart)    ifconfig lo:0 $VIP netmask 255.255.255.255 broadcast $VIP    /sbin/route add -host $VIP dev lo:0    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    sysctl -p >/dev/null 2>&1    echo "RealServer Start OK"    ;;stop)    ifconfig lo:0 down    route del $VIP >/dev/null 2>&1    echo "0" >/proc/sys/net/ipv4/conf/lo/arp_ignore    echo "0" >/proc/sys/net/ipv4/conf/lo/arp_announce    echo "0" >/proc/sys/net/ipv4/conf/all/arp_ignore    echo "0" >/proc/sys/net/ipv4/conf/all/arp_announce    echo "RealServer Stoped"    ;;    *)    echo "Usage: $0 {start|stop}"    exit 1esacexit 0</code>
代码语言:javascript代码运行次数:0运行复制
<code class="javascript">chmod 755 /etc/init.d/lvsrs​service lvsrs start</code>
管理lvs

以下D1,D2上都执行

1)启动lvs调度器

代码语言:javascript代码运行次数:0运行复制
<code class="javascript">service keepalived start                            # 开启路由功能echo "1" >/proc/sys/net/ipv4/ip_forward</code>

2) 关闭lvs调度器

代码语言:javascript代码运行次数:0运行复制
<code class="javascript">service keepalived stopecho "0" >/proc/sys/net/ipv4/ip_forward</code>
添加开机启动代码语言:javascript代码运行次数:0运行复制
<code class="javascript">chkconfig --add keepalivedchkconfig keepalived on​vi /etc/rc.d/rc.local/etc/init.d/lvsrs start  # 添加这一行到末尾</code>

ip a 查询

Linux下安装lvs和keeplived实现负载均衡

相关文章

keep
keep

Keep是一款健身安排,无论是想减肥塑形或增肌,还是寻找健身跑步瑜伽计步等训练计划,你可以随时随地选择课程进行训练!权威教练视频教学,健身干货自由分享!有需要的小伙伴快来保存下载体验吧!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1564

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

716

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

300

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

800

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

588

2023.07.06

linux查看文件夹大小
linux查看文件夹大小

Linux是一种自由和开放源码的类Unix操作系统,存在着许多不同的Linux版本,但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、视频游戏控制台、台式计算机、大型机和超级计算机。linux怎么查看文件夹大小呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

570

2023.07.20

linux查看ip命令
linux查看ip命令

本专题为大家提供linux查看ip命令相关文章内容,感兴趣的朋友可以免费下载体验试试。

314

2023.07.20

linux查看cpu使用率
linux查看cpu使用率

在linux的系统维护中,可能需要经常查看cpu使用率,分析系统整体的运行情况。本专题为大家带来了linux查看cpu使用率的相关文章,感兴趣的朋友千万不要错过了。

400

2023.07.25

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 10.5万人学习

Git 教程
Git 教程

共21课时 | 4.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号