Nginx4大模块——proxy、headers、upstream、stream模块

Nginx

应用程序发布:

灰度模型:

         (1) 如果存在用户会话;

             从服务器上拆除会话;

         (2) 新版本应用程序存在bug;

             回滚;

ngx_http_proxy_module模块:

1、proxy_pass URL;

Context: location, if in location, limit_except

    

注意:proxy_pass后面的路径不带uri时,其会将location的uri传递给后端主机

         server {

                

                 server_name HOSTNAME;

                 location /uri/ {

                      proxy http://hos[:port];

                 }

                

         }

        

         http://HOSTNAME/uri –> http://host/uri

    

proxy_pass后面的路径是一个uri时,其会将location的uri替换为proxy_pass的uri

         server {

                

                 server_name HOSTNAME;

                 location /uri/ {

                      proxy http://host/new_uri/;

                 }

                

         }

        

         http://HOSTNAME/uri/ –> http://host/new_uri/

    

如果location定义其uri时使用了正则表达式的模式,则proxy_pass之后必须不能使用uri; 用户请求时传递的uri将直接附加代理到的服务的之后

         server {

                

                 server_name HOSTNAME;

                 location ~|~* /uri/ {

                      proxy http://host;

                 }

                

         }

        

         http://HOSTNAME/uri/ –> http://host/uri/

2、proxy_set_header field value;

设定发往后端主机的请求报文的请求首部的值;Context: http, server, location

    

proxy_set_header X-Real-IP  $remote_addr;

    $remote_addr:记录的是上一台主机的IP,而上一台主机有可能也是代理服务器

proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

    $proxy_add_x_forwarded_for:记录的是源IP地址

    

在http客户端还有修改/etc/httpd/conf/httpd.conf文件

    LogFormat "%{X-Real-IP}i %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined

    

    通过上述方法则可以在后端主机上记录真实的httpd资源请求者,而不再是只记录前端代理服务器的IP地址

3、proxy_cache_path

定义可用于proxy功能的缓存;Context: http

    

proxy_cache_path path [levels=levels] [use_temp_path=on|off] keys_zone=name:size [inactive=time] [max_size=size] [manager_files=number] [manager_sleep=time] [manager_threshold=time] [loader_files=number] [loader_sleep=time] [loader_threshold=time] [purger=on|off] [purger_files=number] [purger_sleep=time] [purger_threshold=time];

    

proxy_cache_path /var/cache/nginx/proxy_cache levels=1:2:1 keys_zone=gmtest:20M max_size=1G;

4、proxy_cache zone | off;

指明要调用的缓存,或关闭缓存机制;Context: http, server, location

    

proxy_cache gmtest;

5、 proxy_cache_key string;

缓存中用于“键”的内容;

    

默认值:proxy_cache_key $scheme$proxy_host$request_uri;

    建议定义成方法和url

6、proxy_cache_valid [code …] time;

定义对特定响应码的响应内容的缓存时长;

    

定义在http{…}中;

    proxy_cache_path /var/cache/nginx/proxy_cache levels=1:1:1 keys_zone=gmtest:20m max_size=1g;

    

定义在需要调用缓存功能的配置段,例如server{…},或者location中;

    proxy_cache gmtest;

    proxy_cache_key $request_uri;

    proxy_cache_valid 200 302 301 1h;

    proxy_cache_valid any 1m;

7、proxy_cache_use_stale

proxy_cache_use_stale error | timeout | invalid_header | updating | http_500 | http_502 | http_503 | http_504 | http_403 | http_404 | off …;

    

Determines in which cases a stale cached response can be used when an error occurs during communication with the proxied server.

    

后端服务器的故障在那种情况下,就使用缓存的功能对客户的进行返回

8、proxy_cache_methods GET | HEAD | POST …;

If the client request method is listed in this directive then the response will be cached. “GET” and “HEAD” methods are always added to the list, though it is recommended to specify them explicitly.

    

默认方法就是GET HEAD方法

9、proxy_hide_header field;

By default, nginx does not pass the header fields “Date”, “Server”, “X-Pad”, and “X-Accel-…” from the response of a proxied server to a client. The proxy_hide_header directive sets additional fields that will not be passed.

10、proxy_connect_timeout time;

Defines a timeout for establishing a connection with a proxied server. It should be noted that this timeout cannot usually exceed 75 seconds.

    

默认为60s

11、buffer相关的配置

a:proxy_buffer_size size;

Sets the size of the buffer used for reading the first part of the response received from the proxied server. This part usually contains a small response header. By default, the buffer size is equal to one memory page.

    

默认为4k|8k

b:proxy_buffering on | off;

Enables or disables buffering of responses from the proxied server.

    

默认为on

c:proxy_buffers number size;

Sets the number and size of the buffers used for reading a response from the proxied server, for a single connection. By default, the buffer size is equal to one memory page.

    

默认为8 4k|8k

d:proxy_busy_buffers_size size;

When buffering of responses from the proxied server is enabled, limits the total size of buffers that can be busy sending a response to the client while the response is not yet fully read.

    

默认为8k|16k

ngx_http_headers_module模块

The ngx_http_headers_module module allows adding the “Expires” and “Cache-Control” header fields, and arbitrary fields, to a response header.

向由代理服务器响应给客户端的响应报文添加自定义首部,或修改指定首部的值;

1、add_header name value [always];

添加自定义首部;

    

add_header X-Via  $server_addr;

    经由的代理服务器地址

add_header X-Accel $server_name;

2、expires [modified] time;

expires epoch | max | off;

    

用于定义Expire或Cache-Control首部的值;

可以把服务器定义的缓存时长修改了;

ngx_http_upstream_module模块

The ngx_http_upstream_module module is used to define groups of servers that can be referenced by the proxy_pass, fastcgi_pass, uwsgi_pass, scgi_pass, and memcached_pass directives.

1、upstream name { … }

定义后端服务器组,会引入一个新的上下文;Context: http

    

upstream httpdsrvs {

         server …

         server…

        

}

2、server address [parameters];

在upstream上下文中server成员,以及相关的参数;Context: upstream

    

address的表示格式:

    unix:/PATH/TO/SOME_SOCK_FILE

    IP[:PORT]

    HOSTNAME[:PORT]

    

parameters:

         weight=number

             权重,默认为1;默认算法是wrr

         max_fails=number

             失败尝试最大次数;超出此处指定的次数时,server将被标记为不可用

         fail_timeout=time

             设置将服务器标记为不可用状态的超时时长

         max_conns

             当前的服务器的最大并发连接数

         backup

             将服务器标记为“备用”,即所有服务器均不可用时此服务器才启用

         down

             标记为“不可用”

             先在nginx前端配置down,然后在下架后端服务器,上架新的web程序,然后上架,在修改配置文件立马的down

3、least_conn;

最少连接调度算法,当server拥有不同的权重时其为wlc

要在后端服务器是长连接时,效果才好,比如mysql

4、ip_hash;

源地址hash调度方法

5、hash key [consistent];

基于指定的key的hash表来实现对请求的调度,此处的key可以直接文本、变量或二者的组合

    

作用:将请求分类,同一类请求将发往同一个upstream server

    

If the consistent parameter is specified the ketama consistent hashing method will be used instead.

    

示例:

    hash $request_uri consistent;

    hash $remote_addr;

    hash $cookie_name; 对同一浏览器的请求,发往同一个upstream server

6、keepalive connections;

为每个worker进程保留的空闲的长连接数量

    

nginx的其它的二次发行版:

    tengine

    OpenResty

    

1.9版本之后可以反代tcp/udp的协议,基于stream模块,工作与传输层

ngx_stream_core_module模块

模拟反代基于tcp或udp的服务连接,即工作于传输层的反代或调度器

1、stream { … }

定义stream相关的服务;Context: main

    

stream {

         upstream sshsrvs {

                 server 192.168.22.2:22;

                 server 192.168.22.3:22;

                 least_conn;

         }

        

         server {

                 listen 10.1.0.6:22022;

                 proxy_pass sshsrvs;

         }

}

    

stream模块中管的upstream模块的用法同上

2、listen

listen address:port [ssl] [udp] [proxy_protocol] [backlog=number] [bind] [ipv6only=on|off] [reuseport] [so_keepalive=on|off|[keepidle]:[keepintvl]:[keepcnt]];

原创文章,作者:megedugao,如若转载,请注明出处:http://www.178linux.com/55357

(26)
megedugaomegedugao
上一篇 2016-10-29 10:08
下一篇 2016-10-29 10:47

相关推荐

  • 计算机组成与Linux基础

    一 计算机组成 冯诺依曼体系 计算机处理数据和指令一律用二进制表示 指令和数据不加混合存储在同一存储器中 顺序执行程序每一条指令 计算机硬件由运算器、控制器、存储器、输入设备以及输出设备组成 计算机组成部分 CPU:含有指令集,对程序进行运算和判断并分为两个主要单元分别为算术逻辑单元和控制单元。其中算术逻辑单元主要负责程序运算与判断,控制单元负责协调组件与个…

    Linux干货 2017-07-30
  • N21天天第十三周课程练习

    1、建立samba共享,共享目录为/data,要求:(描述完整的过程)   1)共享名为shared,工作组为magedu;   2)添加组develop,添加用户gentoo,centos和ubuntu,其中gentoo和centos以develop为附加组,ubuntu不属于develop组;密码均为用户名;   3)添加s…

    Linux干货 2016-12-05
  • web 服务进阶 httpd配置成https

    web服务进阶 自建CA/https详解 一、SSL与https 1、引言 我们网上购物、网上订票,以及使用支付宝支付过程中都会在网上直接输入账号和密码。这些信息都是非常重要的,如何才能在输入的过程中,不被别人看见和窃取,就需要对你输入的信息进行加密处理。 早期的两主机通信之间是没有加解密程序,后来就在传输层与应用层之间加了一个SSL库,完成加密解密功能。 …

    Linux干货 2016-12-11
  • 处理文本的工具sed,vim 编辑器的使用 Linux版

    处理文本的工具sed Stream EDitor 行编辑器 sed一次处理一行的内容,处理时,将当前处理的行存储在临时缓冲区,称为“模式空间”,接着用sed命令处理缓冲区中的内容,处理完成后,将缓冲区的内容送往屏幕,接着处理下一行不断重复,直到末尾。            一次处理一行 文件&#82…

    Linux干货 2016-08-11
  • 马哥教育网络班21期+第14周课程练习

    系统的INPUT和OUTPUT默认策略为DROP; 1、限制本地主机的web服务器在周一不允许访问;新请求的速率不能超过100个每秒;web服务器包含了admin字符串的页面不允许访问;web服务器仅允许响应报文离开本机; INPUT链 # iptables -I INPUT 1 -p tcp&nb…

    Linux干货 2016-11-14
  • 使用ssh比较慢的小结

    1)情况说明 a、ping ip,响应正常 b、telnet ip,响应正常 c、ssh ip,响应慢,但是等很大会后还是能打开 2)处理方法 方法1: 修改本地中的/etc/ssh/ssh_config,把参数改为GSSAPIAuthentication no 方法2: a、修改远程服务器端的/etc/ssh/sshd_config ,把参数改为GSSAP…

    系统运维 2016-12-05