【nginx】高可用集群

闲话

今天中午自己给自己烧了一顿红烧鸡爪,味道还可以,下午继续,今天必把nginx看完!

基本要点

1、背景
在之前的nginx学习中,我们一般都只配置了一台nginx服务来处理分发请求,但是如果nginx服务器宕机的话,那请求的正常运行将无法得到保障

为了防止这种情况的发生,我们设置2台nginx服务器,一台当做主服务器,另一台当备用服务器,当主服务器nginx宕机时,自动切换到备份服务器,继续处理请求,这个就是我们所说的高可用性

具体流程如下
【nginx】高可用集群_第1张图片

2、准备工作
1)需要2台服务器,分别装上nginx,可参考我之前的博客 nginx安装及防火墙配置
2)在两台服务器上安装keepalived软件
使用yum命令进行安装

yum install keepalived -y

【nginx】高可用集群_第2张图片
执行命令,查看安装是否完成
在这里插入图片描述
软件安装完成之后,系统会在/etc/keepalived/目录下生成keepalived.conf文件

3)keepalived配置
首先创建nginx检测脚本,放置到keepalived.conf配置文件中的指定路径下

如果nginx服务停止,尝试拉起nginx服务,如果nginx拉起失败,那么将keepalived服务也停掉,切换到备用机器的nginx

关于脚本含义,可以参考这位同学的博客:检查nginx进程状态脚本
这脚本坑死我了,查了好久才搞懂含义!!

#!/bin/bash
# 判断nginx进程是否存在
C=`ps -C nginx --no-header |wc -l`
if [ $C -eq 0 ];then
        echo 'test1' # 查看是否进入此if模块的语句,类似于Java的system.out.println的测试语句
        /opt/decade/nginx/sbin/nginx #这里尝试调用nginx启动脚本,重新拉起服务
        sleep 2 # 休眠2秒,这里是为了让nginx服务有时间启动,否则直接走到下一个if条件,nginx还没启动完,系统就会认为nginx服务有问题,起不来,然后就会kill掉这台机器上的keepalived服务
        echo 'test'
        # 判断nginx服务是否被拉起,如果没有,那就kill掉keepalived进程
        if [ `ps -C nginx --no-header |wc -l` -eq 0 ];then
            echo 'test ok!'
            killall keepalived
        fi
fi

注意:killall命令用于杀死指定名字的进程(kill processes by name),即结束同名的的所有进程为了使killall指令生效,我们需要提前安装,并且给nginx_check.sh脚本执行权限

yum install psmisc -y
chmod +x nginx_check.sh  #需要在nginx_check.sh存放路径下执行

然后修改/etc/hosts文件,配置路由
【nginx】高可用集群_第3张图片

最后配置keepalived.conf配置文件,如下图

vrrp_script chk_http_port {

   script "/opt/decade/resource/nginx_check.sh" # 检测脚本存放地址,此处配置的是nginx进程检测脚本

   interval 2 # 脚本执行间隔

   weight -20 # 权重,如果检测脚本中的条件成立,那么就将当前主机的权重降低20

}

【nginx】高可用集群_第4张图片
另外,我们还要在虚拟IP配置的下方增加keepalived脚本的调用

track_script {
    chk_http_port
}

keepalived的停起脚本

systemctl start keepalived
killall keepalived

3、预期结果
完成主备两台机器的配置之后,尝试关掉主服务器的nginx,仍然可以访问我们的服务

如有错误,欢迎指正!

你可能感兴趣的:(nginx,nginx,服务器,运维)