Nginx负载均衡 - keepalived

2024-08-22 21:38
文章标签 nginx 负载 均衡 keepalived

本文主要是介绍Nginx负载均衡 - keepalived,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

常用的负载均衡

1.HTTP重定向

http请求进行转移,在web开发中我们经常会用它来完成自动跳转,比如用户登陆成功过后跳转到相应的管理页面,这种重定向完全由Http定义,并且由Http代理和web服务器共同实现。
备注:http重定向具备了请求转移和自动跳转的本领,所以除了满足应用程序需要的自动跳转之外,它还可以用于实现负载均衡,以达到web扩展的目的。

2.DNS负载均衡 (轮询机制)

DNS 负责提供域名解析服务,当我们访问某个站点时,实际上首先需要通过该站点域名的DNS服务器来获取域名指向的IP地址,在这个过程中,DNS服务器便充当了负载均衡调度器(也称均衡器),它就像前面提到的重定向转移策略一样,将用户的请求分散到多台服务器上,但是它的实现机制完全不同

3.反向代理负载均衡

反向代理服务器的核心工作便是转发HTTP请求,因此它工作在HTTP层面,也就是TCP七层结构中的应用层(第七层),所以基于反向代理的负载均衡也称为七层负载均衡,实现它并不困难,目前几乎所有主流的web服务器都热衷于支持基于反向代理的负载均衡。

4.IP负载均衡

事实上,在数据链路层(第二层)、网络层(第三层)以及传输层(四层)都可以实现不同机制的负载均衡,但有所不同的是,这些负载均衡调度器的工作必须由linux内核来王城,因为我们希望网络数据包在从内核进入缓冲区进入进程用户地址空间之前,尽早的被转发到其他的实际服务器上,而linux中位于内核的NetfilterIPVS可以解决问题,而用户空间的应用程序对此却束手无策。另一方面,也正是因为可以调度器工作在应用层一下,这些负载均衡系统可以支持更多的网络服务器协议

一般做法会使用DNS负载均衡(DNS轮训机制)+nginx负载均衡


开始部署负载均衡  -  首先部署Master服务器


1.下载keepalived

wget http://www.keepalived.org/software/keepalived-1.2.7.tar.gz
tar zxf keepalived-1.2.7.tar.gz

2.安装依赖包

yum -y install gcc pcre-devel zlib-devel openssl-devel
yum -y install popt-devel

3.执行keepalived中的configure文件

cd keepalived-1.2.7
./configure
make
make install

4.迁移文件

cp /usr/local/etc/rc.d/init.d/keepalived /etc/rc.d/init.d/
cp /usr/local/etc/sysconfig/keepalived /etc/sysconfig/
mkdir /etc/keepalived
cp /usr/local/etc/keepalived/keepalived.conf /etc/keepalived/
cp /usr/local/sbin/keepalived /usr/sbin/

5.加入启动服务 使得开机自启动

echo "/usr/local/nginx/sbin/nginx" >> /etc/rc.localecho "/etc/init.d/keepalived start" >> /etc/rc.local

6.配置Nginx

http {include       mime.types;default_type  application/octet-stream;sendfile        on;upstream opslinux.com {ip_hash;server 192.168.1.249:80server 192.168.1.250:80server 192.168.1.251:80}server {listen       80;location / {proxy_pass http://opslinux.com;}
}

7.配置keepalived.conf文件

vi /etc/keepalived/keepalived.conf

global_defs {router_id NGINX_UPSTEAM 
}#实例
vrrp_instance VI_1 {state MASTER          	#主服务 interface eth0	     	#网卡接口名称virtual_router_id 51	#虚拟路由idpriority 100			#优先级advert_int 1			authentication {auth_type PASSauth_pass 1111}
#虚拟 ipvirtual_ipaddress {192.168.0.100}
}

8.开启keepalived :

service keepalived start

9.查看虚拟IP是否绑定在服务器上

ip add

10.监控nginx状态

  • 最简单的做法是监控NginX进程,更靠谱的做法是检查NginX端口,最靠谱的做法是检查多个url能否获取到页面。
如何尝试恢复服务
  • 如果发现NginX不正常,重启之。等待3秒再次校验,仍然失败则不再尝试。
  • 根据上述策略很容易写出监控脚本。这里使用nmap检查nginx端口来判断nginx的状态,记得要首先安装nmap。监控脚本如下:
#!/bin/bash
# check nginx server status
NGINX=/usr/local/nginx/sbin/nginx
PORT=8080nmap localhost -p $PORT | grep "$PORT/tcp open"
#echo $?
if [ $? -ne 0 ];then$NGINX -s stop$NGINXsleep 3nmap localhost -p $PORT | grep "$PORT/tcp open"[ $? -ne 0 ] && /etc/init.d/keepalived stop
fi

不要忘了设置脚本的执行权限,否则不起作用。

11.在keepalived.conf中新增下列代码

vrrp_script chk_http_port { script "/opt/chk_nginx.sh"interval 1weight -2
}track_script {chk_http_port
}

12.为了避免 keepalived 在启动之前 nginx没有启动

所有我们要在 /etc/init.d/keepalived的 start中 先启动nginx

start() {/usr/local/nginx/sbin/nginxsleep 3echo -n $"Starting $prog: "daemon keepalived ${KEEPALIVED_OPTIONS}RETVAL=$?echo[ $RETVAL -eq 0 ] && touch /var/lock/subsys/$prog
}

备注:此处需要关闭ip防火墙 否则会造成nginx通信问题,导致多台主机认为自己是master,虚拟ip绑定在每个主机上

命令:service iptables stop

这样我们的master服务就部署完毕了,接着我们开始部署backup服务器【backup的部署与master的部署很相似,本来要分开成两篇的。。。】


1.下载keepalived

wget http://www.keepalived.org/software/keepalived-1.2.7.tar.gz
tar zxf keepalived-1.2.7.tar.gz

2.安装依赖包

yum -y install gcc pcre-devel zlib-devel openssl-devel
yum -y install popt-devel

3.执行keepalived中的configure文件

cd keepalived-1.2.7
./configure
make
make install

4.迁移文件

cp /usr/local/etc/rc.d/init.d/keepalived /etc/rc.d/init.d/
cp /usr/local/etc/sysconfig/keepalived /etc/sysconfig/
mkdir /etc/keepalived
cp /usr/local/etc/keepalived/keepalived.conf /etc/keepalived/
cp /usr/local/sbin/keepalived /usr/sbin/

5.配置keepalived.conf文件

vi /etc/keepalived/keepalived.conf

global_defs {router_id NGINX_DEVEL
}#实例
vrrp_instance VI_1 {state BACKUP        	#主服务 interface eth0	     	#网卡接口名称virtual_router_id 51	#虚拟路由idpriority 99		#优先级advert_int 1			authentication {auth_type PASSauth_pass 1111}
#虚拟 ipvirtual_ipaddress {192.168.0.100}
}

若有多台主机则需要添加MASTER服务器中的 8,9,10,11,12,的操作要在其他的backup服务器中添加






这篇关于Nginx负载均衡 - keepalived的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1097465

相关文章

使用Nginx来共享文件的详细教程

《使用Nginx来共享文件的详细教程》有时我们想共享电脑上的某些文件,一个比较方便的做法是,开一个HTTP服务,指向文件所在的目录,这次我们用nginx来实现这个需求,本文将通过代码示例一步步教你使用... 在本教程中,我们将向您展示如何使用开源 Web 服务器 Nginx 设置文件共享服务器步骤 0 —

一文带你搞懂Nginx中的配置文件

《一文带你搞懂Nginx中的配置文件》Nginx(发音为“engine-x”)是一款高性能的Web服务器、反向代理服务器和负载均衡器,广泛应用于全球各类网站和应用中,下面就跟随小编一起来了解下如何... 目录摘要一、Nginx 配置文件结构概述二、全局配置(Global Configuration)1. w

若依部署Nginx和Tomcat全过程

《若依部署Nginx和Tomcat全过程》文章总结了两种部署方法:Nginx部署和Tomcat部署,Nginx部署包括打包、将dist文件拉到指定目录、配置nginx.conf等步骤,Tomcat部署... 目录Nginx部署后端部署Tomcat部署出现问题:点击刷新404总结Nginx部署第一步:打包

Nginx、Tomcat等项目部署问题以及解决流程

《Nginx、Tomcat等项目部署问题以及解决流程》本文总结了项目部署中常见的four类问题及其解决方法:Nginx未按预期显示结果、端口未开启、日志分析的重要性以及开发环境与生产环境运行结果不一致... 目录前言1. Nginx部署后未按预期显示结果1.1 查看Nginx的启动情况1.2 解决启动失败的

tomcat在nginx中的配置方式

《tomcat在nginx中的配置方式》文章介绍了如何在Linux系统上安装和配置Tomcat,并通过Nginx进行代理,首先,下载并解压Tomcat压缩包,然后启动Tomcat并查看日志,接着,配置... 目录一、下载安装tomcat二、启动tomcat三、配置nginx总结提示:文章写完后,目录可以自动

Hadoop集群数据均衡之磁盘间数据均衡

生产环境,由于硬盘空间不足,往往需要增加一块硬盘。刚加载的硬盘没有数据时,可以执行磁盘数据均衡命令。(Hadoop3.x新特性) plan后面带的节点的名字必须是已经存在的,并且是需要均衡的节点。 如果节点不存在,会报如下错误: 如果节点只有一个硬盘的话,不会创建均衡计划: (1)生成均衡计划 hdfs diskbalancer -plan hadoop102 (2)执行均衡计划 hd

Windows下Nginx的安装及开机启动

1、将nginx-1.16.1.zip解压拷贝至D:\web\nginx目录下。 2、启动Nginx,两种方法: (1)直接双击nginx.exe,双击后一个黑色的弹窗一闪而过。 (2)打开cmd命令窗口,切换到nginx目录下,输入命令 nginx.exe 或者 start nginx ,回车即可。 3、检查nginx是否启动成功。 直接在浏览器地址栏输入网址 http://lo

nginx介绍及常用功能

什么是nginx nginx跟Apache一样,是一个web服务器(网站服务器),通过HTTP协议提供各种网络服务。 Apache:重量级的,不支持高并发的服务器。在Apache上运行数以万计的并发访问,会导致服务器消耗大量内存。操作系统对其进行进程或线程间的切换也消耗了大量的CPU资源,导致HTTP请求的平均响应速度降低。这些都决定了Apache不可能成为高性能WEB服务器  nginx:

web群集--nginx配置文件location匹配符的优先级顺序详解及验证

文章目录 前言优先级顺序优先级顺序(详解)1. 精确匹配(Exact Match)2. 正则表达式匹配(Regex Match)3. 前缀匹配(Prefix Match) 匹配规则的综合应用验证优先级 前言 location的作用 在 NGINX 中,location 指令用于定义如何处理特定的请求 URI。由于网站往往需要不同的处理方式来适应各种请求,NGINX 提供了多种匹

nginx长连接的问题

转自: http://www.360doc.com/content/12/1108/17/1073512_246644318.shtml