准备nginx和keepalived
安装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和多个backup,master上面有一个对外提供服务的vip(VIP = Virtual IP Address,虚拟IP地址,该路由器所在局域网内其他机器的默认路由为该vip),master会发组播,当backup收不到VRRP包时就认为master宕掉了,这时就需要根据VRRP的优先级来选举一个backup当master。这样的话就可以保证路由器的高可用了。
keepalived主要有三个模块,分别是core、check和VRRP。core模块为keepalived的核心,负责主进程的启动、维护以及全局配置文件的加载和解析。check负责健康检查,包括常见的各种检查方式。VRRP模块是来实现VRRP协议的。
2 高可用配置
2.1 配置主备
两台nginx,一主一备:192.168.0.13和192.168.0.14
修改主nginx下/etc/keepalived/keepalived.conf文件
cp一个出来,改错了还能还原
主修改如下
备修改如下
重启nginx和keepalived
查看是否成功(需等待一会才能看到)
主挂了从才会出现,即飘移过来了
停掉主再查看
重新启动主,备的又会没有
2.1 配置双主
主
备
修改图中的部分数据
Ip addr 查看
13服务器
14服务器
现在访问下面的地址是一个效果
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