NGINX集群+KeepLived实现高可用

5.1 为什么要使用Nginx要搭建集群?

解决单点故障问题

5.2 Keepalived有何作用?

Keepalived帮助我们监测每台nginx是否正常运行,

5.3 客户端发送访问问题

如果搭建了Nginx集群,并使用Keepalived监听,这时候客户端要发送请求给nginx,到底发送给哪台nginx呢?

这时候就需要一个虚拟ip,客户端把所有请求都访问这个虚拟ip,再由Keepalived决定请求到哪台Nginx服务器上!

5.4 Nginx+Keeplived配置实操

环境准备:

192.168.0.221:nginx + keepalived master

192.168.0.222:nginx + keepalived backup

192.168.0.223:tomcat

192.168.0.224:tomcat

虚拟ip(VIP):192.168.0.200,对外提供服务的ip,也可称作浮动ip

各个组件之间的关系图如下:

tomcat做应用服务器

tomcat的安装不在本博客范围之内,tomcat的webapps下记得放自己的应用,我的是myWeb,如果大家也用我的myWeb,那么index.jsp中的ip需要换成自己的

将192.168.0.223、192.168.0.224上的tomcat启动起来,tomcat的路径可能和我的不一致,需要写成自己的

 # cd /usr/local/tomcat7/bin# ./startup.sh

访问myWeb如下

NGINX做负载均衡:

nginx的安装,本文就不讲述了,具体可参考我的另一篇文章 传送门

nginx.conf内容如下

user  root;            #运行用户
worker_processes  1;        #启动进程,通常设置成和cpu的数量相等#全局错误日志及PID文件
error_log  /usr/local/nginx/logs/error.log;
error_log  /usr/local/nginx/logs/error.log  notice;
error_log  /usr/local/nginx/logs/error.log  info;
pid        /usr/local/nginx/logs/nginx.pid;# 工作模式及连接数上线
events
{use epoll;            #epoll是多路复用IO(I/O Multiplexing)中的一种方式,但是仅用于linux2.6以上内核,可以大大提高nginx的性能worker_connections  1024;    #单个后台worker process进程的最大并发链接数
}#设定http服务器,利用它的反向代理功能提供负载均衡支持
http
{include       mime.types;default_type  application/octet-stream;#设定请求缓冲server_names_hash_bucket_size  128;client_header_buffer_size   32K;large_client_header_buffers  4 32k;# client_max_body_size   8m;#sendfile 指令指定 nginx 是否调用 sendfile 函数(zero copy 方式)来输出文件,对于普通应用,#必须设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为 off,以平衡磁盘与网络I/O处理速度,降低系统的uptime.sendfile        on;tcp_nopush     on;tcp_nodelay    on;#连接超时时间keepalive_timeout  65;#开启gzip压缩,降低传输流量gzip  on;gzip_min_length    1k;gzip_buffers    4 16k;gzip_http_version  1.1;gzip_comp_level  2;gzip_types  text/plain application/x-javascript text/css  application/xml;gzip_vary on;#添加tomcat列表,真实应用服务器都放在这upstream tomcat_pool {#server tomcat地址:端口号 weight表示权值,权值越大,被分配的几率越大;    server 192.168.0.223:8080 weight=4 max_fails=2 fail_timeout=30s;server 192.168.0.224:8080 weight=4 max_fails=2 fail_timeout=30s;}server {listen       80;        #监听端口    server_name  localhost;#默认请求设置location / {proxy_pass http://tomcat_pool;    #转向tomcat处理}#所有的jsp页面均由tomcat处理location ~ \.(jsp|jspx|dp)?${proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_pass http://tomcat_pool;    #转向tomcat处理}#所有的静态文件直接读取不经过tomcat,nginx自己处理location ~ .*\.(htm|html|gif|jpg|jpeg|png|bmp|swf|ioc|rar|zip|txt|flv|mid|doc|ppt|pdf|xls|mp3|wma)$ { expires  30d;}location ~ .*\.(js|css)?${expires  1h;}#定义错误提示页面error_page   500 502 503 504  /50x.html;location = /50x.html {root   html;}}
}

主从nginx的配置文件完全一样,nginx.conf配置可复杂可简单,大家根据自己的情况自行配置,照搬上述配置也是可以的。

配置好后,启动nginx,路径要写自己的

# cd /usr/local/nginx/sbin# ./nginx

访问nginx,效果如下:


两台nginx服务器服务正常,此时是没有主从之分的,两者级别一样高,当配置keepalived之后就有了主从之分了。

keepalived实现nginx高可用(HA):

keepalived的安装本文就不讲述了,

keepalived作用其实在第一张图中已经有所体现,主要起到两个作用:实现VIP到本地ip的映射; 以及检测nginx状态。

master上的keepalived.conf内容如下:

global_defs {notification_email {997914490@qq.com}notification_email_from sns-lvs@gmail.comsmtp_server smtp.hysec.comsmtp_connection_timeout 30router_id nginx_master        # 设置nginx master的id,在一个网络应该是唯一的
}
vrrp_script chk_http_port {script "/usr/local/src/check_nginx_pid.sh"    #最后手动执行下此脚本,以确保此脚本能够正常执行interval 2                          #(检测脚本执行的间隔,单位是秒)weight 2
}
vrrp_instance VI_1 {state MASTER            # 指定keepalived的角色,MASTER为主,BACKUP为备interface eth0            # 当前进行vrrp通讯的网络接口卡(当前centos的网卡)virtual_router_id 66        # 虚拟路由编号,主从要一直priority 100            # 优先级,数值越大,获取处理请求的优先级越高advert_int 1            # 检查间隔,默认为1s(vrrp组播周期秒数)authentication {auth_type PASSauth_pass 1111}track_script {chk_http_port            #(调用检测脚本)}virtual_ipaddress {192.168.0.200            # 定义虚拟ip(VIP),可多设,每行一个}
}

backup上的keepalived.conf内容如下:

global_defs {notification_email {997914490@qq.com}notification_email_from sns-lvs@gmail.comsmtp_server smtp.hysec.comsmtp_connection_timeout 30router_id nginx_backup              # 设置nginx backup的id,在一个网络应该是唯一的
}
vrrp_script chk_http_port {script "/usr/local/src/check_nginx_pid.sh"interval 2                          #(检测脚本执行的间隔)weight 2
}
vrrp_instance VI_1 {state BACKUP                        # 指定keepalived的角色,MASTER为主,BACKUP为备interface eth0                      # 当前进行vrrp通讯的网络接口卡(当前centos的网卡)virtual_router_id 66                # 虚拟路由编号,主从要一直priority 99                         # 优先级,数值越大,获取处理请求的优先级越高advert_int 1                        # 检查间隔,默认为1s(vrrp组播周期秒数)authentication {auth_type PASSauth_pass 1111}track_script {chk_http_port                   #(调用检测脚本)}virtual_ipaddress {192.168.0.200                   # 定义虚拟ip(VIP),可多设,每行一个}
}

nginx检测脚本check_nginx_pid.sh内容如下:

#!/bin/bash
A=`ps -C nginx --no-header |wc -l`
if [ $A -eq 0 ];then                            /usr/local/nginx/sbin/nginx                #重启nginxif [ `ps -C nginx --no-header |wc -l` -eq 0 ];then    #nginx重启失败exit 1elseexit 0fi
elseexit 0
fi

启动keepalived

service keepalived start

访问VIP,效果如下:

我们来看下keepalived的日志信息

master(192.168.0.221):

backup(192.168.0.222):


当我们把master上的keepalived停掉(模拟宕机),再来看下keepalived日志

原master(192.168.0.221):

原backup(192.168.0.222):

通过VIP可以正常访问服务,前端请求感受不到后端nginx的切换;重新唤醒原master(192.168.0.221)的测试这里就不进行了,大家自行测试


注意事项:

1.执行脚本时报错:/bin/sh^M: bad interpreter: 没有那个文件或目录

因为操作系统是windows,我在windows下编辑的脚本,所以有可能有不可见字符。脚本文件是DOS格式的, 即每一行的行尾以回车符和换行符来标识, 其ASCII码分别是0x0D, 0x0A。可以有很多种办法看这个文件是DOS格式的还是UNIX格式的, 还是MAC格式的

解决方法:

 vim filename:set ff? #可以看到dos或unix的字样. 如果的确是dos格式的。:set ff=unix #把它强制为unix格式的, 然后存盘退出。再次运行脚本。

从windows编辑文件再拷贝到linux时要特别注意,另外,脚本需要赋予可执行权限才能执行,可执行文件的一种直观表现就是文件本身呈绿色。

2.负载均衡最好进行多浏览器测试,

有些浏览器会缓存,会产生没有负载均衡的效果,例如我这次测试中谷歌浏览器就出现了类似的情况(还没搞清楚是否是缓存的原因),火狐,360、IE浏览器都是正常的负载均衡效果。

3.请求走向

访问虚拟IP(VIP),keepalived将请求映射到本地nginx,nginx将请求转发至tomcat,例如:http://192.168.0.200/myWeb/,被映射成http://192.168.0.221/myWeb/,端口是80,而221上nginx的端口正好是80;映射到nginx上后,nginx再进行请求的转发。

keepalived服务器的ip情况
   

VIP总会在keepalived服务器中的某一台上,也只会在其中的某一台上;VIP绑定的服务器上的nginx就是master,当VIP所在的服务器宕机了,keepalived会将VIP转移到backup上,并将backup提升为master。

4.VIP也称浮动ip,是公网ip,

与域名进行映射,对外提供服务; 其他ip一般而言都是内网ip, 外部是直接访问不了的

NGINX集群+KeepLived实现高可用相关推荐

  1. Java架构师:单体部署 ->Nginx 集群 -> + Keepalived“高可用”组件 -> + LVS负载均衡

    一.集群阶段开篇概述 1.单体部署 1.1 单台服务器(节点)部署 1.2.多台服务器(节点)部署 集群.分布式.微服务中的各个服务器节点必须互通,必须在同一个局域网(内网要通) 1.3.单体架构的优 ...

  2. 在Kubernetes集群上部署高可用Harbor镜像仓库

    这里主要介绍使用kubectl部署Harbor镜像仓库到Kubernetes集群中. 使用Helm部署,参考: https://my.oschina.net/u/2306127/blog/181969 ...

  3. k8s和harbor的集成_在Kubernetes集群上部署高可用Harbor镜像仓库

    在Kubernetes集群上部署高可用Harbor镜像仓库 一.Kubernetes上的高可用Harbor方案 首先,我可以肯定给出一个回答:Harbor支持在Kubernetes部署.只不过Harb ...

  4. etcd集群搭建(高可用)

    一.etcd介绍: ETCD 是一个高可用的分布式键值数据库,可用于服务发现.ETCD 采用 raft 一致性算法,基于 Go 语言实现.etcd作为一个高可用键值存储系统,天生就是为集群化而设计的. ...

  5. linux高可集群用软件,Linux集群概述及高可用软件keepalived配置、测试

    一.Linux集群概述 1). 根据功能划分为两大类:高可用和负载均衡 高可用集群通 常为两台服务器,一台工作,另外一台作为冗余,当提供服务的机器宕机,冗余将接替继续提供服务 2).实现高可用的开源软 ...

  6. kubeadm配置k8s-1.13高可用集群(master高可用haproxykeepalive)+kubernetes-dashboard+监控prometheusgrafana

    参考:https://blog.csdn.net/chenleiking/article/details/84841394 本文使用六台虚拟机,配置含有三个master的k8s集群并实现master之 ...

  7. linux集群架构(一),集群概述、高可用配置

    2019独角兽企业重金招聘Python工程师标准>>> linux集群概述 根据功能划分为两大类:高可用和负载均衡 高可用集群通常为两台服务器,一台工作,另外一台作为冗余,当提供服务 ...

  8. Kubernetes容器集群 - harbor仓库高可用集群部署说明

    之前介绍Harbor私有仓库的安装和使用,这里重点说下Harbor高可用集群方案的部署,目前主要有两种主流的Harbor高可用集群方案:1)双主复制:2)多harbor实例共享后端存储. 一.Harb ...

  9. 架构师之路 — 部署架构 — 高可用集群 — N+1 高可用模型

    目录 文章目录 目录 前言 高可用集群架构 高可用集群模型模型 N+1 模型 N+1 模型关键技术 单进程多定时器的设计 冗余节点快速切换技术 服务器池多级检测机制 前言 本地是对论文<服务器池 ...

  10. Docker 搭建pxc集群 + haproxy + keepalived 高可用(二)

    上一节我们有了两个分片的pxc集群,这一节我们接着安装haproxy和keepalived的实现集群的高可用 一.先下载haproxy的镜像 [root@localhost ~]# docker pu ...

最新文章

  1. R语言构建xgboost模型:特征重要度计算及解读、改善特征重要度数据的可解释性、特征重要度可视化
  2. 又一个jquery+flash上传插件
  3. JAVA15.JDK15.6 Record二次预览特性
  4. Server error for SAP CRM_BUPA_ODATA
  5. bzoj2878 [Noi2012]迷失游乐园——概率期望DP
  6. icp光谱仪的工作原理_创想仪器(GLMY)光电直读光谱仪和X荧光光谱仪的区别
  7. redhat8安装mysql教程
  8. 《Java从入门到放弃》JavaSE入门篇:单元测试
  9. vega56刷64_Vega56显卡怎么刷Bios VEGA56显卡刷Vega64方法
  10. Codeforces Gym 100015A Another Rock-Paper-Scissors Problem 找规律
  11. 桌面点右键,白屏怎么办
  12. 介绍几种 Windows10 自带的截图方式
  13. C++ 获取特定进程的CPU使用率
  14. win7网络上计算机进不去,Win7电脑开机进不了系统怎么办?
  15. 卷积神经网络分类实战
  16. matlab 运算符
  17. iphone手机safari浏览器访问网站滚动条不显示问题解决办法
  18. 成都榆熙:商家怎样提升店铺自然流量?
  19. 每年六一儿童节,牛客都会准备一些小礼物去看望孤儿院的小朋友,今年亦是如此。HF作为牛客的资深元老,自然也准备了一些小游戏。其中,有个游戏是这样的:首先,让小朋友们围成一个大圈。然后,他随机指定一个数m
  20. docker基础总结

热门文章

  1. 电子商务信息整合平台方案
  2. 网上购物系统数据库分析
  3. chrome浏览器安装印象笔记插件
  4. 山东大学高频电子线路实验五 混频器实验详解
  5. loadRunner12压力测试工具使用流程
  6. SQL安装步骤及可能遇到的错误
  7. office出错怎么简单修复
  8. 使用梦网云通讯平台解决手机验证码问题
  9. php 省份的缩写,34个省级行政区记忆口诀、省份简称和省会城市表
  10. 【Chapter 1】什么是软件架构