nginx基本运行介绍(三)

keepalived+Nginx实现高可用集群

keepalived介绍
keepalived是集群管理中保证集群高可用的一个服务软件,通过keepalived,我们可以实现Nginx集群,实现高可用。

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

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

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

下面我们不在docker里面使用nginx,而直接在我们的宿主机上来玩,故我们需要先安装nginx
默认情况Centos7中没有Nginx的源,Nginx官方提供了源,所以执行如下命令添加源

rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm

安装Nginx

yum install -y nginx

启动Nginx并设置开机自动运行

systemctl start nginx.service
systemctl enable nginx.service

Nginx关闭重启命令

systemctl stop nginx.service
systemctl restart nginx.service

输入ip进行测试
在这里插入图片描述
keepalived安装
安装yum命令

yum install keepalived

keepalived常用命令:

systemctl start keepalived.service
systemctl stop keepalived.service
systemctl restart keepalived.service

keepalived查看日志:

tail -f  /var/log/messages

查找安装目录:

find / -name keepalived

在这里插入图片描述
我们平时用的就是一个keepalived配置在/etc/keepalived 下
在这里插入图片描述
keepalived+nginx高可用集群配置
我们首先要搞两台机器,每个机器都安装有keepalived以及Nginx,为了演示得更逼真,nginx也要反向代理搞两个tomcat实现负载均衡;所以这两台机器,每个机器上都再搞个docker以及tomcat;

首先我们配置keepalived
找到第一台机器的/etc/keepalived目录的keepalived.conf配置文件,打开;
在这里插入图片描述
我们主要是配置这两个节点,下方其他的是配置的lvs,我们都删除掉 不需要;
global_defs是全局定义
vrrp_instance VI_1 是实例配置;
配置讲解:
#全局配置

global_defs {
   notification_email { # keepalived服务宕机异常出现的时候,发送通知邮件 可以是多个
     acassen@firewall.loc  #  收件人邮箱1
     failover@firewall.loc #  收件人邮箱2
     sysadmin@firewall.loc #  收件人邮箱3
   }
   notification_email_from Alexandre.Cassen@firewall.loc  #邮件发件人
   smtp_server 192.168.200.1  # 邮件服务器地址
   smtp_connect_timeout 30   # 超时时间
   router_id LVS_DEVEL   # 路由id 多个keepalived集群的时候 必须一致
   vrrp_skip_check_adv_addr # 默认是不跳过检查。检查收到的VRRP通告中的所有地址可能会比较耗时,设置此命令的意思是,如果通告与接收的上一个通告来自相同的master路由器,则不执行检查(跳过检查)。
   vrrp_strict   # 这个东西要注释掉,否则要出乱子。严格遵守VRRP协议。下列情况将会阻止启动Keepalived:1. 没有VIP地址。2. 单播邻居。3. 在VRRP版本2中有IPv6地址。
   vrrp_garp_interval 0  # 小数类型,单位秒,在一个网卡上每组gratuitous arp消息之间的延迟时间,默认为0,一个发送的消息=n组 arp报文
   vrrp_gna_interval 0 # 小数类型,单位秒, 在一个网卡上每组na消息之间的延迟时间,默认为0
}

#vrrp实例 我们集群设置 多机配置,除了state和priority不一样,其他都一样

vrrp_instance VI_1 {
    state MASTER  # 服务器状态 MASTER是主服务器  BACKUP是备份服务器 主服务器的priority要比备份服务器大
    interface eth0 # 通信端口 通过ip addr可以看到 根据自己的机器配置
    virtual_router_id 51  # vrrp实例id  keepalived集群,实例id必须一致
    priority 100  # 权重比  主服务器的priority要比备份服务器大
    advert_int 1  # 心跳间隔  单位秒  keepalived多机器集群 通过心跳检测,如果发送心跳没反应 就立刻接管;
    authentication { # 服务器之间通信密码
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress { # 自定义虚拟IP 
        192.168.200.16
        192.168.200.17
        192.168.200.18
    }
}

router_id 配置方式
我们修改/etc/hosts文件(宿主机上的不是自己电脑上)
加一行

127.0.0.1 KEEPALIVED_NGINX_MASTER

在这里插入图片描述
这里的KEEPALIVED_NGINX_MASTER 就可以配置到router_id 里;

vrrp_instance 的 interface 配置:
我们ip addr看宿主机的
在这里插入图片描述
我这边是 eth0

下面贴上keepalived修改后的配置,备份的服务器可以自己租一个,或者在虚拟机里面进行配置,克隆一份即可

! Configuration File for keepalived
# 全局配置
global_defs {
   notification_email { # keepalived服务宕机异常出现的时候,发送通知邮件 可以是多个
     acassen@firewall.loc  #  收件人邮箱1
     failover@firewall.loc #  收件人邮箱2
     sysadmin@firewall.loc #  收件人邮箱3
   }
   notification_email_from Alexandre.Cassen@firewall.loc  #邮件发件人
   smtp_server 192.168.200.1  # 邮件服务器地址
   smtp_connect_timeout 30   # 超时时间
   router_id KEEPALIVED_NGINX_MASTER   # 机器标识 局域网内唯一即可
   vrrp_skip_check_adv_addr # 默认是不跳过检查。检查收到的VRRP通告中的所有地址可能会比较耗时,设置此命令的意思是,如果通告与接收的上一个通告来自相同的master路由器,则不执行检查(跳过检查)。
   #vrrp_strict   # 严格遵守VRRP协议。下列情况将会阻止启动Keepalived:1. 没有VIP地址。2. 单播邻居。3. 在VRRP版本2中有IPv6地址。
   vrrp_garp_interval 0  # 小数类型,单位秒,在一个网卡上每组gratuitous arp消息之间的延迟时间,默认为0,一个发送的消息=n组 arp报文
   vrrp_gna_interval 0 # 小数类型,单位秒, 在一个网卡上每组na消息之间的延迟时间,默认为0
}
# vrrp实例  我们集群设置 多机配置,除了state和priority不一样,其他都一样
vrrp_instance VI_1 {
    state MASTER  # 服务器状态 MASTER是主服务器  BACKUP是备份服务器 主服务器的priority要比备份服务器大
    interface eth0# 通信端口 通过ip addr可以看到 根据自己的机器配置
    virtual_router_id 51  # vrrp实例id  keepalived集群,实例id必须一致
    priority 100  # 权重比
    advert_int 1  # 心跳间隔  单位秒  keepalived多机器集群 通过心跳检测,如果发送心跳没反应 就立刻接管;
    authentication { # 服务器之间通信密码
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress { # 自定义虚拟IP 
        192.168.1.99
    }

}

备份机配置:

! Configuration File for keepalived
# 全局配置
global_defs {
   notification_email { # keepalived服务宕机异常出现的时候,发送通知邮件 可以是多个
     acassen@firewall.loc  #  收件人邮箱1
     failover@firewall.loc #  收件人邮箱2
     sysadmin@firewall.loc #  收件人邮箱3
   }
   notification_email_from Alexandre.Cassen@firewall.loc  #邮件发件人
   smtp_server 192.168.200.1  # 邮件服务器地址
   smtp_connect_timeout 30   # 超时时间
   router_id KEEPALIVED_NGINX_BACKUP   # 机器标识 局域网内唯一即可
   vrrp_skip_check_adv_addr # 默认是不跳过检查。检查收到的VRRP通告中的所有地址可能会比较耗时,设置此命令的意思是,如果通告与接收的上一个通告来自相同的master路由器,则不执行检查(跳过检查)。
   # vrrp_strict   # 严格遵守VRRP协议。下列情况将会阻止启动Keepalived:1. 没有VIP地址。2. 单播邻居。3. 在VRRP版本2中有IPv6地址。
   vrrp_garp_interval 0  # 小数类型,单位秒,在一个网卡上每组gratuitous arp消息之间的延迟时间,默认为0,一个发送的消息=n组 arp报文
   vrrp_gna_interval 0 # 小数类型,单位秒, 在一个网卡上每组na消息之间的延迟时间,默认为0
}
# vrrp实例  我们集群设置 多机配置,除了state和priority不一样,其他都一样
vrrp_instance VI_1 {
    state BACKUP  # 服务器状态 MASTER是主服务器  BACKUP是备份服务器 主服务器的priority要比备份服务器大
    interface ens33 # 通信端口 通过ip addr可以看到 根据自己的机器配置
    virtual_router_id 51  # vrrp实例id  keepalived集群,实例id必须一致
    priority 50  # 权重比
    advert_int 1  # 心跳间隔  单位秒  keepalived多机器集群 通过心跳检测,如果发送心跳没反应 就立刻接管;
    authentication { # 服务器之间通信密码
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress { # 自定义虚拟IP 
        192.168.1.99
    }
}

启动

systemctl start keepalived.service

我们可以通过192.168.1.99访问到我们的集群机器;

下面我们进行测试:
为了方便测试,我们修改nginx的默认文件;
nginx默认文件目录:
/usr/share/nginx/html目录
修改index.html内容为当前机器IP;

这时候再访问192.168.1.99
因为107是主机器;权重高,所以访问的是107机器;
假如我们让107挂掉 systemctl stop keepalived.service
则自动切换到备份机器109

所以我们的配置时成功的

通过shell脚本来优化上面的配置
前面我们测试的情况是 keepalived挂掉的情况,实际情况是keepalived不容易挂掉,容易挂掉的是nginx;
所以这里就有有问题了,nginx挂了,但是keepavlied没挂,这时候 依然可以访问机器,但是访问不到服务;
所以这里需要借助keepalived的vrrp_script配置;来调用自定义shell脚本;
我们给下脚本:

#!/bin/bash
echo 'xxxxxx'
count_nginx=`ps -ef|grep -w nginx|grep -v grep|wc -l`
echo $count_nginx
if [ $count_nginx -eq 0 ];then
    systemctl start nginx.service
    sleep 2
    if [ `ps -ef|grep -w nginx|grep -v grep|wc -l` -eq 0 ];then
        systemctl stop keepalived.service
    fi  
fi

这个shell脚本的意思是 统计nginx进程数,假如是0个 说明Nginx挂掉了,那就启动nginx,等2秒,再统计,假如还是0,说明nginx启动失败,

那我们就把keepalived也啥掉 切换备份机器,假如不是0,说明启动成功,那就继续运行;
把上面shello脚本命名nginx_check.sh文件,存/shell/目录下;
下面是shell脚本测试;
切换shell目录
在这里插入图片描述
查看:
在这里插入图片描述
在这里插入图片描述
我们测试:

sh nginx_check.sh

在这里插入图片描述
执行没问题,有2条记录,所以不用干啥
假如我们把 nginx停掉 ; 模拟nginx宕机

systemctl stop nginx.service

在这里插入图片描述
我们执行shell脚本 是0 所以自动启动nginx
所以我们下面执行会发现 又有 Nginx了;

我们配置下keepalived.conf;

vrrp_script chk_http_port {
 script "/shell/nginx_check.sh" #脚本地址
 interval 2 #检测脚本执行的间隔
 weight 2 #比重
}

这时候 我们重启keepalived测试,也是没问题;

下面我们加上tomcat来测试,这里我们用docker里面的tomcat
然后运行omcat

docker run -d  -p 8080:8080  镜像id

我们再浏览器访问,因为是两台机器,故分别使用ip地址进行访问
接下来,我们配置nginx负载均衡;再/etc/nginx目录下;
打开nginx.conf配置文件;
在 include /etc/nginx/conf.d/*.conf;上方加上;

upstream www.jiangnanfeipeng.com{
         server 192.168.1.107:8080;
         server 192.168.1.109:8080;
    }

nginx/nginx/conf.d/下的default.conf改成;

server {
    listen       80;
    server_name  localhost;
    location / {
        proxy_pass   http://www.jiangnanfeipeng.com;
        index  index.html index.htm;
    }
}

我们重启nginx

systemctl restart nginx.service

访问 http://192.168.1.107/ 或者 http://192.168.1.111/都能访问到tomcat集群;

我们再启动keepalived

systemctl start keepalived.service

然后访问 http://192.168.1.99/ 能够实现 keepalived+Nginx+tomcat负载均衡

当然我们hosts文件也修改下 C:\Windows\System32\drivers\etc加一条

192.168.1.99  www.feng.com

这样可以直接用域名访问,到此keepalived+Nginx+tomcat配置完成,感兴趣可以点赞留言评论,谢谢!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值