【upstream】Nginx配置upstream实现负载均衡
如果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实现负载均衡相关推荐
- Nginx-06:Nginx配置实例之负载均衡
Nginx配置实例之负载均衡 目的:访问http://192.168.17.129/edu/a.html时平均的分配到8080和8081端口,即实现负载均衡的效果. 1.准备工作 (1)准备两台tom ...
- django部署 nginx 配置简单的负载均衡
这里使用的负载均衡就是将过来的请求分发给不同的django服务去处理,不同的django服务使用的相同的数据库,那么来看nginx配置 upstream test01 {# 这里配置的是简单的负载均衡 ...
- Nginx 配置实战:负载均衡的实现
负载均衡的必要性 那些星星就是服务器,不过这个例子并不是实际生产中的采用的模型,因为这种星型构架,如果中间的服务器塌了,周围四个也无法联网,但是这个例子就是说明,每个服务器集群会有一个或者几个中心服务 ...
- Nginx反向代理以及负载均衡配置
一 .nginx 的优缺点: nginx 相对 apache 的优点: 轻量级,同样起web 服务,比apache 占用更少的内存及资源 抗并发,nginx 处理请求是异步非阻塞的,而apache 则 ...
- 图文解说:Nginx+tomcat配置集群负载均衡
图文解说:Nginx+tomcat配置集群负载均衡 博客分类: appserver nginxTomcatUbuntuLinux网络应用 作者:niumd Blog:http://ari.iteye ...
- Nginx反向代理实现负载均衡配置图解
come from: http://www.php100.com/html/program/nginx/2013/0905/5529.html 负载均衡配置是超大型机器需要考虑的一些问题,同时也 ...
- 深入浅出学习透析Nginx服务器的基本原理和配置指南「负载均衡篇」
负载均衡 之前的章节内容中[深入浅出学习透析Nginx服务器的基本原理和配置指南「初级实践篇 」]和 [深入浅出学习透析Nginx服务器的基本原理和配置指南「进阶实践篇」],我们采用的代理仅仅指向一个 ...
- Nginx配置upstream
Nginx配置upstream并且实现负载均衡 Nginx配置upstream实现负载均衡 nginx配置-upstream
- 从0开始,在Linux中配置Nginx反向代理、负载均衡、session共享、动静分离
写这篇文章花费了我近一周的时间,参考网上许多优秀的博客文章,我不敢说写的很好,至少很全很详细.本文先介绍原理部分,然后再进行实战操作,我认为这样才会有更深的理解,不过这也导致了文章篇幅很长.但是,如果 ...
- Nginx反向代理服务器及负载均衡服务配置实战
Nginx反向代理服务器及负载均衡服务配置实战 1 前言:什么是Nginx? Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服 ...
最新文章
- hdu1874 畅通project续 最短路 floyd或dijkstra或spfa
- 读论文之《基于EV10AQ190的高速ADC接口设计》
- 计算机接口实验1,计算机接口技术实验一.doc
- shell脚本监控系统负载、CPU和内存使用情况
- Tensorflow学习教程集合
- 分布式深度学习,93页ppt概述最新DDL技术发展
- IndexTank全文检索引擎设计分析
- 【英语学习】【English L06】U02 Food L2 Salad dressings
- rose-scanning reading
- mysql 选取数据库_mysql选取数据库
- 信息抽取 | 72篇论文梳理:涉及NER、复杂关系、小样本、文档级、多模态、开放域抽取...
- JS 简易控制台插件 [供 博客, 论坛 运行js用]
- u盘如何修复 新萝卜U盘官方网站原创
- 【DBA | IT人生】数据库解惑系列
- 2022-2027年(新版)中国产权交易行业前景动态与未来发展形势报告
- 介绍两个测试网页打开速度的网站
- 【Linux】在Xilinx平台上实现UVC Gadget(2)- 解决dwc3驱动bug
- 制作一个电影推荐系统的案例
- SAP-MM知识精解-自动科目记账(04-2)- 业务事物之“科目分组代码”的影响
- 利用FFmpeg编码器将JPG图片进行H.264编码原理
热门文章
- js中的 substring和substr方法
- navicate连接mysql问题(#1130 - Host 'localhost' is not allowed to connect to this MySQL server)
- Ping of Death:速修复 TCP/IP RCE 漏洞 CVE-2020-16898
- FPGA 芯片被曝严重的 Starbleed 漏洞,影响数据中心IoT工业设备等
- active-class属于Vue哪一个modules,有什么作用
- 第十六章:springboot 整合logback日志
- 知物由学 |“网状世界”下,无处可逃的信息安全
- 后台产品基本功:RBAC权限后台角色与权限设计
- Linux内核的编译方法及如何往内核中增加程序
- Linux Rsync实现文件同步备份(转载)