keepalived 根据vip在主从环境中只启动一台服务的情况,自己编写脚本控制只启动一台服务

在高负载环境下,发现同一服务在两台服务器上重复处理数据,造成服务器压力过大。通过keepalived的VIP,实现根据VIP(redis-master)所在服务器决定服务运行位置,避免重复处理。编写bash脚本,检查VIP位置并控制服务启动或停止,以适应VIP漂移。当VIP在本地,服务未启动时,启动服务;反之,服务已启动则停止。提供GitHub源码链接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

环境情况!

服务器上运行着自己编写的一个服务,后来因为后面像一个服务器发现负载过高,调查问题时!

发现后端服务器处理了两次,这个服务把收到的数据存放到mq中,后面服务器处理时去mq中取!

从后面服务器处理的log中发现处理了两次相同的数据,导致后面的服务器负载高!关掉一台后,发现后面服务器负载减少了一半!

后面提出需求!因为keepalived是根据redis的master/slave主机做了vip!所以,可根据vip(redis-master)在哪台机器,自己的服务就在哪台服务器上运行!另一台则不运行!当vip发生飘移时!自己的服务也根据vip一起切换!

废话少说!直接上操作!

思路和解释在下面注解!

#!/bin/bash
#create user github:Xiaopei147
#create date 2022/2/28 08:00:00(CST)
#add to github date 2022/3/2 14:30(CST)
#####################################################
##⚠⚠⚠⚠⚠⚠⚠⚠The copyright of this script is mine##
##⚠⚠⚠⚠⚠⚠⚠⚠      这个脚本的版权是我              ##
#####################################################
ip_c=`/sbin/ip a |grep "scope global eth0" |wc -l`
status=`/sbin/service xxx status |grep 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值