闲话
今天中午自己给自己烧了一顿红烧鸡爪,味道还可以,下午继续,今天必把nginx看完!
基本要点
1、背景
在之前的nginx学习中,我们一般都只配置了一台nginx服务来处理分发请求,但是如果nginx服务器宕机的话,那请求的正常运行将无法得到保障
为了防止这种情况的发生,我们设置2台nginx服务器,一台当做主服务器,另一台当备用服务器,当主服务器nginx宕机时,自动切换到备份服务器,继续处理请求,这个就是我们所说的高可用性
2、准备工作
1)需要2台服务器,分别装上nginx,可参考我之前的博客 nginx安装及防火墙配置
2)在两台服务器上安装keepalived软件
使用yum命令进行安装
yum install keepalived -y
执行命令,查看安装是否完成
软件安装完成之后,系统会在/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存放路径下执行
最后配置keepalived.conf配置文件,如下图
vrrp_script chk_http_port {
script "/opt/decade/resource/nginx_check.sh" # 检测脚本存放地址,此处配置的是nginx进程检测脚本
interval 2 # 脚本执行间隔
weight -20 # 权重,如果检测脚本中的条件成立,那么就将当前主机的权重降低20
}
另外,我们还要在虚拟IP配置的下方增加keepalived脚本的调用
track_script {
chk_http_port
}
keepalived的停起脚本
systemctl start keepalived
killall keepalived
3、预期结果
完成主备两台机器的配置之后,尝试关掉主服务器的nginx,仍然可以访问我们的服务
如有错误,欢迎指正!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/136793.html