keepalived实现nginx反向代理的高可用
实现keepalived调用脚本进行资源监控
keepalived调用外部的辅助脚本进行资源监控,并根据监控的结果状态能实现优先动态调整
vrrp_script:自定义资源监控脚本,vrrp实例根据脚本返回值,公共定义,可被多个实例调用,定义在vrrp实例之外
track_script:调用vrrp_script定义的脚本去监控资源,定义在实例之内,调用事先定义的vrrp_script
分两步:(1) 先定义一个脚本;(2) 调用此脚本
vrrp_script <SCRIPT_NAME> {
script ""
interval INT
weight -INT
}
track_script {
SCRIPT_NAME_1
SCRIPT_NAME_2
}
1、环境搭建:
类型 |
机器名称 |
IP配置 |
服务角色 |
A |
client |
192.168.37.7 |
客户端访问(桥接模式) |
C |
lvs-server1 |
VIP:192.168.37.100 DIP:192.168.37.17 |
负载均衡调度器(NAT模式) |
D |
lvs-server2 |
VIP:192.168.37.100 DIP:192.168.37.27 |
负载均衡调度器(NAT模式) |
E |
rs1 |
RIP:192.168.37.37 |
后端服务器(NAT模式) |
F |
rs2 |
RIP:192.168.37.47 |
后端服务器(NAT模式) |
2、在keepalived主服务器配置
配置keepalived服务
[root@centos17~]#yum install keepalived
[root@centos17~]#vim /etc/keepalived/keepalived.conf
global_defs {
notification_email {
974212253@qq.com 接收邮箱地址
}
notification_email_from www.magedu.net 从哪个邮箱发送
smtp_server 127.0.0.1 本地IP地址
smtp_connect_timeout 30
router_id ka1 本地的主机名
vrrp_skip_check_adv_addr
vrrp_garp_interval 0
vrrp_gna_interval 0
}
vrrp_script chk_down {
script "/etc/keepalived/test.sh" 调用本地脚本test.sh
interval 1
weight -30 权重减30
} vrrp_script chk_nginx {
script "/etc/keepalived/check_nginx.sh" 调用本地脚本check_nginx.sh
interval 1
weight -30 权重减30
} vrrp_instance VI_1 {
state MASTER 本机的主节点
interface ens33 本机的网卡名称
virtual_router_id 66 本机路由ID号
priority 100 本机keepalived优先级
unicast_src_ip 192.168.37.17 # 配置源地址的IP地址,绑定单播地址的目的是为了防止与其他主机的IP地址存在冲突问题。
unicast_peer {
192.168.37.27 # 配置从节点的目标IP地址
}
advert_int 1
authentication {
auth_type PASS
auth_pass 123456 密码
}
virtual_ipaddress {
192.168.37.100/24 dev ens33 label ens33:1 添加一个VIP地址
}
track_script {
chk_down 对宕机进行检查
}
track_script {
chk_nginx 对nginx进行检查
}
notify_master "/etc/keepalived/notify.sh master" 调用脚本,返回当前keepalived状态信息:master
notify_backup "/etc/keepalived/notify.sh backup" 返回backup信息
notify_fault "/etc/keepalived/notify.sh fault" 返回fault信息
} [root@centos17~]#systemctl start keepalived
配置主节点nginx服务,配置完成之后启动nginx服务:nginx
yum install nginx -y 安装nginx服务包
[root@centos17~]#vim /etc/nginx/nginx.conf
upstream websrvs{
server 192.168.37.37:80;
server 192.168.37.47:80;
} server {
listen 80;
server_name www.magedu.net;
root /data/site1;
index index.html;
location / {
proxy_pass http://websrvs;
}
在keepalived主节点创建脚本
在keepalived主节点创建一个检查nginx状态脚本
[root@centos17keepalived]#vim check_nginx.sh
#!/bin/bash
killall -0 nginx &> /dev/null || exit 1 检查此时的nginx服务进程是否正常,如果非0(死机),就会执行退出显示1。
[root@centos17]#chmod +x check_nginx.sh 添加执行权限
当keepalived服务器宕机时,在keepalived主节点创建一个降优先级脚本。
[root@centos17keepalived]#vim test.sh
#!/bin/bash
[ -f /etc/keepalived/down ] && exit 1 || exit 0 判断/etc/keepalived/目录下是否有down文件,如果有就返回1,没有就返回0 [root@centos17keepalived]#chmod +x test.sh 加上执行权限
当nginx停止服务或者死机时,此时nginx服务器变成从节点,检测到主节点变成从节点后,此脚本就会提示主节点变为从节点,返回backup,就会重新启动nginx服务,又会抢占从节点nginx服务,变成主节点。
实现脚本如下:
[root@centos17keepalived]#vim notify.sh
#!/bin/bash
contact='root@localhost'
notify() {
mailsubject="$(hostname) to be $1, vip floating"
mailbody="$(date +'%F %T'): vrrp transition, $(hostname) changed to be $1"
echo "$mailbody" | mail -s "$mailsubject" $contact
}
case $1 in
master)
notify master
;;
backup)
notify backup
systemctl restart nginx 当主节点的nginx宕机之后,返回backup,就会有重启nginx,又抢回主节点位置,继续为客户端提供服务。
;;
fault)
notify fault
;;
*)
echo "Usage: $(basename $0) {master|backup|fault}"
exit 1
;;
esac
3、在keepalived从服务器配置
在keepalived从服务器上配置相关文件
[root@centos27~]#vim /etc/keepalived/keepalived.conf
global_defs {
notification_email {
974212253@qq.com
}
notification_email_from ka1@magedu.net
smtp_server 127.0.0.1
smtp_connect_timeout 30
router_id ka2
vrrp_skip_check_adv_addr
vrrp_garp_interval 0
vrrp_gna_interval 0
}
vrrp_script chk_down {
script "/etc/keepalived/test.sh"
interval 1
weight -30
}
vrrp_script chk_nginx {
script "/etc/keepalived/check_nginx.sh"
interval 1
weight -30
} vrrp_instance VI_1 {
state BACKUP
interface ens33
virtual_router_id 66
priority 80
unicast_src_ip 192.168.37.27 配置从节点的IP地址
unicast_peer {
192.168.37.17 配置主节点的目标IP地址
}
advert_int 1
authentication {
auth_type PASS
auth_pass 123456
}
virtual_ipaddress {
192.168.37.100/24 dev ens33 label ens33:1
}
track_script {
chk_down
}
track_script {
chk_nginx
}
notify_master "/etc/keepalived/notify.sh master"
notify_backup "/etc/keepalived/notify.sh backup"
notify_fault "/etc/keepalived/notify.sh fault"
}
配置从节点的nginx服务,配置完成之后启动nginx服务:nginx
[root@centos17~]#vim /etc/nginx/nginx.conf
upstream websrvs{
server 192.168.37.37:80;
server 192.168.37.47:80;
} server {
listen 80;
server_name www.magedu.net;
root /data/site1;
index index.html;
location / {
proxy_pass http://websrvs;
}
在keepalived从节点创建脚本
在keepalived从节点创建一个检查nginx状态脚本
[root@centos17keepalived]#vim check_nginx.sh
#!/bin/bash
killall -0 nginx &> /dev/null || exit 1 检查此时的nginx服务进程是否正常,如果非0(死机),就会执行退出显示1。
[root@centos17]#chmod +x check_nginx.sh 添加执行权限
当keepalived服务器宕机时,在keepalived从节点创建一个降优先级脚本。
[root@centos17keepalived]#vim test.sh
#!/bin/bash
[ -f /etc/keepalived/down ] && exit 1 || exit 0 判断/etc/keepalived/目录下是否有down文件,如果有就返回1,没有就返回0 [root@centos17keepalived]#chmod +x test.sh 加上执行权限
此时nginx从节点服务器变成主节点。
创建完成之后加上执行权限,实现脚本如下:
[root@centos17keepalived]#vim notify.sh
#!/bin/bash
contact='root@localhost'
notify() {
mailsubject="$(hostname) to be $1, vip floating"
mailbody="$(date +'%F %T'): vrrp transition, $(hostname) changed to be $1"
echo "$mailbody" | mail -s "$mailsubject" $contact
}
case $1 in
master)
notify master
;;
backup)
notify backup
systemctl restart nginx
;;
fault)
notify fault
;;
*)
echo "Usage: $(basename $0) {master|backup|fault}"
exit 1
;;
esac
后端http服务器上创建网页
在两个后端服务器上创建网页,作为测试效果使用。
[root@cenots47~]#yum install httpd -y
[root@cenots47~]#echo 192.168.37.47 > /var/www/html/index.html
[root@cenots47~]#systemctl start httpd
[root@cenots37~]#yum install httpd -y
[root@cenots37~]#echo 192.168.37.37 > /var/www/html/index.html
[root@cenots37~]#systemctl start httpd
客户端验证效果
在客户端修改hosts配置文件,并测试效果,如果主keepalived服务器宕机了,VIP地址就会漂移到从节点上去,继续运行nginx服务,不会影响用户访问效果。
vim /etc/hosts
[root@centos7network-scripts]#while true;do curl 192.168.37.100;sleep 0.5;done
192.168.37.47
192.168.37.47
192.168.37.37
192.168.37.47
192.168.37.37
当主节点的nginx服务器死机了,此时的VIP地址会临时漂移到从节点上,当脚本检测到主节点的nginx服务死机后,就会重新启动nginx服务,将VIP地址就会从从节点服务器抢过来,继续作为主节点为客户端进行服务。
测试如下:
1、杀掉主节点的nginx服务
[root@centos17keepalived]#killall nginx
2、在http后端服务器上监控多播地址,此时可以看到主节点的优先级由100降到70,然后从节点的优先级80进行为客户端提供服务,由于有脚本检测主节点返回了backup,就会重新启动nginx,此时主节点就又会将优先级变回100,将从节点的服务抢占回来。
3、在客户端进行查看效果,当主节点的nginx死机后,重启nginx后就会又为客户端进行服务。
keepalived实现nginx反向代理的高可用的更多相关文章
- haproxy+keepalived配置haproxy反向代理的高可用
http://www.cnblogs.com/shantu/p/4586277.html
- Keepalived+LVS+Nginx负载均衡之高可用
Keepalived+LVS+Nginx负载均衡之高可用 上一篇写了nginx负载均衡,此篇实现高可用(HA).系统整体设计是采用Nginx做负载均衡,若出现Nginx单机故障,则导致整个系统无法正常 ...
- Net分布式系统之三:Keepalived+LVS+Nginx负载均衡之高可用
上一篇写了nginx负载均衡,此篇实现高可用(HA).系统整体设计是采用Nginx做负载均衡,若出现Nginx单机故障,则导致整个系统无法正常运行.针对系统架构设计的高可用要求,我们需要解决Nginx ...
- Nginx反向代理,负载均衡,redis session共享,keepalived高可用
相关知识自行搜索,直接上干货... 使用的资源: nginx主服务器一台,nginx备服务器一台,使用keepalived进行宕机切换. tomcat服务器两台,由nginx进行反向代理和负载均衡,此 ...
- Keepalived+Nginx实现负载均衡高可用
一.负载均衡高可用 Nginx作为负载均衡器,所有请求都到了Nginx,可见Nginx处于非常重点的位置,如果Nginx服务器宕机后端web服务将无法提供服务,影响严重. 为了避免负载均衡服务器的宕机 ...
- suse 12 编译部署Keepalived + nginx 为 kube-apiserver 提供高可用
文章目录 编译部署nginx 下载nginx源码包 编译nginx 配置nginx.conf 配置nginx为systemctl管理 分发nginx二进制文件和配置文件 启动kube-nginx服务 ...
- Linux系统——Nginx反向代理与负载均衡
集群集群是指一组(若干个)相互独立的计算机,利用高速通信网路组成的一个较大的计算机服务系统,每个集群节点(即集群中的每台计算机)都是运用各自服务的独立服务器.这些服务器之间可以彼此通信,协同向用户提供 ...
- LVS和nginx反向代理网站架构
LVS和nginx反向代理网站架构 nginx反向代理和lvs的dr都存在单点,要keepalived做高可用,但是成本高了 f
- Linux实战教学笔记30:Nginx反向代理与负载均衡应用实践
1.1 集群简介 简单地说,集群就是指一组(若干个)相互独立的计算机,利用高速通信网络组成的一个较大的计算机服务系统,每个集群节点(即集群中的每台计算机)都是运行各自服务的独立服务器.这些服务器之间可 ...
随机推荐
- 一秒解决CentOS下service 功能 不能使用 bash: service: command not found
首先检查自己是否 使用的是root用户 如果是并且还不能用-----执行以下操作 在centos系统中,如果/sbin目录下没有service这个命令,就会出现 bash: service: comm ...
- mysql查询之上升的温度,有趣的电影,超过5名学生的课,大国,反转性别, 换座位
最近发现一个网站 力扣 查看 上面有很多算法和数据库的题目,做了一下,发现自己平时都疏忽了,因此边做边记录下来 1.上升的温度 给定一个 Weather 表,编写一个 SQL 查询,来查找与之前(昨天 ...
- Harbor密码重置 密码修改 admin密码重置
Harbor密码重置harbor现在是使用postgresql 数据库了.不再支持mysql,网上有N多重置Mysql密码的,可以略过了.我密码错了默认的Harbor12345 修改为: RedHat ...
- 利用function和bind实现回调功能
介绍一种利用function和bind来实现回调的功能. C++参考手册中对function的介绍: std::function的实例能存储.复制及调用任何可调用的目标,包括:函数.lambda表达式 ...
- 最新 识装java校招面经 (含整理过的面试题大全)
从6月到10月,经过4个月努力和坚持,自己有幸拿到了网易雷火.京东.去哪儿. 识装等10家互联网公司的校招Offer,因为某些自身原因最终选择了 识装.6.7月主要是做系统复习.项目复盘.LeetCo ...
- TCP/IP学习笔记4--网络地址
"他强由他强,清风拂山岗.他横由他横,明月照大江.世间诸事,敞开心扉,顺其自然." -- 张大千 地址具有两个特性: 1:唯一性 同一个通信网络中的任意两个通信主体不能具有相同的地 ...
- c++模板使用及常见问题
一.为什么使用模板?? 使用模板的目的是为了避免重复声明和定义一系列基本功能相同的函数或者类,其区别因传入参数的不同而产生不同类型的数据,其基本工作过程都是一致的! 二.调用模板函数产生不明确问题 ( ...
- 【Qt开发】菜单栏,工具栏和状态栏
概述 菜单栏,工具栏,状态栏应用中经常见到,下图解释一目了然,实际开发中 两种方式来实现,一种是使用纯代码QMenuBar,QToolBar,QStatusBar来设计开发,另一种使用Qt Desig ...
- machine learning相关会议
1. ICML(International Conference on Machine Learning) 链接:https://en.wikipedia.org/wiki/Internation ...
- JAVA day1 基础知识
一.windows命令 dir:查看文件 cd:打开文件 二.java的编译和运行 编译: javac 源文件名 一个类编译后会对应一个.class文件 运行: java 类名 三.类 一个源文件内可 ...