Nginx中的反向代理

一、ngx_http_proxy_module模块:(可通过不同的location实现动静分离)

转发请求至另一台主机

proxy_pass URL;

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

server {
server_name HOSTNAME;
location /uri/ {
proxy_pass http://host[:port]; 注意:最后没有/
}
}

上面示例:http://HOSTNAME/uri --> http://host/uri ,功能类似 root

如果上面示例中有 /,即:http://host[:port]/ 此方式较少使用

意味着:http://HOSTNAME/uri --> http://host/ 即置换,功能类似 alias

案例1:实现简单的反向代理

vim test.conf 
server {
      listen 80 ;
      server_name www.magedu.net;
      root /data/ssl;
      location / {
         proxy_pass http://192.168.43.103 ;
      }
}
server {
     listen 9001;
     server_name www.apix.com ;
     location / {
         proxy_pass http://192.168.43.103 ;
     }
}
[root@centos7 ~]# systemctl restart httpd
[root@centos7 ~]# echo 192.168.43.103 > /var/www/html/index.html
[root@centos7 ~]# curl 192.168.43.103
192.168.43.103
[root@centos6 ~]# curl www.apix.com:9001
192.168.43.103

二、proxy_set_header field value;

设定转发往后端主机的请求报文的请求首部的值;

Context: http, server, location

proxy_set_header X-Real-IP $remote_addr;

proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

请求报文的标准格式如下:

X-Forwarded-For: client1, proxy1, proxy2

案例2:RS日志中显示客户端IP

nginx服务器

vim /etc/nginx/conf.d/test.conf 
server {
      listen 80 ;
      server_name www.magedu.net;
      root /data/ssl;
      location / {
         proxy_pass http://192.168.43.103 ;
         proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
      }
}
vim /etc/httpd/conf/httpd.conf
   # LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined
    LogFormat "\"%{X-Forwarded-For}i\" %h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined
tail -f /var/log/httpd/access_log
"192.168.43.100" 192.168.43.101 - - [25/Jul/2020:10:43:26 +0800] "GET / HTTP/1.0" 200 15 "-" "curl/7.19.7 (x86_64-redhat-linux-gnu) libcurl/7.19.7 NSS/3.27.1 zlib/1.2.3 libidn/1.18 libssh2/1.4.2"

三、启用用于反向代理的缓存功能(proxy_cache_path)

1、主配置文件中配置

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];

2、在http配置定义缓存信息

proxy_cache_path /var/cache/nginx/proxy_cache #定义缓存保存路径,proxy_cache会自动创建

levels=1:2:2 #定义缓存目录结构层次,1:2:2 可以生成24x28x2^8=1048576个目录 ###keys_zone=proxycache:20m #指内存中缓存的大小,主要用于存放key和metadata(如:使用次数)

inactive=120s; #缓存有效时间

max_size=1g; #最大磁盘占用空间,磁盘存入文件内容的缓存空间最大值

3、server中调用缓存配置

(1)proxy_cache zone | off; 默认off

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

(2)proxy_cache_key string;

缓存中用于“键”的内容

默认值:proxy_cache_key schemeproxy_host$request_uri;

(3)proxy_cache_valid [code ...] time;

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

定义在http{...}中

示例:

proxy_cache_valid 200 302 10m;

proxy_cache_valid 404 1m;

案例3:启用反向代理的缓存功能

vim /etc/nginx/nginx.conf
http {
    proxy_cache_path /var/cache/nginx/proxy_cache levels=1:2:2 keys_zone=proxycache:20m inactive=120s max_size=1g;(proxycache:20m 指内存中缓存的大小,主要用于存放key和metadata,max_size=1g 指磁盘存入文件内容的缓存空间最大值)
}
mkdir /var/cache/nginx
vim /etc/nginx/conf.d/test.conf 
server {
      listen 80 ;
      server_name www.magedu.net;
      root /data/ssl;

      proxy_cache proxycache;
      proxy_cache_key $request_uri;
      proxy_cache_valid 200 302 301 1h;
      proxy_cache_valid any 1m;

      location / {
         proxy_pass http://192.168.43.103 ;
         proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
      }
}

结果如下

[root@centos7 conf.d]# tree /var/cache/nginx/
/var/cache/nginx/
└── proxy_cache
    └── 9
        └── 7d
            └── cc
                └── 6666cd76f96956469e7be39d750cc7d9

3、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 ...

在被代理的后端服务器出现哪种情况下,可直接使用过期的缓存响应客户端

4、proxy_cache_methods GET | HEAD | POST ...;

对哪些客户端请求方法对应的响应进行缓存,GET和HEAD方法总是被缓存

四、反向代理中头部信息处理

1、proxy_hide_header field;

用于隐藏后端服务器特定的响应首部,默认nginx在响应报文中不传递后端服务器的首部字段Date, Server, X-Pad, X-Accel等

示例:

proxy_hide_header Etag;

2、proxy_pass_header field;

默认nginx在响应报文中不传递后端服务器的首部字段Date, Server, X-Pad, X-Accel等参数,如果要传递的话则要使用 proxy_pass_header field声明将后端服务器返回的值传递给客户端

3、ngx_http_headers_module模块

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

4、add_header name value [always];

添加自定义首部

add_header X-Via $server_addr;

add_header X-Cache $upstream_cache_status;

add_header X-Accel $server_name;

5、add_trailer name value [always];

添加自定义响应信息的尾部, 1.13.2版后支持

6、反向代理性能调整

(1)proxy_connect_timeout time;

定义与后端服务器建立连接的超时时长,如超时会出现502错误,默认为60s,一般不建议超出75s

(2)proxy_send_timeout time;

对后端服务器send,将请求发送给后端服务器的超时时长;默认为60s

(3)proxy_read_timeout time;

从后端服务器read,等待后端服务器发送响应报文的超时时长,默认为60s

(4)proxy_ignore_client_abort off;

当客户端网络中断请求时,nginx服务器中断其对后端服务器的请求。即如果此项设置为on开启,则服务器会忽略客户端中断并一直等着代理服务执行返回,如果设置为off,则客户端中断后nginx也会中断客户端请求并立即记录499日志,默认为off

(5)proxy_http_version 1.0;

用于设置nginx提供代理服务的HTTP协议的版本,默认http 1.0

(6)proxy_headers_hash_bucket_size 128;

当配置了 proxy_hide_header和proxy_set_header的时候,用于设置nginx保存HTTP报文头的hash表的上限

(7)proxy_headers_hash_max_size 512;

设置proxy_headers_hash_bucket_size的最大可用空间

(8)server_namse_hash_bucket_size 512;

server_name hash表申请空间大小

(9)server_names_hash_max_size 512;

设置服务器名称hash表的上限大小

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,793评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,567评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,342评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,825评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,814评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,680评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,033评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,687评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,175评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,668评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,775评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,419评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,020评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,206评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,092评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,510评论 2 343