09-ngx_http_proxy_module模块

ngx_http_proxy_module模块常见指令:

1、proxy_pass URL;    该指令用于设置被代理服务器的协议、主机名、IP地址和端口等形式。
2、proxy_set_header field value;    设定发往后端主机的请求报文的请求首部的值;
    Field:要更改信息所在的头域
    Value:更改的值,支持使用文本、变量或者变量的组合
    proxy_set_header X-Real-IP  $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
3、proxy_cache_path    定义可用于proxy功能的缓存;
    proxy_cache_path path [levels=levels] [use_temp_path=on|off] keys_zone=name:size [inactive=time] [max_size=size]…
    levels:设置在对于path指定目录的第几级hash目录中缓存数据
    key_zone:Nginx服务器的缓存索引从简进程在内存中为缓存数据建立索引,用来定义放存缓存索引的内存区域的名称和大小
    inactive;表示缓存有效时间
    max_size:设置硬盘中缓存数据大大小
4、proxy_cache zone | off;    指明要调用的缓存,或关闭缓存机制;
5、 proxy_cache_key string; 缓存中用于“键”的内容;
    默认值:proxy_cache_key $scheme$proxy_host$request_uri; 
6、proxy_cache_valid [code …] time;    定义对特定响应码的响应内容的缓存时长;
7、proxy_cache_use_stale     使用过期缓存
8、proxy_cache_methods GET | HEAD | POST …;     根据客户端请求报文请求方式,来选着需要缓存的数据 
9、proxy_hide_header field;     该指令用于设置nginx服务器在发送响应报文时,隐藏一些头信息
10、proxy_connect_timeout time;    该指令来设定nginx服务器域后端被代理服务器尝试连接的超时时间。默认为60s;最长为75s; 
11、proxy_read_timeout time;    该指令设置nginx服务器向后端被代理服务器发出read请求后,等待响应的超时时间 
12、proxy_send_timeout time;    该指令设置nginx服务器向后端被代理服务器发出write请求后,等待响应的超时时间  

ngx_http_headers_module:该模块由代理服务器响应给客户端的响应报文添加自定义首部,或修改首部的值。

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首部的值; 

小实验:配置反向代理服务器LNAMP,并验证缓存功能

各节点均为centos7.2,其中controller1 节点安装nginx实现反向代理,controller2节点安装httpd,php,wordpress,controller3安装mariadb。

首先controller3节点安装mariadb,创建数据库wordpress并授权给carl用户

MariaDB [(none)]> create database wordpress;

MariaDB [(none)]> grant all privileges on wordpress.* to ‘carl‘@‘%‘ identified by ‘jl3040265‘;

MariaDB [(none)]> flush privileges;

controller2节点安装httpd,php,php-mysql,并为wordpress配置环境

yum install httpd php php-mysql

1.修改httpd主配置文件ServerName 为www.mywordpress

2.解压缩wordpress 至/var/www/html目录下

3.切换至wordpress目录,cp wp-config-sample.php wp-config.php

4.配置wp-config.php,能够启动wordpress

controller1节点安装nginx,配置反向代理功能

在nginx主配置文件的http配置段中加入cache配置信息

proxy_cache_path    /var/nginx      levels=1:2  keys_zone=proxycache:20M max_size=1g;

[[email protected] conf.d]# mkdir -pv /var/nginx

配置虚拟机反向代理
server {
        listen 80;
        server_name     www.test.com;
        location        /wordpress  {
                proxy_pass      http://9.110.187.121:80/;
                proxy_cache     proxycache;
                proxy_cache_key $request_uri;
                proxy_cache_methods     GET HEAD;
                proxy_cache_valid       200 302 20m;
                proxy_cache_valid       404     5m;
        }

}

访问www.test.com 可以看到效果,ls  /var/nginx 可以看到缓存的文件。

时间: 2024-08-25 00:41:09

09-ngx_http_proxy_module模块的相关文章

Nginx中ngx_http_proxy_module模块

该模块允许将请求传递给另?一台服务器?指令:1 ,proxy_pass设置代理理服务器?的协议和地址以及应映射位置的可选 URI .作为协议,可以指定“ http 或 https .可以将地址指定为域名或IP地址,以及可选端?口Syntax: proxy_pass URL;Default: —Context: location, if in location,limit_except如果 proxy_pass 后?面指定了了 uri ,则其会将 location 指定的 uri 给替换掉loca

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_pass http://host[:port]; 最后没有/     }     ... } 上面示例:http:/

80-nginx_http_proxy,upstream,stream模块简析

一. ngx_http_proxy_module模块: 模块功能: 为后端httpd服务做反向代理, 并且与Httpd 之间使用http进行通信 1.proxy_pass URL; Context: location, if in location, limit_except 当root 与proxy_pass 同时存在是,proxy 优先级更高 ---------------------------------------------------------------------------

http_proxy_module 模块

一.proxy_pass 指令 proxy_pass 指令属于 ngx_http_proxy_module 模块,此模块可以将请求转发到另一台服务器,在实际的反向代理工作中,会通过 location 功能匹配指定的 URI ,然后把接收到的符合匹配 URI 的请求通过 proxy_pass 抛给定义好的 upstream 节点池 location /name/ { # 使用案例 proxy_pass http://127.0.0.1/remote/; } 二.http proxy 模块参数 (1

nginx添加 nginx_heath模块

原因?为什么会使用nginx_heath 这个模块,主要是如nginx+tomcat部署的时,tomcat挂了之后nginx->upstream 轮询是可以踢掉挂掉的tomcat服务的,如果部署的机器挂了之后nginx轮询是不能踢掉的,如果服务再去请求,就会出现请求超时! 1.ngx_http_proxy_module 模块和ngx_http_upstream_module模块(自带) 官网地址:http://nginx.org/cn/docs/http/ngx_http_proxy_modul

Nginx负载均衡组件模块

Nginx负载均衡组件模块 实现Nginx负载均衡的组件主要有两个: n  ngx_http_proxy_module proxy代理模块,用于把请求后抛给服务器节点或upstream服务器池 n  ngx_http_upstream_module 负载均衡模块,可以实现网站的负载均衡功能及节点的健康检查 1.upstream模块 upstream模块允许Nginx定义一组或多组节点服务器组,使用时可以通过proxy_pass代理方式把网站的请求发送到事先定义好的对应upstream组的名字上,

nginx下后端节点realserverweb健康检测模块ngx_http_upstream_check_module

本文章收录做资料使用,非本人原创,特此说明. 公司前一段对业务线上的nginx做了整理,重点就是对nginx上负载均衡器的后端节点做健康检查.目前,nginx对后端节点健康检查的方式主要有3种,这里列出: 1.ngx_http_proxy_module 模块和ngx_http_upstream_module模块(自带) 官网地址:http://nginx.org/cn/docs/http/ngx_http_proxy_module.html#proxy_next_upstream 2.nginx

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

一:ngx_http_proxy_module 反向代理( reverse proxy) 方式是指用代理服务器来接受 Internet 上的连接请求, 然后将请求转发给内部网络中的上游服务器, 并将从上游服务器上得到的结果返回给 Internet 上请求连接的客户端, 此时代理服务器对外的表现就是一个 Web 服务器. 充当反向代理服务器也是 Nginx 的一种常见用法( 反向代理服务器必须能够处理大量并发请求), 下面将介绍Nginx作为 HTTP 反向代理服务器的基本用法.由于Nginx具有

Nginx - upstream 模块及参数测试

目录 - 1. 前言- 2. 配置示例及指令说明    - 2.1 配置示例    - 2.2 指令    - 2.3 upstream相关变量- 3. 参数配置及测试    - 3.1 max_fails 和 fail_timeout    - 3.2 proxy_next_upstream    - 3.3 nginx 与后端web连接时间的三个参数 1. 前言 当 Nginx 作为反向代理使用的时候,upstream模块有着举足轻重的地位,官方解释: 2. 配置示例及指令说明 2.1 配置