公司两台文件服务器要做高可用,避免单点故障,故采用keepalived实现,其中一台宕机,依靠另外一台继续提供服务,并且邮件通知服务状态。

1.keepalived介绍

  Keepalived是一个基于VRRP协议来实现的服务高可用方案,可以利用其来避免IP单点故障,类似的工具还有heartbeat、corosync、pacemaker。但是它一般不会单独出现,而是与其它负载均衡技术(如lvs、haproxy、nginx)一起工作来达到集群的高可用。

keepalived实现原理是以VRRP协议为实现基础的,VRRP全称Virtual Router Redundancy Protocol,即虚拟路由冗协议。 虚拟路由冗余协议,可以认为是实现路由器高可用的协议,即将N台提供相同功能的路由器组成一个虚拟路由器组,这个组里面有一个master和多个backup,master上面有一个对外提供服务的vip(该路由器所在局域网内其他机器的默认路由为该vip),master会发组播,组播地址:224.0.0.18,当backup收不到vrrp包时就认为master出问题了,这时就需要根据VRRP的优先级(0-255)从backup中选举出一个master。这样的话就可以保证路由器的高可用了。

keepalived主要有三个模块,分别是core、checkers和vrrp。core模块为keepalived的核心,负责主进程的启动、维护以及全局配置文件的加载和解析。checkers负责健康检查,包括常见的各种检查方式(tcp、http、ssl)。vrrp模块是来实现VRRP协议实现的。

2.vrrp的优势

  冗余:可以使用多个路由器设备作为LAN客户端的默认网关,大大降低了默认网关成为单点故障的可能性;
  负载共享:允许来自LAN客户端的流量由多个路由器设备所共享;
  多VRRP组:在一个路由器物理接口上可配置多达255个VRRP组;
  多IP地址:基于接口别名在同一个物理接口上配置多个IP地址,从而支持在同一个物理接口上接入多个子网;
  抢占:在master故障时允许优先级更高的backup成为master;
  通告协议:使用IANA所指定的组播地址224.0.0.18进行VRRP通告;
  VRRP追踪:基于接口状态来改变其VRRP优先级来确定最佳的VRRP路由器成为master;

3.Keepalived+Nginx

  环境:Openstack 虚拟机,这里使用unicast单播实现master/slave之间的心跳信号通讯。

  node1:192.168.242.133

  node2:192.168.242.130

  VIP:192.168.242.50

3.1安装keepalived:

vim /etc/ansible/hosts[nginx]192.168.242.133192.168.242.130
#ansible all -m yun -a "name=keepalived state=present"

3.2配置文件和服务启动脚本

配置文件:/etc/keepalive/keepalive.conf
服务脚本:/etc/rc.d/init.d/keepalive

3.2 Nginx和RabbitMQ检测脚本

   该脚本会检测ngnix的运行状态,根据其脚本返回状态码,判断服务在线状态,如果检测服务失败则降低其优先级,准备让其它机器接管VIP。

#!/bin/bash
count=`netstat -ntlp | grep "\<5672\>" | wc -l`
killall -0 nginx &> /dev/null
[ $? -eq 0 ] && [ $count -gt 0 ] && exit 0 || exit 1

3.2 keepalived notify脚本

  

#!/bin/bash
# Author: DevOps

vip=172.50.0.50
contact='xxxx@163.com'notify() {mailsubject="`hostname` to be $1: $vip floating"mailbody="`date '+%F %H:%M:%S'`: vrrp transition, `hostname` changed to be $1"echo $mailbody | mail -s "$mailsubject" $contact
}case "$1" inmaster)notify masterexit 0;;backup)notify backupexit 0;;fault)notify faultexit 0;;*)echo 'Usage: `basename $0` {master|backup|fault}'exit 1;;
esac

3.3 keepalived配置文件

  

! Configuration File for keepalivedglobal_defs {                         ##全局定义段notification_email {               ##通知机制,收件人xx@xx.com}notification_email_from devops@devops.com     ####发件人smtp_server 192.168.x.x                       ##发件服务器smtp_connect_timeout 30                       ##服务器连接超时时间router_id LVS_DEVEL                           ##路由器标志
}vrrp_script chk_nginx {                          ##定义检测脚本名script "/etc/keepalived/check_nginx_rabbitmq.sh"         ##检测脚本执行状态 interval 1                                   ##检测脚本状态间隔时间weight -2                                     ##权重值,脚本检测失败,优先级会减去2。
}
vrrp_instance VI_1 {                             ##VRRP实例,定义一个虚拟路由器  VI_1虚拟路由器名state MASTER                                 ##设置改节点为MASTER节点interface eth0                               ##通告,选举网络接口virtual_router_id 51                         ##虚拟路由器ID,双方必须一致priority 100                                 ##优先级  0-255#nopreempt                                   ##非抢占模式unicast_src_ip 192.168.64.133                ##使用单播发送心跳信号,本地作为单播源IPunicast_peer {                               ##单播目的IP,另外一台节点192.168.64.130}advert_int 1                            ##通告时间间隔authentication {                        ##心跳认证方式,明文,SHA,不认证三种auth_type PASSauth_pass 1111}virtual_ipaddress {                       ##VRRP VIP地址192.168.64.50 }track_script {                            ##探测脚本执行chk_nginx }notify_master "/etc/keepalived/notify.sh master"    ##定义在状态进行转换时的通知脚本。notify_backup "/etc/keepalived/notify.sh backup"notify_fault "/etc/keepalived/notify.sh fault"
}

  在其BACKUP上,只需要改变 :

    state MASTER :state BACKUP

    priority 100 : priority 99

    unicast_src_ip 192.168.64.130   

    unicast_peer { 192.168.64.133 } 即可。

重启keepalived服务:

  

ansible nginx -m shell -a "service keepalived restart"

  

转载于:https://www.cnblogs.com/wangyichen/p/4917241.html

Rabbitmq+Nginx+keepalived高可用热备相关推荐

  1. 构建MFS+Keepalived双机高可用热备方案`

    一.简介 MooseFS(即Moose File System,简称MFS)是一个具有容错性的网络分布式文件系统,它将数据分散存放在多个物理服务器或单独磁盘或分区上,确保一份数据有多个备份副本,对于访 ...

  2. Nginx+Keepalived实现双机热备

    这篇文章主要介绍了Nginx+Keepalived实现双机热备,小编觉得挺不错的,现在分享给大家,也给大家做个参考.一起跟随小编过来看看吧 一.Keepalived Keepalived是保证集群高可 ...

  3. Nginx+Keepalived高可用集群应用实践

    Nginx+Keepalived高可用集群应用实践 1.Keepalived高可用软件 1.1 Keepalived服务的三个重要功能 1.1.1管理LVS负载均衡软件 早期的LVS软件,需要通过命令 ...

  4. keep老是显示服务器开小差,nginx+keepalived高可用服务器宕机解决方案

    原标题:nginx+keepalived高可用服务器宕机解决方案 1.基本服务器宕机的主从切换配置 两台nginx服务器,分别安装keepalived,配置/etc/keepalived/keepal ...

  5. Nginx+keepalived高可用配置实战

    1.整体架构图如下 2.环境准备 今天所配置的是keepalived+nginx 的负载均衡 下载keepalived软件 [root@LB01 tools]# wget http://www.kee ...

  6. nginx+keepalived高可用web架构

    nginx+keepalived高可用web架构 1.下载所需的软件包 (1).keepalived软件包keepalived-1.1.20.tar.gz (2).nginx软件包nginx-1.1. ...

  7. (七)centos7案例实战——nginx+keepalived高可用服务器集群搭建

    前言 本节内容延续之前的内容,往期博客已经介绍了如何安装nginx服务器以及将nginx安装成为一个系统服务,本节内容是在前期内容的基础上,搭建一个高可用的nginx服务器集群,主要使用Keepali ...

  8. Nginx+keepalived 高可用双机热备(主从模式/双主模式)

    基础介绍 负载均衡技术对于一个网站尤其是大型网站的web服务器集群来说是至关重要的!做好负载均衡架构,可以实现故障转移和高可用环境,避免单点故障,保证网站健康持续运行. 关于负载均衡介绍,可以参考:l ...

  9. nginx keepalived高可用集群主从模式

    hostname ip 说明 proxy-01 172.0.5.108 keepalived主节点nginx主负载均衡 proxy-02 172.0.5.39 keepalived备节点nginx辅负 ...

  10. 17. Nginx + keepalived 高可用

    文章目录 17. Nginx 高可用 17.1 Keeplived+Nginx高可用集群(主从模式) 17.1.1 准备测试机器 17.1.2 安装 keepalived 17.1.3 修改主机(ma ...

最新文章

  1. 在边缘AI与云AI之间寻找平衡
  2. 基于nginx和ffmpeg前端flv.js简单的直播环境搭建(rtmp+http-flv+hls)
  3. Android RxJava 3.x 使用总结
  4. LeetCode算法
  5. jQuery 3.5.0 发布
  6. aws rds监控慢sql_AWS RDS SQL Server恢复模型,备份和还原
  7. 网络数据库的复制和同步(一)
  8. dao获取到mysql存储函数_GreenDao3.0使用
  9. ATTCK实战系列三(msf域渗透)
  10. Docker仓库介绍和镜像加速器
  11. java解析excel日期格式_JAVApoi读取excel无法识别自定义格式年月日时分秒
  12. OPPO对诺基亚发起5G专利侵权诉讼
  13. 用python找出12万次MACD顶底背离,胜率究竟有多少?附代码【邢不行】
  14. 三口烧瓶规格有哪些_三口烧瓶有哪些规格,用途是什么 | | 化工资讯网
  15. 22.12.1打卡 漫步校园 记忆化搜索
  16. Apache Solr任意文件读取漏洞复现
  17. 来电显示软件测试自学,用MSComm控件实现来电显示
  18. 游戏设计师修炼之道:数据驱动的游戏设计
  19. ASP:IT外包敲门砖
  20. 首个活体机器人诞生:青蛙细胞生成,超级计算机设计,外媒:毛骨悚然

热门文章

  1. 5.4 Components -- Wrapping Content in A Component(在组件中包裹内容)
  2. 析构函数 deinit
  3. PowerDesigner数据库设计工具
  4. windows下mysql-8.0.11的安装
  5. edge chrome Android,微软Edge浏览器正式登陆Android平台
  6. 对象用[]来获取属性的注意点
  7. Centos 7 mini安装
  8. 拉格朗日乘子法(编辑中)
  9. Python进阶(二)Python中的类继承、封装、多态使用方法
  10. 线性规划 (一) 线性规划的基本形式及各种概念