CentOS7+Keepalived+Nginx高可用配置

Keepalived介绍

Keepalived是一个基于VRRP协议来实现的服务高可用方案。VRRP协议(虚拟路由冗余协议—— Virtual Router Redundancy Protocol,简称VRRP),是由IETF提出的解决局域网中配置静态网关出现单点失效现象的路由协议,1998年已推出正式的RFC2338协议标准。VRRP广泛应用在边缘网络 中,它的设计目标是支持特定情况下IP数据流量失败转移不会引起混乱,允许主机使用单路由器,以 及即使在实际第一跳路由器使用失败的情形下仍能够维护路由器间的连通性。 大白话来说就是,VRRP协议允许一台机器可以拥有一个或者多个虚拟IP。在高可用的一组机器中,有 一个master,多个slave,对外提供一个虚IP,通过虚IP访问master,slave负责监控master,如果 master宕机,则选举其中一个slave接管master,虚IP绑定到新的master上(俗称IP漂移),从而实现了高可用。深入了解请查看 keepAlived官网

环境

硬件

配置 测试配置
CPU 1.8GHz
内存 4GB
核心 4核
带宽 1000Mb

软件

  • VMware® Workstation 16 Pro 16.1.1 build-17801498
  • CentOS Linux release 7.6.1810 (Core)
  • nginx-1.9.9
  • keepalived-1.3.5-19.el7.x86_64

规划

IP host 说明
192.168.88.100 KP的VIP
192.168.88.54 node1 节点1,安装kp与ng,设置master
192.168.88.59 node2 节点2,安装kp与ng,设置slave

安装过程

因为两个节点配置过程基本都是相同的,可以使用xhell的“发送键入到所有会话”的方式,同时安装两个节点(相信我,试一下,非常爽)。

nginx

基础安装过程参考文章:《CentOS 7 安装 nginx 极简教程》《nginx安装 ./configure参数详解

安装完成后,修改index.html,区分node1和node2。最后一个字符关闭同步输入。

vim /usr/local/nginx/html/index.html
设置区分两个节点

修改配置文件,默认使用运维用户(www)运行进程,并且将项目的配置文件从默认配置文件独立出去。运维用户的创建过程参考文章《CentOS 7 创建运维用户

vim /usr/local/nginx/conf/nginx.conf
修改ng配置

创建项目配置目录

mkdir /usr/local/nginx/conf/vhost
chmod 777 /usr/local/nginx/conf/vhost

nginx命令提升权限

chmod u+s /usr/local/nginx/sbin/nginx

运行测试

/usr/local/nginx/sbin/nginx
ps -ef | grep nginx

可以看到nginx进程已经起来了。

ng进程

防火墙添加端口。通过浏览器验证一下。

firewall-cmd --zone=public --add-port=80/tcp --permanent
firewall-cmd --reload

node1:

node1页面

node2:

node2页面

keepalived

安装依赖

yum install -y net-snmp-agent-libs ipset ipset-libs net-snmp-libs

安装keepalived

yum install ‐y keepalived

准备相关脚本,并上传到服务器

check_ng.sh

#!/bin/bash

if [ "$(ps -ef | grep "nginx: master process"| grep -v grep )" == "" ];
then 
    /usr/local/nginx/sbin/nginx
    sleep 2 
    if [ "$(ps -ef | grep "nginx: master process"| grep -v grep )" == "" ];
    then
        systemctl stop keepalived
    fi
fi

master.sh

#!/bin/bash

ip=$(hostname -I | awk '{print $1}')
dt=$(date +'%Y-%m-%d %H:%M:%S')
echo "$0--${ip}--${dt}">>/joinway/tools/keepalived/log/kp.log

backup.sh

#!/bin/bash

ip=$(hostname -I | awk '{print $1}')
dt=$(date +'%Y-%m-%d %H:%M:%S')
echo "$0--${ip}--${dt}">>/joinway/tools/keepalived/log/kp.log

fault.sh

#!/bin/bash

ip=$(hostname -I | awk '{print $1}')
dt=$(date +'%Y-%m-%d %H:%M:%S')
echo "$0--${ip}--${dt}">>/joinway/tools/keepalived/log/kp.log

stop.sh

#!/bin/bash

ip=$(hostname -I | awk '{print $1}')
dt=$(date +'%Y-%m-%d %H:%M:%S')
echo "$0--${ip}--${dt}">>/joinway/tools/keepalived/log/kp.log

修改kp配置

vim /etc/keepalived/keepalived.conf

node1(master)配置:

! Configuration File for keepalived

global_defs
{
    notification_email {
        acassen@firewall.loc
        failover@firewall.loc
        sysadmin@firewall.loc
    }
    notification_email_from Alexandre.Cassen@firewall.loc
    smtp_server 127.0.0.1
    smtp_connect_timeout 30
    router_id LVS_DEVEL
    vrrp_skip_check_adv_addr
    vrrp_strict
    vrrp_garp_interval 0
    vrrp_gna_interval 0
    script_user root
    enable_script_security
}

vrrp_script check_ng
{
    script "/joinway/tools/keepalived/check_ng.sh"
    interval 1
}

vrrp_instance VI_1 {
    state MASTER
    interface ens33
    virtual_router_id 51
    priority 100
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass joinway
    }
    virtual_ipaddress {
        192.168.88.100
    }
    track_script {
        check_ng
    }
    notify_master /joinway/tools/keepalived/master.sh
    notify_backup /joinway/tools/keepalived/backup.sh
    notify_fault /joinway/tools/keepalived/fault.sh
    notify_stop /joinway/tools/keepalived/stop.sh

}

node2(backup)配置:

! Configuration File for keepalived

global_defs {
   notification_email {
     acassen@firewall.loc
     failover@firewall.loc
     sysadmin@firewall.loc
   }
   notification_email_from Alexandre.Cassen@firewall.loc
   smtp_server 127.0.0.1
   smtp_connect_timeout 30
   router_id LVS_DEVEL
   vrrp_skip_check_adv_addr
   vrrp_strict
   vrrp_garp_interval 0
   vrrp_gna_interval 0
   script_user root
   enable_script_security
}

vrrp_script nginx_check {
  script "/joinway/tools/keepalived/check_ng.sh"
  interval 1
  user root
}

vrrp_instance VI_1 {
    state BACKUP
    interface ens33
    virtual_router_id 51
    priority 90
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass joinway
    }
    virtual_ipaddress {
        192.168.88.100
    }
    track_script {
        nginx_check
    }
    notify_master /joinway/tools/keepalived/master.sh
    notify_backup /joinway/tools/keepalived/backup.sh
    notify_fault /joinway/tools/keepalived/fault.sh
    notify_stop /joinway/tools/keepalived/stop.sh

}

配置文件中的第24/30/39/44/45/46/47行需要根据实际情况进行调整。

创建脚本路径并修改文件权限

mkdir -p /joinway/tools/keepalived
chmod 755 /joinway/tools/keepalived/*.sh
KP脚本

至此,所有的配置就做好了,可以启动keepalived了。

等一下,这里还有一个坑,如果没有关闭防火墙,请记得配置vrrp协议,否则脑裂 ̄へ ̄

firewall-cmd --add-rich-rule='rule protocol value="vrrp" accept' --permanent && firewall-cmd --reload

管理命令如下:

systemctl start keepalived.service    # 启动
systemctl stop keepalived.service     # 停止
systemctl status keepalived.service   # 查看状态

start之后可以看到keepalived已经运行起来的

KP进程

但是这时发现一个问题,我们在脚本中配置的“/joinway/tools/keepalived/log/kp.log”路径下log并没有输出出来,并且在nginx挂掉的时候,check_ng.sh脚本也没起到应有的作用。

于是在调查原因的过程中,发现KP日志有如下错误信息。

KP启动异常

“Unable to access script”、“Disabling notify script”,这个错误信息可谓是赫赫有名啊,可能很多小伙伴都会遇到一样的情况,在网上找了好多的方案,试来试去,基本都是徒劳。最靠谱的算是关闭selinux,关闭了确实有效果,但是作为生产服务器,关闭厂家自带的安全机制很显然不是一个很好的选择,在山穷水尽之后,果然是柳暗花明。

在这里特别感谢阿里云大神咸鱼运维杂谈,详细解析了selinux拦截kp运行脚本的原因以及解决方案。

修改kp脚本的安全上下文。

chcon -t keepalived_unconfined_script_exec_t /joinway/tools/keepalived/*.sh
KP正常启动

手动创建kp.log日志文件后,脚本触发的日志也正常了。

/joinway/tools/keepalived/log
vim /joinway/tools/keepalived/log/kp.log
kp切换日志

调整KP日志

在解决问题过程中,发现kp的日志默认是写在系统“/var/log/messages”路径中的,考虑到以后kp的维护需要交给运维账户,需要把kp日志单独独立出来,权限单独控制。

编辑配置文件/etc/sysconfig/keepalived,将第14行的KEEPALIVED_OPTIONS="-D"修改为KEEPALIVED_OPTIONS="-D -d -S 0"

vim /etc/sysconfig/keepalived
/etc/sysconfig/keepalived

修改rsyslog的配置文件/etc/rsyslog.conf,在结尾加入如下2行内容,将local0设备的所有日志都记录到/var/log/keepalived.log文件.

vim /etc/rsyslog.conf
/etc/rsyslog.conf

重启rsyslog服务

service rsyslog restart

修改日志文件权限,让运维用户可以看得到。

chmod 755 /var/log/keepalived.log

至此keepalived已可以正常使用。

kp访问

模拟node1挂掉

node1挂了

node2接管服务

node2

模拟node1恢复

node1恢复

node1重新接管服务

node1

测试运维用户(www)

[www@node1 ~]$ sudo systemctl stop keepalived.service
[www@node1 ~]$ sudo systemctl start keepalived.service
[www@node1 ~]$ sudo systemctl status keepalived.service
[www@node1 ~]$ tail -f /var/log/keepalived.log
[www@node1 ~]$ tail -f /joinway/tools/keepalived/log/kp.log 

KP指令均可正常执行

运维用户KP正常
[www@node1 vhost]$ sudo /usr/local/nginx/sbin/nginx -t
[www@node1 vhost]$ sudo /usr/local/nginx/sbin/nginx -s stop
[www@node1 vhost]$ sudo /usr/local/nginx/sbin/nginx -s quit
[www@node1 vhost]$ sudo /usr/local/nginx/sbin/nginx -s reload
[www@node1 vhost]$ sudo /usr/local/nginx/sbin/nginx
[www@node1 vhost]$ tail -f /usr/local/nginx/logs/access.log 
[www@node1 vhost]$ tail -f /usr/local/nginx/logs/error.log

NG指令正常

运维用户股NG正常
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351

推荐阅读更多精彩内容