热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

第十一周LINUX学习笔记

第十一周LINUX学习笔记,Go语言社区,Golang程序员人脉社

                            keepalived

keepalived:
    基于vrrp(虚拟冗余路由协议)的实现
    virtual server: 对于IPVS
    vrrp_script: 调用外部脚本 nginx haproxy等轻量级的实现

    所谓的vrrp就是为了解决前端路由器如果发生单点故障导致后方服务器全部不能与外部通信的问题。于是两台路由器通过vrrp协议连接,两个路由器都给予虚拟的IP地址(VIP)和虚拟的MAC地址(VMAC),当发生故障的时候,两个地址一起转移,而不像其他的高可用功能一样,需要进行一次虚假的mac地址的通告。因此,所以所谓的keepalived就是将VRRP协议实现在了LINUX上,但是又不仅仅限制于转换地址的功能,也能够提供如转移一些nginx的服务的功能。

    而keepalived之间的资源转移是通过降低主节点的优先级的方式,将资源转移到副节点的方式

    /etc/keepalived/keepalived.conf
    /etc/rc.d/init.d/keepalived

    keepalived.conf

global_defs {  #全局配置段,一般来配置邮件功能
   notification_email {#收件人
       root@localhost
   }
   notification_email_from kaadmin@localhost  #发件人
   smtp_server 127.0.0.1
   smtp_connect_timeout 30
   router_id LVS_DEVEL
}

vrrp_instance VI_1 { #虚拟路由段的配置
    state MASTER #初始状态,如果这边设置了master 那么backup的priority 的值一定要小于master的
    interface eth0 #通信网卡
    virtual_router_id 51 #虚拟路由的ID号,不能大于255 还是MAC地址的最后一位,所以MAC地址就可以直接由这个来定义
    priority 100 #初始优先级
    advert_int 1 #初始化通告的个数
    authentication { #认证方式
        auth_type PASS  #认证类型
        auth_pass 1111 #认证密码
    }
    virtual_ipaddress { #VIP配置段
        192.168.1.103
    }
    track_script{
        abc #引用脚本名称
    }
}

vrrp_script abc{ #可以定义一个额外的脚本
    #脚本功能
}



1.如何在状态转换时进行通知?
    一般在vrrp_instance{}中进行使用
    to MASTER transition
        notify_master /path/to_master.sh
    to BACKUP transition
        notify_backup /path/to_backup.sh
    FAULT transition
        notify_fault "/path/to_backup.sh VG_1"


MASTER通知脚本实例:
#!/bin/bash
#
vip=192.168.1.103
cOntact='root@localhost'
thisip=`ifconfig eth0 | awk '/inet addr:/{print $2}' | awk -F: '{print $2}'` #获取IP地址的
nofity(){
    mailbody="vrrp transition,$vip floated to $thisip"
    subject="$thissip is to be $vip master"
    echo $mailbody | mail -s $subject $contact
}
nofity   

或者合并为一个脚本,在keepalived.txt中有提供案例
在vrrp_instance配置中只需要加入
notify_master "/path/notify.sh master"
notify_backup "/path/notify.sh backup"
notify_fault "/path/notify.sh fault"

2.如何配置ipvs?
    virtual server
    realserver
        health check
keepalived.conf 中的示例
virtual_server 172.168.100.100 80 {# VIP 地址和端口
    delay_loop 6
    lb_algo rr #负载均衡方法
    lb_kind DR  #LVS工作模型
    nat_mask 255.255.0.0
    persistence_timeout 0 #持久功能
    protocol TCP #基于什么工作方式

    real_server 172.16.100.17 80 {#RIP
        weight 1
        HTTP_GET {
            url {
              path /
              status_code 200
            }

            
            connect_timeout 3
            nb_get_retry 3
            delay_before_retry 3
        }
    }
    real_server 172.16.100.18 80 {#RIP
        weight 1
        HTTP_GET {
            url {
              path /
              status_code 200
            }

            connect_timeout 3
            nb_get_retry 3
            delay_before_retry 3
        }
    }    
}

3.如何对某特定服务做高可用
1丶监控服务
vrrp_script{

}
2丶追踪监控服务
track_script{

}

另外应该在nofity脚本中定义根据状态来启动或停止nginx
notify_master "/path/notify.sh master"
notify_backup "/path/notify.sh backup"
notify_fault "/path/notify.sh fault"
设置vrrp_script监控服务,防止因为nginx进程以及停止了,服务却还没有停止,导致无法转移的情况
vrrp_script chk_nginx{
    script "killall -0 nginx"
    inerval 1
    weight -2
    fall 2 失败次数一次
    rise 1 成功次数一次就行
}
4.如何实现基于多虚拟路由的master/master 模型

在配置文件中定义两个vrrp_instance


vrrp_instance VI_1 { #虚拟路由段的配置
    state MASTER #初始状态,如果这边设置了master 那么backup的priority 的值一定要小于master的
    interface eth0 #通信网卡
    virtual_router_id 51 #虚拟路由的ID号,不能大于255 还是MAC地址的最后一位,所以MAC地址就可以直接由这个来定义
    priority 100 #初始优先级
    advert_int 1 #初始化通告的个数
    authentication { #认证方式
        auth_type PASS  #认证类型
        auth_pass 1111 #认证密码
    }
    virtual_ipaddress { #VIP配置段
        192.168.1.103
    }
vrrp_instance VI_2 { #虚拟路由段的配置
    state BACKUP #初始状态,如果这边设置了master 那么backup的priority 的值一定要小于master的
    interface eth0 #通信网卡
    virtual_router_id 55 #虚拟路由的ID号,不能大于255 还是MAC地址的最后一位,所以MAC地址就可以直接由这个来定义
    priority 99 #初始优先级
    advert_int 1 #初始化通告的个数
    authentication { #认证方式
        auth_type PASS  #认证类型
        auth_pass 1111 #认证密码
    }
    virtual_ipaddress { #VIP配置段
        192.168.1.102
    }

另外一个机子的配置文件只需要改变两边的初始状态 和初始优先级


推荐阅读
  • 深入解析Linux下的I/O多路转接epoll技术
    本文深入解析了Linux下的I/O多路转接epoll技术,介绍了select和poll函数的问题,以及epoll函数的设计和优点。同时讲解了epoll函数的使用方法,包括epoll_create和epoll_ctl两个系统调用。 ... [详细]
  • 本文介绍了在rhel5.5操作系统下搭建网关+LAMP+postfix+dhcp的步骤和配置方法。通过配置dhcp自动分配ip、实现外网访问公司网站、内网收发邮件、内网上网以及SNAT转换等功能。详细介绍了安装dhcp和配置相关文件的步骤,并提供了相关的命令和配置示例。 ... [详细]
  • 概述H.323是由ITU制定的通信控制协议,用于在分组交换网中提供多媒体业务。呼叫控制是其中的重要组成部分,它可用来建立点到点的媒体会话和多点间媒体会议 ... [详细]
  • Nginx使用AWStats日志分析的步骤及注意事项
    本文介绍了在Centos7操作系统上使用Nginx和AWStats进行日志分析的步骤和注意事项。通过AWStats可以统计网站的访问量、IP地址、操作系统、浏览器等信息,并提供精确到每月、每日、每小时的数据。在部署AWStats之前需要确认服务器上已经安装了Perl环境,并进行DNS解析。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • 本文介绍了RPC框架Thrift的安装环境变量配置与第一个实例,讲解了RPC的概念以及如何解决跨语言、c++客户端、web服务端、远程调用等需求。Thrift开发方便上手快,性能和稳定性也不错,适合初学者学习和使用。 ... [详细]
  • 本文介绍了在mac环境下使用nginx配置nodejs代理服务器的步骤,包括安装nginx、创建目录和文件、配置代理的域名和日志记录等。 ... [详细]
  • 31.项目部署
    目录1一些概念1.1项目部署1.2WSGI1.3uWSGI1.4Nginx2安装环境与迁移项目2.1项目内容2.2项目配置2.2.1DEBUG2.2.2STAT ... [详细]
  • 单页面应用 VS 多页面应用的区别和适用场景
    本文主要介绍了单页面应用(SPA)和多页面应用(MPA)的区别和适用场景。单页面应用只有一个主页面,所有内容都包含在主页面中,页面切换快但需要做相关的调优;多页面应用有多个独立的页面,每个页面都要加载相关资源,页面切换慢但适用于对SEO要求较高的应用。文章还提到了两者在资源加载、过渡动画、路由模式和数据传递方面的差异。 ... [详细]
  • 目录浏览漏洞与目录遍历漏洞的危害及修复方法
    本文讨论了目录浏览漏洞与目录遍历漏洞的危害,包括网站结构暴露、隐秘文件访问等。同时介绍了检测方法,如使用漏洞扫描器和搜索关键词。最后提供了针对常见中间件的修复方式,包括关闭目录浏览功能。对于保护网站安全具有一定的参考价值。 ... [详细]
  • Python项目实战10.2:MySQL读写分离性能优化
    本文介绍了在Python项目实战中进行MySQL读写分离的性能优化,包括主从同步的配置和Django实现,以及在两台centos 7系统上安装和配置MySQL的步骤。同时还介绍了创建从数据库的用户和权限的方法。摘要长度为176字。 ... [详细]
  • HSRP热备份路由器协议的应用及配置
    本文介绍了HSRP热备份路由器协议的应用及配置方法,包括设计目标、工作原理、配置命令等。通过HSRP协议,可以实现在主动路由器故障时自动切换到备份路由器,保证网络连通性。此外,还介绍了R1和R2路由器的配置方法以及Sw1和Sw2交换机的配置方法,最后还介绍了测试连通性和路由追踪的方法。 ... [详细]
  • ZABBIX 3.0 配置监控NGINX性能【OK】
    1.在agent端查看配置:nginx-V查看编辑时是否加入状态监控模块:--with-http_stub_status_module--with-http_gzip_stat ... [详细]
  • 现在比较流行使用静态网站生成器来搭建网站,博客产品着陆页微信转发页面等。但每次都需要对服务器进行配置,也是一个重复但繁琐的工作。使用DockerWeb,只需5分钟就能搭建一个基于D ... [详细]
author-avatar
菜菜ING
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有