Nginx搭建负载均衡集群的实现_nginx

来源:脚本之家  责任编辑:小易  

通过设置特定的策略,使nginx将请求按策略分配到不同的后端服务器一般可以使用IP分流、服务器压

(1).实验环境

合理啊 我是做软件测试的,现在我测试的平台就是这样搞得 keepalived+nginx 指向后端服

youxi1  192.168.5.101  负载均衡器

常见的有LVS、Nginx和HAProxy,者者介绍分别如下:LVS:使用集群技术和Linux操作

youxi2  192.168.5.102  主机1

该文章来源于互联网,目前找不到原作者,放在这里的目的是记录healthcheck_nginx_ups

youxi3  192.168.5.103  主机2

nginx和haproxy一样也可以做前端请求分发实现负载均衡效果,比如一个tomcat服务如果并发

(2).Nginx负载均衡策略

曾轶可:皮肤确实不错,还是化妆看着舒服周迅:素颜时的自然清新,也同样动人赵丽颖:依旧的娃娃脸,可爱哩姚笛:美虽美,但是小编我也不是很喜欢了张馨予:还可以吧杨幂:眼睛还是又大又亮,鼻子也很挺王珞丹:看来发型很重要章子怡:不愧是汪峰的女神宋茜:好深的眼袋唐嫣:糖糖要幸福呢

  nginx的负载均衡用于upstream模板定义的后端服务器列表中选取一台服务器接收用户的请求。一个基本的upstream模块如下:

首先我们要先明确两点:一、华为不是专门卖手机的。二、华为的收入有一半多来自海外。而腾讯有约95%的业务分布在国内。华为就算是手机的中国市场不要了,华为也能活下来。与手机制造商相比,华为更乐意被称作通信运营商。2016年华为营业收入5200亿元,三大业务:消费者业务、运营商业务和企业业务收入占比分别是:34.5%、55.7%和7.8%。运营商业务才是为华为贡献收入最多的业务。三大业务消费者业务就是卖华为各种手机产品,以及电子产品。2016年收入1798.08亿元,华为手机销量去年销量为1.39亿台,出现了不错的增长。但是却不是华为最主要的业务。运营商业务主要是为世界各地通信运营商提供硬件设备和软

upstream [服务器组名称]{   server [IP地址]:[端口号];   server [IP地址]:[端口号];   .... }

我认为他们是来搞笑的。换上德牧也比哈士奇有震慑力!在很多人的心目中,绰号“撒手没”(撒手就跑没影了)和“井犬”(横竖都很二)的哈士奇,长着一张认真的脸,常常搞破坏装无辜,但是也因为动不动就侧头歪舌头卖萌装傻深得人心。一般来说,具备巡逻功能的狗狗都要有护卫犬的性格。护卫犬领地意识强烈,对陌生人警惕,具有一定的攻击性和杀伤力。哈士奇最好是拉雪橇,它有很强的耐力、超强的食物吸收转化能力和比较强的耐寒能力。如果真的遇到坏人了,它可能还会冲上去摇尾巴,从而变成人质。‘二哈’这名字,绝非‘浪得虚名’。

  在upstream模块配置完成后,要让指定的访问反向代理到服务器列表,格式如下:

这篇文给题主借鉴一下怎样去除淋浴房玻璃上的水渍淋浴房如何清理我们都知道,淋浴房的主要构造是玻璃以及五金配件,玻璃看着透亮有光泽,但其实卫浴间的玻璃很容易聚集污渍,长此以往顽固污渍集聚就很难去除了。注意钢化玻璃不可以用坚硬的物体刮划,以免危及玻璃的安全性。淋浴房玻璃在于日常的清理,每次洗完后都能随手清洁一下,才能保证淋浴房的长久亮丽。那么怎样去除淋浴房玻璃上的水渍呢,淋浴房如何清理呢?来了解下吧。怎样去除淋浴房玻璃上的水渍:1、将少许洗发水倒入脸盆内,搅和均匀后,用抹布蘸取,这样能使玻璃门格外干净明亮。2、在玻璃门上事先涂上粉笔灰水或者石膏粉,待玻璃干燥后,直接用干抹布擦拭,即可去除污渍,将玻璃

location ~ .*$ {   index index.jsp index.html;   proxy_pass http://[服务器组名称]; }

  扩展:nginx的location配置规则:https://www.zgxue.com/article/182472.htm

  这样就完成了最基本的负载均衡,但是这并不能满足实际需求。目前Nginx的upstream模块支持6种方式的负载均衡策略(算法):轮询(默认方式)、weight(权重方式)、ip_hash(依据ip分配方式)、least_conn(最少连接方式)、fair(第三方提供的响应时间方式)、url_hash(第三方通过的依据URL分配方式)。

 1)轮询

  最基本的配置方法,是upstream模块默认的负载均衡策略。每个请求会按时间顺序平均分配到不同的后端服务器。有如下参数:

fail_timeout 与max_fails结合使用
max_fails 在fail_timeout参数设置的时间内最大失败次数。如果在这个时间内,所有该服务器的请求都失败了,那么认为该服务器停机
fail_time 服务器被认为停机的时长,默认10s(被认为停机的服务器尝试间隔?)
backup 标记该服务器为备用服务器。当主服务器停止时,请求会被发送到它这里
down 标记服务器永久停机

  注意:1.down标记的服务器会自动剔除;2.缺省就是轮询;3.此策略适合服务器配置无状态且短平块的服务使用

 2)weight

  权重方式,在轮询策略的基础上指定轮询的几率。也可以认为是在轮询的基础上新增了一个weight的参数,此参数指定轮询的几率,值为number。upstream模块配置模板如下:

upstream [服务器组名称]{   server [IP地址]:[端口号] weight=2;   server [IP地址]:[端口号];   .... }

  在该例子中,没有weight参数的服务器默认为1,weight的数值与访问比例成正比,所有weight值的总和为一个循环单位,服务器自身的weight值为循环单位内的轮询次数。

  注意:1.权重越高分配到的请求越多;2.此策略可以和least_conn策略、iphash策略结合使用;3.此策略比较适合服务器硬件配置差距较大的情况。

 3)ip_hash

  依据ip分配方式,指定负载均衡器按照基于客户端IP的分配方式,这个方法确保了相同的客户端请求一致发送到相同的服务器,以保证session会话。这样每个访客都固定访问一个后端服务器,可以解决session不能跨服务器的问题。upstream模块配置模板如下:

upstream [服务器组名称]{   ip_hash;   server [IP地址]:[端口号] weight=2;   server [IP地址]:[端口号];   .... }

  注意:1.nginx1.3.1之前的版本不能在ip_hash中使用权重(weight);2..ip_hash不能与backup同时使用;3.此策略适合有状态服务的程序,比如session;4.当有服务器需要剔除,必须手动down掉。

 4)least_conn

  最少连接方式,把请求发给链接数最少的后端服务器。轮询是把请求平均分配给各个后端,使它们的负载大致相同。但是,有些请求占用的时间很长,会导致其所在的后端负载较高。这种情况下,least_conn这种方式就可以达到更好的负载均衡效果。upstream模块配置模板如下:

upstream [服务器组名称]{   least_conn;   server [IP地址]:[端口号] weight=2;   server [IP地址]:[端口号];   .... }

  注意:此策略适合请求处理时间长短不一造成的服务器过载情况。

 5)fair

  响应时间方式,按照服务器端的响应时间来分配请求,响应时间短的优先分配。upstream模块配置模板如下:

upstream [服务器组名称]{   server [IP地址]:[端口号] weight=2;   server [IP地址]:[端口号];   ....   fair; }

  注意:需要安装第三方插件。

 6)url_hash

  url分配方式,按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,要配合缓存命中来使用。同一个资源多次请求可能会到达不同的服务器上,导致不必要的多次下载,缓存命中率不高,以及一些资源时间的浪费。而使用url_hash,可以使得同一个url(也就是同一个资源请求)会到达同一台服务器,一旦缓存住了资源,再次收到请求,就可以在缓存中读取。upstream模块配置模板如下:

upstream [服务器组名称]{   hash $request_uri;   server [IP地址]:[端口号] weight=2;   server [IP地址]:[端口号];   .... }

  注意:1.需要安装第三方插件;2.uri,是i,不是小写的L。

(3).实验

 1)在负载均衡器youxi1上编译安装nginx

  安装nginx的依赖包

[root@youxi1 ~]# yum -y install gcc gcc-c++ autoconf automake zlib zlib-devel openssl openssl-devel pcre pcre-devel

  上传nginx源码包nginx-1.14.1.tar.gz,解压安装

[root@youxi1 ~]# tar xf nginx-1.14.1.tar.gz -C /usr/local/src/ [root@youxi1 ~]# cd /usr/local/src/nginx-1.14.1/ [root@youxi1 nginx-1.14.1]# ./configure --prefix=/usr/local/nginx --with-http_dav_module --with-http_stub_status_module --with-http_addition_module --with-http_sub_module --with-http_flv_module --with-http_mp4_module [root@youxi1 nginx-1.14.1]# make && make install [root@youxi1 nginx-1.14.1]# echo $? 0

  参数说明:

    --with-http_dav_module,启用ngx_http_dav_module支持(增加PUT,DELETE,MKCOL:创建集合,COPY和MOVE方法)默认情况下为关闭,需编译开启;

    --with-http_stub_status_module,启用ngx_http_stub_status_module支持(获取nginx自上次启动以来的工作状态);

    --with-http_addition_module,启用ngx_http_addition_module支持(作为一个输出过滤器,支持不完全缓冲,分部分响应请求);

    --with-http_sub_module,启用ngx_http_sub_module支持(允许用一些其他文本替换nginx响应中的一些文本);

    --with-http_flv_module,启用ngx_http_flv_module支持(提供寻求内存使用基于时间的偏移量文件);

    --with-http_mp4_module,启用对mp4文件支持(提供寻求内存使用基于时间的偏移量文件)。

  生成nginx用户

[root@youxi1 nginx-1.14.1]# useradd -M -s /sbin/nologin nginx

  启动并添加开机自启

[root@youxi1 nginx-1.14.1]# /usr/local/nginx/sbin/nginx [root@youxi1 nginx-1.14.1]# echo /usr/local/nginx/sbin/nginx >> /etc/rc.local [root@youxi1 nginx-1.14.1]# chmod +x /etc/rc.d/rc.local

  如果防火墙是开启的记得添加端口号

[root@youxi1 nginx-1.14.1]# firewall-cmd --permanent --zone=public --add-port=80/tcp && firewall-cmd --reload success success

  查看下界面,看看nginx是否正常安装

  测试完成后,修改nginx的配置文件,最后重启nginx

[root@youxi1 nginx-1.14.1]# cp /usr/local/nginx/conf/nginx.conf{,.bak} [root@youxi1 nginx-1.14.1]# vim /usr/local/nginx/conf/nginx.conf user nginx;  //第2行 location / {  //第43行起   root html;   index index.html index.htm;   if ($request_uri ~* \.html$){     proxy_pass http://htmlservers;   }   if ($request_uri ~* \.php$){     proxy_pass http://phpservers;   }   proxy_pass http://picservers; } upstream htmlservers {  //在http模块下,server模块平级处添加   server 192.168.5.102:80;   server 192.168.5.103:80; } upstream phpservers{   server 192.168.5.102:80;   server 192.168.5.103:80; } upstream picservers {   server 192.168.5.102:80;   server 192.168.5.103:80; } [root@youxi1 nginx-1.14.1]# /usr/local/nginx/sbin/nginx -s reload

 2)在youxi2和youxi3上布置网页程序

[root@youxi2 ~]# yum -y install httpd [root@youxi2 ~]# echo youxi2 > /var/www/html/index.html [root@youxi2 ~]# echo youxi2.php > /var/www/html/index.php [root@youxi2 ~]# echo youxi2.other > /var/www/html/index.jsp [root@youxi2 ~]# systemctl start httpd.service [root@youxi3 ~]# yum -y install httpd [root@youxi3 ~]# echo youxi3 > /var/www/html/index.html [root@youxi3 ~]# echo youxi3.php > /var/www/html/index.php [root@youxi3 ~]# echo youxi3.other > /var/www/html/index.jsp [root@youxi3 ~]# systemctl start httpd.service

  如果防火墙是开启的,记得添加端口号

[root@youxi2 ~]# firewall-cmd --permanent --zone=public --add-port=80/tcp && firewall-cmd --reload success success [root@youxi3 ~]# firewall-cmd --permanent --zone=public --add-port=80/tcp && firewall-cmd --reload success success

 3)测试

  首先测试html页面

  接着测试php页面

  最后测试其他页面

参考:https://www.cnblogs.com/1214804270hacker/p/9325150.html

到此这篇关于Nginx搭建负载均衡集群的实现的文章就介绍到这了,更多相关Nginx 负载均衡集群内容请搜索真格学网以前的文章或继续浏览下面的相关文章希望大家以后多多支持真格学网!

扩展阅读,根据您访问的内容系统为您准备了以下内容,希望对您有帮助。

nginx实现tomcat集群的负载均衡有几种方式

一,如果仅是对外提供一个页面访问,不用区分单一用户(不区分每个访问session,不涉及用户权限,用户资料等内容),仅仅配置nginx负载均衡策略即可。

nginx负载均衡策略主要分一下四种:

1)、轮询(默认)

每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器宕机,能自动剔除。

2)、ip_hash 每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器。

3)、fair 按后端服务器的响应时间来分配请求,响应时间短的优先分配。

4)、url_hash 按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效。

二,如果涉及到用户session,做一些鉴权缓存、存放临时信息时,就必须做tomcat的session共享。

目前可参考到的session共享方式主要分为两种。

1)利用tomcat自带的组播机制,实现session复制。

对tomcat及应用的若干配置文件进行配置即可实现,网上有很多资料可参考。但这种方式些弊端,看过一些资料,不建议用session复制的方式。在实际使用过程中,也发现有存在session莫名失踪的现象。

2)利用第三方机制存储session。

比较常见的是tomcat集成memcached服务器来存储session。实际项目中,我们采用过利用redis实现session存储,redis高效的存取性能为高效的访问提供了保障,但是目前redis的集群功能似乎没有发布,如何解决redis的单点故障需要研究。

多个nginx如何分发,达到负载均衡。国内大型网站一般如何实现的?

这方面的资料,基本都是一块一块不完整的。我大概跟你说一个基本架构:

1、DNS服务器,如果资金充足的话,建议使用BGP机房,2-3台DNS服务器均衡,通常使用bind软件。如果资金紧的话,可以购买专业的dns服务,比如国内的dnspod。

2、CDN服务器,一开始如果想省事,可以买专业公司的服务,如chinacache,但随着发展成本会越来越高。自建的话,可能分别搭建,放电信、联通、移动等不同机房的服务器,通过dns做动态解析。超大网站的话,可以用Squid,普通中至大型用nginx,内部玩玩用varnish。

3、前端均衡,资金充足的话,可以使用硬件设备,几十万一台。自已有技术队伍的话,就用nginx/haproxy+keepalived等自已组建前端。均衡的方式都比较灵活,随机、权重、ip、url都有。

4、同步的问题要看同步什么东西,普通的可以实时文件同步。但数据库的话,要看具体类型选择同步方式了。

5、后端的应用服务器和数据库集群,要看流量规划了。追问好像还没有具体的说,如果多台 nginx 如何实现负载均衡。 看你说的意思,是不是就是用DNS和CDN建立多套程序每个程序 使用nginx 做反向代理。 假如考虑到成本等其他原因,不想建立多套系统,就是一个机房或者私有云里面,建立这套系统,实现多个nginx之间的负载均衡,有什么好的办法?追答多台nginx实现均衡,有几种方法:

1、每台nginx都有公网地址,在域名处设置同个域名多个指向,最简单实现轮洵。但故障切负会慢一点。

2、一台公网nginx通过upstream功能,轮洵、ip、url多方式分发到内网多台nginx。但公网的nginx如果down机的话,内网全段。

3、一对公网nginx加三个公网ip,通过keepalive实现高可用,再upstream到内网。

4、一台硬件均衡服务器在前端,再通过硬件均衡到内容的其它服务器。

你所说的那个假如,可以通过 2 、3、 4的方法实现。

集群和负载均衡的区别 nginx

集群和负载均衡的区别如下:

1、集群(Cluster)

所谓集群是指一组独立的计算机系统构成的一个松耦合的多处理器系统,它们之间通过网络实现进程间的通信。应用程序可以通过网络共享内存进行消息传送,实现分布式计算机。

2、负载均衡(Load Balance)

网络的负载均衡是一种动态均衡技术,通过一些工具实时地分析数据包,掌握网络中的数据流量状况,把任务合理均衡地分配出去。这种技术基于现有网络结构,提供了一种扩展服务器带宽和增加服务器吞吐量的廉价有效的方法,加强了网络数据处理能力,提高了网络的灵活性和可用性。

3、特点

(1)高可靠性(HA)。利用集群管理软件,当主服务器故障时,备份服务器能够自动接管主服务器的工作,并及时切换过去,以实现对用户的不间断服务。

(2)高性能计算(HP)。即充分利用集群中的每一台计算机的资源,实现复杂运算的并行处理,通常用于科学计算领域,比如基因分析、化学分析等。

(3)负载平衡。即把负载压力根据某种算法合理分配到集群中的每一台计算机上,以减轻主服务器的压力,降低对主服务器的硬件和软件要求。

LVS系统结构与特点

1. Linux Virtual Server:简称LVS。是由中国一个Linux程序员章文嵩博士发起和领导的,基于Linux系统的服务器集群解决方案,其实现目标是创建一个具有良好的扩展性、高可靠性、高性能和高可用性的体系。许多商业的集群产品,比如RedHat的Piranha、 Turbo Linux公司的Turbo Cluster等,都是基于LVS的核心代码的。

2. 体系结构:使用LVS架设的服务器集群系统从体系结构上看是透明的,最终用户只感觉到一个虚拟服务器。物理服务器之间可以通过高速的 LAN或分布在各地的WAN相连。最前端是负载均衡器,它负责将各种服务请求分发给后面的物理服务器,让整个集群表现得像一个服务于同一IP地址的虚拟服务器。

3. LVS的三种模式工作原理和优缺点: Linux Virtual Server主要是在负载均衡器上实现的,负载均衡器是一台加了 LVS Patch的2.2.x版内核的Linux系统。LVS Patch可以通过重新编译内核的方法加入内核,也可以当作一个动态的模块插入现在的内核中。

nginx实现负载均衡至少需要几台服务器

一般需要三台服务器, 两台nginx做前端,一台后端数据库。

  • 本文相关:
  • nginx+tomcat高性能负载均衡集群搭建教程
  • nginx+tomcat搭建高性能负载均衡集群的实现方法
  • nginx实现集群的负载均衡配置过程解析
  • 详解nginx + tomcat 反向代理 负载均衡 集群 部署指南
  • 采用软件负载均衡器实现web服务器集群(iis+nginx)
  • nginx安装及配置详细分析
  • nginx 的多站点配置方案
  • nginx虚拟主机配置实例详解
  • nginx整合kafka的方法示例
  • linux下nginx 0.8.40的安装方法
  • nginx一个ip如何配置多个站点的方法教程
  • nginx的完整配置详解及实例代码
  • nginx中fastcgi如何配置优化
  • windows下nginx + php5 的安装与配置方法
  • 详解nginx轮询算法底层实现的方法
  • nginx实现tomcat集群的负载均衡有几种方式
  • 多个nginx如何分发,达到负载均衡。国内大型网站一般如何实现的?
  • 集群和负载均衡的区别 nginx
  • nginx实现负载均衡至少需要几台服务器
  • nginx实现负载均衡的方式有哪些
  • nginx是怎么实现负载均衡的
  • centos 7搭建nginx集群
  • nginx负载均衡的算法怎么实现的
  • 集群是用什么方案实现nginx均衡配置
  • web nginx 负载均衡的项目怎么处理
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全星外虚拟主机华众虚拟主机linuxwin服务器ftp服务器dns服务器tomcat nginxzabbix云和虚拟化服务器其它首页服务器nginxnginx+tomcat高性能负载均衡集群搭建教程nginx+tomcat搭建高性能负载均衡集群的实现方法nginx实现集群的负载均衡配置过程解析详解nginx + tomcat 反向代理 负载均衡 集群 部署指南采用软件负载均衡器实现web服务器集群(iis+nginx)nginx安装及配置详细分析nginx 的多站点配置方案nginx虚拟主机配置实例详解nginx整合kafka的方法示例linux下nginx 0.8.40的安装方法nginx一个ip如何配置多个站点的方法教程nginx的完整配置详解及实例代码nginx中fastcgi如何配置优化windows下nginx + php5 的安装与配置方法详解nginx轮询算法底层实现的方法nginx提示:500 internal servernginx 多站点配置方法集合权限问题导致nginx 403 forbiddenginx fastcgi错误primary scripnginx服务器的反向代理proxy_pasnginx 403 forbidden的解决办法nginx伪静态配置和常用rewrite伪nginx下301重定向域名的方法小结详解nginx服务器中配置超时时间的windows下nginx+php5的安装与配置webapi部署多服务器配置nginx负载均衡的教nginx 简单的负载均衡配置示例ubuntu上安装nginx服务器程序及简单的环境nginx下部署vue项目的方法步骤nginx配置限制同一个ip的访问频率方法nginx 运维之域名验证的方法示例详解 nginx 301重定向的配置制作nginx的rpm包教程nginx服务器的ssl证书配置以及对ssl的反向全面解析nginx到底能做什么
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved