zoukankan      html  css  js  c++  java
  • nginx+keepalived 简单实现主备和双主模式

    准备nginxkeepalived

    安装nginx(自行安装)

    yum install nginx

    安装keepalived(安装包安装总报错,yum安装能好一点)

    yum install keepalived -y

    keepalived

    https://www.cnblogs.com/zhangxingeng/p/10595058.html 

    1   nginx负载均衡高可用

    1.1  什么是负载均衡高可用

             nginx作为负载均衡器,所有请求都到了nginx,可见nginx处于非常重点的位置,如果nginx服务器宕机后端web服务将无法提供服务,影响严重。

             为了屏蔽负载均衡服务器的宕机,需要建立一个备份机。主服务器和备份机上都运行高可用(High Availability)监控程序,通过传送诸如“Iam alive”这样的信息来监控对方的运行状况。当备份机不能在一定的时间内收到这样的信息时,它就接管主服务器的服务IP并继续提供负载均衡服务;当备份管理器又从主管理器收到“I am alive”这样的信息时,它就释放服务IP地址,这样的主服务器就开始再次提供负载均衡服务。

    1.2  keepalived+nginx实现主备,双主

    1.2.1  什么是keepalived

             keepalived是集群管理中保证集群高可用的一个服务软件,用来防止单点故障。

            Keepalived的作用是检测web服务器的状态,如果有一台web服务器死机,或工作出现故障,Keepalived将检测到,并将有故障的web服务器从系统中剔除,当web服务器工作正常后Keepalived自动将web服务器加入到服务器群中,这些工作全部自动完成,不需要人工干涉,需要人工做的只是修复故障的web服务器。

    1.2.2  keepalived工作原理

             keepalived是以VRRP协议为实现基础的,VRRP全称Virtual Router Redundancy Protocol,即虚拟路由冗余协议。

             虚拟路由冗余协议,可以认为是实现路由器高可用的协议,即将N台提供相同功能的路由器组成一个路由器组,这个组里面有一个master和多个backupmaster上面有一个对外提供服务的vipVIP = Virtual IP Address,虚拟IP地址,该路由器所在局域网内其他机器的默认路由为该vip),master会发组播,当backup收不到VRRP包时就认为master宕掉了,这时就需要根据VRRP的优先级来选举一个backupmaster。这样的话就可以保证路由器的高可用了。

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

    2  高可用配置

    2.1  配置主备

    两台nginx,一主一备:192.168.0.13192.168.0.14

    修改主nginx下/etc/keepalived/keepalived.conf文件

    cp一个出来,改错了还能还原

    主修改如下

    备修改如下

    重启nginxkeepalived

    查看是否成功(需等待一会才能看到)

     

    主挂了从才会出现,即飘移过来了

    停掉主再查看

     

    重新启动主,备的又会没有

    2.1  配置双主

     备

    修改图中的部分数据

    Ip addr 查看

    13服务器

    14服务器

    现在访问下面的地址是一个效果

    http://192.168.0.233/  

    http://192.168.0.234/

    keepalived 配置 日志方法

    keepalived默认会把日志打在/var/log/messages。如果不进行配置的话,日志混在一起,如果遇到问题需要查看日志,不太方便进行查看,下面是keepalived日志的具体配置方法、步骤。

    方法/步骤

    keepalived 当前的版本为

    keepalived -v

    keepalived默认会把日志打在/var/log/messages。如果不进行配置的话,日志混在一起很难进行调试问题

    vi /etc/sysconfig/keepalived

    把KEEPALIVED_OPTIONS="-D" 修改为

    KEEPALIVED_OPTIONS="-D -d -S 0"

    在/etc/rsyslog.conf 末尾添加

    vim /etc/rsyslog.conf

    local0.*  /var/log/keepalived.log

    重启日志记录服务

    [root@master log]# systemctl restart rsyslog

    [root@master log]# systemctl status rsyslog

    重启keepalived服务

    systemctl restart keepalived

    /var/log/keepalived.log 日志文件已经有最新的日志记录进来了

    高可用之调用辅助脚本进行资源监控,并根据监控的结果状态实现动态调整

    https://www.cnblogs.com/zhangxingeng/p/10721083.html 

    纵有白头俱老意,奈何缘浅路芊芊.
  • 相关阅读:
    Web开发利器Webstorm导入多个文件夹或者项目
    js react 全选和反选
    nginx的配置文件 【nginx.conf】
    nginx 服务器重启命令,关闭
    Nginx反向代理新篇-使用location对多个URL做反向代理
    Windows下Nginx的安装与配置
    es6 递归 tree
    自定义table样式
    数据库(7)
    数据库(6)
  • 原文地址:https://www.cnblogs.com/hanby/p/15155862.html
Copyright © 2011-2022 走看看