一、Nginx反向代理

nginx的代理过程,客户端请求到达nginx代理服务器,nginx服务器并不对请求做应答处理,而是判断请求类型,并将请求合理的调度到后端服务器,由后端服务器队请求做处理,处理完毕在经由nginx代理服务器返回给客户端。后端服务器可在远程也可在本地,也可以是nginx服务器内部定义的其他虚拟主机。这些接收nginx转发的服务器被称为上游(upstream)。

使用nginx做代理的目的之一是扩展基础架构的规模。nginx可以处理大量并发连接,请求到来后,nginx可将其转发给任意数量的后台服务器进行处理,这等于将负载均衡分散到整个集群。

语法:proxy_pass URL
说明:URL的形式可以如下:http://location:8000/uri/ 等,可在location中进行配置。
例子:下面是一个简单的代理到本机其他端口的示例

在80端口监听的目录下没有test_proxy的文件,但在8080端口监听目录下有,在80端口的server里面添加如下内容:

location ~ /test_proxy.html$ {
proxy_pass http://127.0.0.1:8080;
}

然后在浏览器上输入http://IP地址/test_proxy.html,会出现请求的信息,实际上是80端口转发给了8080端口并把数据请求了回来。

二、缓冲

nginx也提供了缓冲的机制,用于提高性能。没有缓冲的情况下,数据直接从后端服务器发送给客户端。缓冲的作用是在nginx上临时存储来自后端服务器的处理结果,从而可以提早关闭nginx到后端的连接,减少IO的损耗。一般内容存放在内存当中,但当内容过多,造成的内存不够时,会把内容存放在临时文件目录下。下面是一些常用的缓冲的配置项,可以再http、server和location内容块下。

proxy_buffering:控制本内容块下是否启用缓冲,默认是"on"
proxy_buffers:有两个参数,第一个控制缓冲区请求数量,第二个控制缓冲区大小。默认值为8个、一页(一般是4k或8k)。这个值越大,缓冲的内容越多。
proxy_buffer_size:后端回复结果的首段(包含header的部分)是单独缓冲的,此配置就是配置这部分缓冲区的大小。这个值默认与proxy_buffer的值相同,我们可以把它设置得小一些,因为header内容一般比较少。
proxy_busy_buffers_size:设置被标记为"client-ready"(客户端就绪)的缓冲区大小。客户端一次只能从一个缓冲读取数据,而缓冲是按照队列次序被分批发送给客户端的。此语法配置的就是这个队列的大小。
proxy_temp_path:定义nginx存储临时文件路径。
proxy_max_temp_file_size:每个请求可以存储临时文件的目录大小。如果上游发来的结果太大以至于无法放入一个缓冲,则nginx会为其创建临时文件。

三、负载均衡

Nginx负载均衡示意图

配置语法:upstream name {.......}
说明:name是自定义的一个名字,而{}则是需要定义的内容,只能在http块定义,不能在server块里定义。定义完之后可在location块下写入如下代码进行调用:http://name

例子:由于服务器数量的限制,此处我们是用一台服务器的不同的端口来模拟负载均衡,当然,多台的配置也是类似的。

在server块内加入如下代码:

upstream test {
#ip_hash
server IP:8001;
server IP:8002;
server IP:8003;
}

然后,在http块内的location中加入如下内容:

location / {#设置主机头和客户端真实地址,以便服务器获取客户端真实IP proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_connect_timeout 30;#设置连接超时时间为30s
proxy_send_timeout 60; proxy_read_timeout 60;
proxy_buffer_size 32k; #设置缓冲区大小
proxy_buffering on; #开启缓冲区
proxy_buffers 4 128k; #设置缓冲区的数目和大小
proxy_busy_buffers_size 256k; #设置客户端就绪缓冲区大小 proxy_max_temp_file_size 256k;
proxy_pass http://test; #调用上面设置的负载均衡
}

当然,得提醒一下,我们设置的IP的端口是事先在配置文件里配置好的。例如如下的配置。

然后,我们访问我们的主机地址,然后不断的刷新,会发现出来每个端口出来的页面信息。默认的负载均衡采用的是轮询的方式。

如果是用的不同的服务器进行负载均衡的话,只需稍稍改改,就例如如下配置:

upstream mydomain.com{
server 10.220.5.111:80;
server 10.220.5.112:80;
server 10.220.5.113:80;
}

配置完之后呢,剩下的在http里的代码和上面的相似,然后在其他的三个服务器那里进行如下配置。当然,我们还得在那三个服务器那里的防火墙进行设置。

server{
listen 80;
server_name www.mydomain.com;
index index.htm index.php index.html;
root 目录路径;
}

①后端服务器在负载均衡调度中的状态
dowm:当前的server暂时不参与负载均衡。
backup:预留的备份服务器。
max_fails:允许请求失败的次数。
fail_timeout:经过max_fails失败后,服务器暂停的时间。
max_conns:限制最大的接收连接数。

注:以上的配置都是在upstream的时候配置的,例如在{}里面加入的server IP:8001 dowm,就表示这个服务是不参与负载均衡的,用来做备 份的,以上配置都是写在服务的后面。

②调度算法
轮询:按时间顺序逐一分配到不同的后端服务器。
加权轮询:可在配置的server后面加个weight=number,number值越高,分配的概率越大。
ip_hash:每个请求按访问IP的hash分配,这样来自同一IP固定访问一个后台服务器。
least_hash:最少链接数,哪个机器连接数少就发分发给哪个机器。
url_hash:按访问的url的hash结果分配请求,是每个url定向到同一后端服务器上。
hash关键值:hash自定义的key。

注:调度算法在设置upstream中配置,例如在此大括号里面写入ip_hash表示使用ip_hash的方式分配。

------做运维之前很矫情的小年轻-----

基于Nginx的负载均衡相关推荐

  1. 基于Nginx的负载均衡实验

    实验工具 Nginx Nodejs 浏览器 实验原理 反向代理服务器位于用户与目标服务器之间,但是对于用户而言,反向代理服务器就相当于目标服务器,即用户直接访问反向代理服务器就可以获得目标服务器的资源 ...

  2. NGINX基于Tomcat配置负载均衡

    NGINX基于Tomcat配置负载均衡 本部署指南说明了如何使用NGINX开源和NGINX Plus在Apache Tomcat TM应用程序服务器池之间平衡HTTP和HTTPS流量.本指南中的详细说 ...

  3. Nginx搭建负载均衡集群

    (1).实验环境 youxi1 192.168.5.101 负载均衡器 youxi2 192.168.5.102 主机1 youxi3 192.168.5.103 主机2 (2).Nginx负载均衡策 ...

  4. lnmp架构——nginx的负载均衡

    lnmp架构--nginx的负载均衡 1 什么是nginx 2 nginx的作用 3 nginx的特点 4 nginx的安装以及优化 4.1 安装nginx 4.2 优化 5 nginx主配置文件操作 ...

  5. Nginx+keepalived负载均衡高可用篇第③版

    Nginx+keepalived负载均衡高可用篇第③版 对付中.小型企业,假如没有资金去购买昂贵的四/七层负载均衡交换机,那么Nginx是不错的七层负载均衡选择,并且可以通过Nginx + Keepa ...

  6. 用haproxy结合keepalived实现基于LNMP的负载均衡和高可用

    今天我们讲haproxy结合keepalived实现LNMP的负载均衡和高可用,现在的公司大部分都基于haproxy实现负载均衡.下面以一个事例去给大家详细讲解如何去实现: 一.用haproxy结合k ...

  7. Nginx之负载均衡(四)

    在上一篇博客我们介绍了 Nginx 一个很重要的功能--代理,包括正向代理和反向代理.这两个代理的核心区别是:正向代理代理的是客户端,而反向代理代理的是服务器.其中我们又重点介绍了反向代理,以及如何通 ...

  8. 使用nginx+Apache负载均衡及动静分离

    使用nginx+Apache负载均衡及动静分离 介绍    LB负载均衡集群分两类: LVS (四层)和 nginx或haproxy (七层)    客户端都是通过访问分发器的VIP来访问网站 在七层 ...

  9. Nginx+DNS负载均衡实现

    2019独角兽企业重金招聘Python工程师标准>>> 负载均衡有多种实现方法,nginx.apache.LVS.F5硬件.DNS等. DNS的负载均衡就是一个域名指向多个ip地址, ...

最新文章

  1. 机器学习入门案例简单理解——Tensorflow之MNIST解析
  2. Deep learn toolbox:CNN BP求导解析
  3. 张颐武:周小平的意义
  4. 论文浅尝 - ICML2020 | 跨域对齐的图最优运输算法
  5. 【python教程入门学习】迭代器、生成器和可迭代对象
  6. 东航期货行情接口和交易接口(20190509)
  7. 网络协议:传输层(http://java-mzd.iteye.com/blog/1007577)
  8. windows10 右键 manage 没反应
  9. 发力多人在线游戏!PS5有望2020年E3展会亮相!
  10. 在.Net中实现RichClient+Restful+JPA架构-探索实现
  11. 阶段5 3.微服务项目【学成在线】_day02 CMS前端开发_15-webpack研究-webpack-dev-server-程序调试...
  12. 基于sklearn的线性分类器
  13. 旅行商问题(TSP) 中国34个城市 经纬度平面坐标
  14. 分布式光纤振动传感技术在电力电缆管道防外力破坏的应用
  15. 计算机论文档案初探,[电子档案管理论文:档案计算机管理技术人才培训工作初探.doc...
  16. vs2008gridview自带删除功能代码怎么实现
  17. php 表示每月一号,关于适合每月一号发的说说
  18. android 日历 签到,Android MaterialCalendarView 日历使用 每日签到
  19. 使用redis所维护的代理池抓取微信文章
  20. php统计邮件打开率,监控 Amazon SES 电子邮件的打开率、点击率和退回率

热门文章

  1. CentOS7 Tomcat安装
  2. intel 汇编中断解释
  3. IE8 chrome 中 table隔行换色解决办法
  4. 1个多月就能看到效果的减肥大法 - 生活至上,美容至尚!
  5. 力扣(LeetCode):字符串转换整数 (atoi)
  6. SPI及其工作原理浅析
  7. string 与char *的区别
  8. 在php storm中怎么搭建环境,PhpStorm搭建git环境
  9. linux转mysql_转linux下mysql命令
  10. Java---简易自动取货机