如果Nginx没有仅仅只能代理一台服务器的话,那它也不可能像今天这么火,Nginx可以配置代理多台服务器,当一台服务器宕机之后,仍能保持系统可用。具体配置过程如下:

1. 在http节点下,添加upstream节点。

upstream s-server1{
server 10.0.6.108:7080;
server 10.0.0.85:8980;
}

2. 将server节点下的location节点中的proxy_pass配置为:http:// + upstream名称,即“
http://s-server1”.

location / {
root html;
index index.html index.htm;
proxy_pass http://s-server1;
}

3. 现在负载均衡初步完成了。upstream按照轮询(默认)方式进行负载,每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。虽然这种方式简便、成本低廉。但缺点是:可靠性低和负载分配不均衡。适用于图片服务器集群和纯静态页面服务器集群。

除此之外,upstream还有其它的分配策略,分别如下:

1、轮询(默认) 
每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。

upstream s-server1{ server 192.168.0.14; server 192.168.0.15;
} 

2.weight(权重)
指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。如下所示,10.0.0.88的访问比率要比10.0.0.77的访问比率高一倍。

upstream s-server1{ server 10.0.0.77 weight=5; server 10.0.0.88 weight=10;
}

3.ip_hash(访问ip)
每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。

upstream s-server1{ ip_hash; server 10.0.0.10:8080; server 10.0.0.11:8080;
}

一旦涉及到负载均衡啊、集群等问题,最好最好是不用session,一定要用的话,必须在应用服务器这一级来做复制。而 ip_hash 在实际的环境中用处不大,因为很多人上网都是多个ip来回变得

4.fair(第三方)
按后端服务器的响应时间来分配请求,响应时间短的优先分配。与weight分配策略类似。

upstream s-server1{ server 10.0.0.10:8080; server 10.0.0.11:8080; fair;
}

5.url_hash(第三方)
按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效。
注意:在upstream中加入hash语句,server语句中不能写入weight等其他的参数,hash_method是使用的hash算法。

upstream s-server1{ server 10.0.0.10:7777; server 10.0.0.11:8888; hash $request_uri; hash_method crc32;
}

upstream还可以为每个设备设置状态值,这些状态值的含义分别如下:

down 表示单前的server暂时不参与负载.

weight 默认为1.weight越大,负载的权重就越大。

max_fails :允许请求失败的次数默认为1.当超过最大次数时,返回proxy_next_upstream 模块定义的错误.

fail_timeout : max_fails次失败后,暂停的时间。

backup: 其它所有的非backup机器down或者忙的时候,请求backup机器。所以这台机器压力会最轻。

#定义负载均衡设备的Ip及设备状态
upstream s-server1{ ip_hash; server 10.0.0.11:9090 down; server 10.0.0.11:8080 weight=2; server 10.0.0.11:6060; server 10.0.0.11:7070 backup;
}

#多个项目
upstream s-server1{ ip_hash; server 10.0.0.11:9090 down; server 10.0.0.11:8080 weight=2;
}
upstream s-server2{ ip_hash; server 10.0.0.11:9090 down; server 10.0.0.11:8080 weight=2;
}
 

配置好之后可以使用命令来检查配置是否正确

/sbin/nginx -t

疑问:

使用ip_hash的方式,如果nginx服务器被局域网内很多用户使用,由于他们的外网ip都是一样的,局域网的所有用户访问的就是同一个服务器,没有负载均衡,解决方式?

【upstream】Nginx配置upstream实现负载均衡相关推荐

  1. Nginx-06:Nginx配置实例之负载均衡

    Nginx配置实例之负载均衡 目的:访问http://192.168.17.129/edu/a.html时平均的分配到8080和8081端口,即实现负载均衡的效果. 1.准备工作 (1)准备两台tom ...

  2. django部署 nginx 配置简单的负载均衡

    这里使用的负载均衡就是将过来的请求分发给不同的django服务去处理,不同的django服务使用的相同的数据库,那么来看nginx配置 upstream test01 {# 这里配置的是简单的负载均衡 ...

  3. Nginx 配置实战:负载均衡的实现

    负载均衡的必要性 那些星星就是服务器,不过这个例子并不是实际生产中的采用的模型,因为这种星型构架,如果中间的服务器塌了,周围四个也无法联网,但是这个例子就是说明,每个服务器集群会有一个或者几个中心服务 ...

  4. Nginx反向代理以及负载均衡配置

    一 .nginx 的优缺点: nginx 相对 apache 的优点: 轻量级,同样起web 服务,比apache 占用更少的内存及资源 抗并发,nginx 处理请求是异步非阻塞的,而apache 则 ...

  5. 图文解说:Nginx+tomcat配置集群负载均衡

    图文解说:Nginx+tomcat配置集群负载均衡 博客分类: appserver nginxTomcatUbuntuLinux网络应用  作者:niumd Blog:http://ari.iteye ...

  6. Nginx反向代理实现负载均衡配置图解

     come from: http://www.php100.com/html/program/nginx/2013/0905/5529.html 负载均衡配置是超大型机器需要考虑的一些问题,同时也 ...

  7. 深入浅出学习透析Nginx服务器的基本原理和配置指南「负载均衡篇」

    负载均衡 之前的章节内容中[深入浅出学习透析Nginx服务器的基本原理和配置指南「初级实践篇 」]和 [深入浅出学习透析Nginx服务器的基本原理和配置指南「进阶实践篇」],我们采用的代理仅仅指向一个 ...

  8. Nginx配置upstream

    Nginx配置upstream并且实现负载均衡 Nginx配置upstream实现负载均衡 nginx配置-upstream

  9. 从0开始,在Linux中配置Nginx反向代理、负载均衡、session共享、动静分离

    写这篇文章花费了我近一周的时间,参考网上许多优秀的博客文章,我不敢说写的很好,至少很全很详细.本文先介绍原理部分,然后再进行实战操作,我认为这样才会有更深的理解,不过这也导致了文章篇幅很长.但是,如果 ...

  10. Nginx反向代理服务器及负载均衡服务配置实战

    Nginx反向代理服务器及负载均衡服务配置实战 1 前言:什么是Nginx? Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服 ...

最新文章

  1. hdu1874 畅通project续 最短路 floyd或dijkstra或spfa
  2. 读论文之《基于EV10AQ190的高速ADC接口设计》
  3. 计算机接口实验1,计算机接口技术实验一.doc
  4. shell脚本监控系统负载、CPU和内存使用情况
  5. Tensorflow学习教程集合
  6. 分布式深度学习,93页ppt概述最新DDL技术发展
  7. IndexTank全文检索引擎设计分析
  8. 【英语学习】【English L06】U02 Food L2 Salad dressings
  9. rose-scanning reading
  10. mysql 选取数据库_mysql选取数据库
  11. 信息抽取 | 72篇论文梳理:涉及NER、复杂关系、小样本、文档级、多模态、开放域抽取...
  12. JS 简易控制台插件 [供 博客, 论坛 运行js用]
  13. u盘如何修复 新萝卜U盘官方网站原创
  14. 【DBA | IT人生】数据库解惑系列
  15. 2022-2027年(新版)中国产权交易行业前景动态与未来发展形势报告
  16. 介绍两个测试网页打开速度的网站
  17. 【Linux】在Xilinx平台上实现UVC Gadget(2)- 解决dwc3驱动bug
  18. 制作一个电影推荐系统的案例
  19. SAP-MM知识精解-自动科目记账(04-2)- 业务事物之“科目分组代码”的影响
  20. 利用FFmpeg编码器将JPG图片进行H.264编码原理

热门文章

  1. js中的 substring和substr方法
  2. navicate连接mysql问题(#1130 - Host 'localhost' is not allowed to connect to this MySQL server)
  3. Ping of Death:速修复 TCP/IP RCE 漏洞 CVE-2020-16898
  4. FPGA 芯片被曝严重的 Starbleed 漏洞,影响数据中心IoT工业设备等
  5. active-class属于Vue哪一个modules,有什么作用
  6. 第十六章:springboot 整合logback日志
  7. 知物由学 |“网状世界”下,无处可逃的信息安全
  8. 后台产品基本功:RBAC权限后台角色与权限设计
  9. Linux内核的编译方法及如何往内核中增加程序
  10. Linux Rsync实现文件同步备份(转载)