upstream 参数

nginx关于upstream参数官方文档:http://nginx.org/en/docs/http/ngx_http_upstream_module.html         英文

https://www.kancloud.cn/louis1986/nginx-web/527874                     中文

upstream 参数

参数

描述

service

反向服务地址 加端口

weight

权重

max_fails

失败多少次 认为主机已挂掉则,踢出

fail_timeout

踢出后重新探测时间

backup

备用服务

max_conns

允许最大连接数

slow_start

当节点恢复,不立即加入

 service

每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除 配置如下:

upstream names{server 127.0.0.1:8050 ;server 127.0.0.1:8060 ;}

weight(权重)

指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。

upstream tuling {server 127.0.0.1:8050 weight=5;server 127.0.0.1:8060 weight=1;}

max_conns

可以根据服务的好坏来设置最大连接数,防止挂掉,比如1000,我们可以设置800

upstream tuling {server 127.0.0.1:8050 weight=5 max_conns=800;server 127.0.0.1:8060 weight=1;}

max_fails、 fail_timeout

max_fails=number               配置请求尝试失败的次数
fail_timeout=time
这是一个设置参数,一般跟上面的参数协同使用。该参数的含义:
1:当连接后端server失败时,多长时间内可反复尝试连接后端server;
2:一旦超过这个设置时间段,则判断该server的状态为不可用(unavailable );
这个参数的默认值为10秒

upstream tuling {server 127.0.0.1:8050 weight=1 max_fails=1 fail_timeout=20;server 127.0.0.1:8060 weight=1;}//关闭掉8050的服务 你会发现在20秒内还是访问8060的,20s后才会访问8050

记得修改完nginx.conf 后,./sbin/nginx -s reload 重启nginx ,然后我们可以让8050关闭来演示

负载均衡算法

轮询+weight   默认的

ip_hash : 基于Hash 计算

应用场景:保持session 一至性

url_hash: (第三方)

应用场景:静态资源缓存,节约存储,加快速度

least_conn 最少链接

least_time 最小的响应时间,计算节点平均响应时间,然后取响应最快的那个,分配更高权重。

下面是ip_hash,url_hash的示意图

下面是nginx大概的参数流程(粗略)

location参数

语法规则: location [=|~|~*|^~] /uri/ { … }

= 开头表示精确匹配

^~ 开头表示uri以某个常规字符串开头,理解为匹配 url路径即可。nginx不对url做编码,因此请求为/static/20%/aa,可以被规则^~ /static/ /aa匹配到(注意是空格)。

~ 开头表示区分大小写的正则匹配

~*  开头表示不区分大小写的正则匹配

!~和!~*分别为区分大小写不匹配及不区分大小写不匹配 的正则

/ 通用匹配,任何请求都会匹配到。

多个location配置的情况下匹配顺序为(参考资料而来,还未实际验证,试试就知道了,不必拘泥,仅供参考):

首先匹配 =,其次匹配^~, 其次是按文件中顺序的正则匹配,最后是交给 / 通用匹配。当有匹配成功时候,停止匹配,按当前匹配规则处理请求。

nginx的location配置详解例子(Sign_Black):https://www.cnblogs.com/sign-ptk/p/6723048.html

下面通过几个例子熟悉和学习nginx的使用场景

nginx 动静分离演示

1.为了区分,我们在web1 中 放一张图片 images/tomcat.png

cd webappsmkdir images //创建一个images文件夹cp tomcat.png images/tomcat.png //复制图片到images文件中

2.进入nginx配置,当然也可以用正则表示式的方式,这里是简单演示

3.配置host

这样就完成了

防盗链配置:

什么是图片防盗链?意思是指本站内图片、CSS等资源只有本站点可以访问,不允许其它站点打开! 该功能如果用JAVA如何实现?很单简单,只要判断一下 请求头当中的referer 属性是否为 指定域名即可。 Nginx原理类似。

加入至指定location 即可实现

valid_referers none blocked *.luban.com;if ($invalid_referer) {return 403;}

演示防盗链配置:

说明:如果 valid_referers 条件判断未通过,nginx 则会赋值 invalid_referer 为true

语法: valid_referers none | blocked | server_names | string ...;

参数说明:

none 不允许 “Referer” 来源头部为空的情况

blocked 不允许“Referer”值为空情况,有可能Referer被的值被代理或者防火墙删除

server_names “Referer”来源头部包必须含当前的server_names (当前域名)可以多个

(关于valid_referers比较详细的讲解:https://blog.csdn.net/ywb201314/article/details/51461053 )

防盗链配置

location ~* \.(gif|png|jpg|swf|flv)$ {root html;valid_referers none blocked *.tl.com;if ($invalid_referer) {#rewrite ^/ http://www.tl.com/image/403.png;return 404;#这里我们直接返回404}}

下载限速

下载限速:

location /download {limit_rate 1m;//限制1Mlimit_rate_after 30m;//对30m上的数据限制}

创建IP黑名单

# 创建黑名单文件

# 创建黑名单文件echo 'deny 192.168.0.132;' >> balck.ip#http 配置块中引入 黑名单文件include       black.ip;

( 动态创建ip黑名单: https://www.cnblogs.com/wloveh/p/4434919.html  )

日志配置

日志格式:

log_format  main  '$remote_addr - $remote_user [$time_local]   "$request" '

'$status $body_bytes_sent "$http_referer" ''

"$http_user_agent" "$http_x_forwarded_for"';

access_log  logs/access.log  main;

#基于域名打印日志

access_log logs/$host.access.log main;

error日志的设置

语法:error_log /path/file level;

默认:error_log logs/error.log error;

level是日志的输出级别,取值范围是debug、info、notice、warn、error、crit、alert、emerg,

针对指定的客户端输出debug级别的日志

语法:debug_connection[IP|CIDR]

events {debug_connection 192.168.0.147; debug_connection 10.224.57.0/200;}

日志配置详解  https://blog.csdn.net/biubiuli/article/details/79481882

Nginx 负载均衡演示之 upstream 参数、 location 参数等示例说明相关推荐

  1. Nginx 负载均衡演示之 upstream 参数 location 参数

    upstream 参数 nginx关于upstream参数官方文档:http://nginx.org/en/docs/http/ngx_http_upstream_module.html upstre ...

  2. Nginx负载均衡配置策略

    转自:http://www.freeoa.net/osuport/cluster/nginx-load-equilibrium-configuration-strategy_1652.html Ngi ...

  3. Nginx负载均衡探活max_fails和fail_timeout的设置、根据参数转发upstream

    Nginx负载均衡max_fails和fail_timeout的设置作用,直接贴配置上,看干货 server { listen 80; server_name xxxx.ikong.com; loca ...

  4. 1,Nginx负载均衡策略upstream,六种策略

    upstream提供负载均衡功能,支持6种负载分配方式,默认是轮询分配方式 负载均衡作用 转发功能 故障转移 恢复添加 工作流程 分析客户端请求,构建调用服务器 调用ngx_http_upstream ...

  5. Nginx负载均衡集群介绍

    第1章 集群介绍 1.1 集群简介 1.1.1 什么是集群 简单说,集群就是一组(若干个)相互独立的计算机,利用高速通信网络组成的一个较大的计算机服务系统,每个集群节点(即集群中的每台计算机)都是运行 ...

  6. linux window nginx性能,Nginx负载均衡搭建(Window与Linux)

    windows上搭建nginx负载均衡 1.准备几台http服务器软件,这里选用一台apache一台tomcat apache(windows)下载链接:https://www.apachehaus. ...

  7. PHP+Nginx+宝塔+rsync代码同步 实现Nginx负载均衡

    PHP+Nginx+宝塔+rsync代码同步 实现Nginx负载均衡 作为一个PHP菜鸟,最近闲着没事,就想搭建一个Nginx试试,因为重来没有搭过,特此记录一下,也希望能为新入门的兄弟们提供一点帮助 ...

  8. Nginx - 负载均衡

    一.前言 前文简单介绍了如何安装Nginx,方法非常简单,操作也非常方便.上文中提到了Nginx可以做http服务器.虚拟主机.负载均衡.在这篇博客中小编就向大家介绍一下如何用Nginx做负载均衡. ...

  9. Nginx负载均衡配置教程-Linux

    引言 别问,问就是工作需要.让我把写的一个服务用Nginx负载均衡一下. 正好记录一下. 1. 准备 确保你的Nginx已经安装完毕,且可以正常使用.如果还没安装,请看这个链接:https://blo ...

  10. [ 总结 ] nginx 负载均衡 及 缓存

    操作系统:centos6.4 x64 前端使用nginx做反向代理,后端服务器为:apache + php + mysql 1. nginx负载均衡. nginx编译安装(编译安装前面的文章已经写过) ...

最新文章

  1. Bzoj1835:[ZJOI2010]基站选址
  2. oracle ORA-00119和ORA-00132解决方法
  3. window连接不上linux ftp_Linux文件自动备份方案
  4. Angular2封装拖拽指令
  5. python绘图—— matplotlib
  6. 618 大促背后的淘系前端技术体系
  7. 5.11 加权Gram-Schmidt 分解
  8. Virtual Box创建共享目录
  9. QAbstractButton的clicked、pressed、released、toggled、triggered等信号区别
  10. python定义变量取值范围_python怎么限定函数自变量取值范围?
  11. 适配 Android N 需要注意什么
  12. 解决Linux(ubuntu),windows双系统重装后恢复开机选单
  13. 淘宝旺旺号转userid 和 uid 的接口方法
  14. 在Docker中配置AdGuard Home
  15. Nmap学习4 - 主机发现 实验一
  16. grasps什么意思中文_grasps是什么意思_grasps怎么读_grasps翻译_用法_发音_词组_同反义词_抓住( grasp的第三人称单数 )-新东方在线英语词典...
  17. 【论文夜读】陈天琦神作Neural Ordinary Differential Equations(NuerIPS2018最佳paper)
  18. 执行cmake .. 报错:Cannot find llvm-lit
  19. 12月上海Cloudera Hadoop大数据培训:CCAH、CCDH
  20. 记一次失败的导师霸面

热门文章

  1. Unity3D 2D设计小游戏移动幻影的实现
  2. 我在黑暗中看到你眼中的月光_你好黑暗,我的老朋友
  3. Fcitx使用搜狗词库与皮肤
  4. 新手,如何快速建立一个网站?
  5. 值得推荐的在线报表设计器
  6. 微软亚洲研究院院长换帅!复旦校友周礼栋博士升任新院长
  7. [题]口袋的天空(连接云朵) —— 标签 #最小生成树(kru) #并查集
  8. Python爬虫——爬取豆瓣VIP书籍信息并存入数据库
  9. 浙江大学计算机系自主招生题目,浙江大学自主招生试题
  10. 三日济州岛,何以韩国人眼光?-让自己慢下来(43)