Nginx反向代理工作原理简介与配置详解

简介: Nginx反向代理工作原理简介与配置详解

Nginx反向代理工作原理简介与配置详解

 


测试环境

CentOS 6.5-x86_64

 

nginx-1.10.0

下载地址:http://nginx.org/en/download.html

下载地址:http://pan.baidu.com/s/1skNT7zv

 

安装nginx

[root@localhost mnt]# tar -xzvf nginx-1.10.0.tar.gz

[root@localhost mnt]# cd nginx-1.10.0

[root@localhost nginx-1.10.0]# ./configure --prefix=/usr/local/ngnix --with-pcre=/mnt/pcre-8.36

Configuration summary

 + using PCRE library: /mnt/pcre-8.36

 + OpenSSL library is not used

 + using builtin md5 code

 + sha1 library is not found

 + using system zlib library

 

 nginx path prefix: "/usr/local/ngnix"

 nginx binary file: "/usr/local/ngnix/sbin/nginx"

 nginx modules path: "/usr/local/ngnix/modules"

 nginx configuration prefix: "/usr/local/ngnix/conf"

 nginx configuration file: "/usr/local/ngnix/conf/nginx.conf"

 nginx pid file: "/usr/local/ngnix/logs/nginx.pid"

 nginx error log file: "/usr/local/ngnix/logs/error.log"

 nginx http access log file: "/usr/local/ngnix/logs/access.log"

 nginx http client request body temporary files: "client_body_temp"

 nginx http proxy temporary files: "proxy_temp"

 nginx http fastcgi temporary files: "fastcgi_temp"

 nginx http uwsgi temporary files: "uwsgi_temp"

 nginx http scgi temporary files: "scgi_temp"

 

注:

1、编译时,指定了pcre安装目录,但是安装出错,解决方法如上,指定源码所在目录

2、如果不指定--with-pcre选项,会报类似如下的错误

3、需要预先安装gcc-c++

 

[root@localhost nginx-1.10.0]# make && make install

启动ngnix

[root@localhost nginx-1.10.0]# /usr/local/ngnix/sbin/nginx -c /usr/local/ngnix/conf/nginx.conf

 

反向代理工作原理

客户端向反向代理发送请求,接着反向代理转发请求至目标服务器,并把获得的内容返回给客户端

 

反向代理配置

测试链接:

http://192.168.1.104/zentaopms/www/index.php

http://192.168.1.104/zentaopms/www/index.php?m=project&f=create

 

如上,想通过192.168.1.103代理服务器访问上述测试链接,具体咋操作呢?如下

 

编辑所使用的配置文件

[root@localhost nginx-1.10.0]# vim /usr/local/ngnix/conf/nginx.conf

 

找到“Server”结点,增加入下带背景色内容

   server {

       listen       80;

       server_name  localhost;

 

       #charset koi8-r;

 

       #access_log  logs/host.access.log  main;

 

       location / {

           root   html;

           index  index.html index.htm;

       }

 

       #error_page  404              /404.html;

 

       # redirect server error pages to the static page /50x.html

       #

       error_page   500 502 503 504  /50x.html;

       location = /50x.html {

           root   html;

       }

 

       location /zentaopms/www/ {

           proxy_pass http://192.168.1.104;

       }

       # proxy the PHP scripts to Apache listening on 127.0.0.1:80

       #

       #location ~ \.php$ {

       #    proxy_pass   http://127.0.0.1;

       #}

 

重新加载配置文件

[root@localhost nginx-1.10.0]# /usr/local/ngnix/sbin/nginx -s reload

 

访问测试url

如下,OK

 

 

说明:

传递请求给被代理服务器

为了把请求传递给被代理服务器,需要在location中指定proxy_pass机制。如下

 

location /some/path/ {

   proxy_pass http://www.example.com/link/;

}

 

proxy_pass既可以是ip地址,也可以是域名,同时还可以指定端口

 

location ~ \.php {

   proxy_pass http://127.0.0.1:8000;

}

 

注意:如果proxy_pass指定的地址携带了URI,如上例中/link/,那么这里的URI将替换请求URI中匹配location参数的部分,比如请求/some/path/page.html,将被替换为http://www.example.com/link/page.html

 

另外,如果请求不是发往http类型的被代理服务器,则选择如下之一:

  • fastcgi_pass  传递请求给FastCGI服务器
  • uwsgi_pass传递请求给uwsgi服务器
  • scgi_pass传递请求给SCGI服务器
  • memcached_pass传递请求给memcached服务器

 

请求也可以发往一命名的组服务器,这种请求下,将根据指定方法,在这些服务器之中进行请求的分发。

 

传递请求头

默认的,nginx在被代理请求中定义两个头域:HostConnection,并且清除包含空值的头域。Host被设置为$proxy_host变量,而Connection则被设置为close

 

使用proxy_set_header机制可修改默认配置及其它头域的值。可以在location中,server上下文,http块或者其它更高层级中指定这种机制。

 

例子:

location /some/path/ {

   proxy_set_header Host $host;

   proxy_set_header X-Real-IP $remote_addr;

   proxy_pass http://localhost:8000;

}

 

如果想阻止某个头域被传递给被代理服务器,可以如下设置头域的值为空

location /some/path/ {

   proxy_set_header Accept-Encoding "";

   proxy_pass http://localhost:8000;

}

 

配置缓冲(Buffer)

默认的,Ngnix buffering来自被代理服务器的响应。Ngnix在内部buffering中存储响应,直到收到整个响应后才发送给客户端。对于慢客户端来说,buffering可优化性能,这样,如果响应从Nginx同步传递给客户端,这将会浪费被代理服务器的时间。但是,如果开启bufferingNginx允许被代理服务器快速处理请求,因为Nginx会尽可能久的存储来自被代理服务器的响应,直到客户端下载它们。

 

使用proxy_buffering机制开启或关闭缓冲。默认的,开启缓冲。

 

proxy_buffers控制buffer大小和分配给请求的buffer数量。来自被代理服务器响应中的第一部分被存储在单一的buffer中,该buffer的大小由proxy_buffer_size设定。该部分通常包含一个相对较小的响应头,其大小可以设置成比用于存储剩余响应部分buffer小。

 

例子:

location /some/path/ {

   proxy_buffers 16 4k;

   proxy_buffer_size 2k;

   proxy_pass http://localhost:8000;

}

 

如果关闭buffering,当从被代理服务器接收到响应时,将被同步把响应发往客户端。这对于想尽快收到请求的快速交互客户端来说。这是其想要的。

 

例子:关闭buffering

location /some/path/ {

   proxy_buffering off;

   proxy_pass http://localhost:8000;

}

 

这种情况下,nginx只用proxy_buffer_size来存储响应的当前部分。

 

选择一个出口IP地址

如果代理服务器有多个网络接口,有时候需要选择特定的源ip地址来连接到代理服务器。当被代理服务器被设置为只接受来自特定IP地址或者IP范围的连接请求时,这特别有用。

 

例:

location /app1/ {

   proxy_bind 127.0.0.1;

   proxy_pass http://example.com/app1/;

}

 

location /app2/ {

   proxy_bind 127.0.0.2;

   proxy_pass http://example.com/app2/;

}

 

ip地址也可以是一个变量

例:

location /app3/ {

   proxy_bind $server_addr;

   proxy_pass http://example.com/app3/;

}

 

参考链接:

https://www.nginx.com/resources/admin-guide/reverse-proxy/

 

 

目录
相关文章
|
2天前
|
缓存 Java 应用服务中间件
nginx的正向代理和反向代理以及tomcat
Nginx的正向代理和反向代理功能在不同的场景中具有重要作用,正向代理主要用于客户端访问控制和匿名浏览,而反向代理则用于负载均衡和高可用性服务。Tomcat作为Java Web应用服务器,与Nginx结合使用,可以显著提升Web应用的性能和稳定性。通过合理配置Nginx和Tomcat,可以构建高效、稳定和可扩展的Web服务架构。
43 11
|
10天前
|
存储 应用服务中间件 nginx
nginx反向代理bucket目录配置
该配置实现通过Nginx代理访问阿里云OSS存储桶中的图片资源。当用户访问代理域名下的图片URL(如 `http://代理域名/123.png`)时,Nginx会将请求转发到指定的OSS存储桶地址,并重写路径为 `/prod/files/2024/12/12/123.png`。
43 5
|
26天前
|
负载均衡 前端开发 应用服务中间件
负载均衡指南:Nginx与HAProxy的配置与优化
负载均衡指南:Nginx与HAProxy的配置与优化
47 3
|
1月前
|
安全 应用服务中间件 网络安全
如何测试Nginx反向代理实现SSL加密访问的配置是否正确?
如何测试Nginx反向代理实现SSL加密访问的配置是否正确?
61 3
|
1月前
|
安全 应用服务中间件 网络安全
配置Nginx反向代理实现SSL加密访问的步骤是什么?
我们可以成功地配置 Nginx 反向代理实现 SSL 加密访问,为用户提供更安全、可靠的网络服务。同时,在实际应用中,还需要根据具体情况进行进一步的优化和调整,以满足不同的需求。SSL 加密是网络安全的重要保障,合理配置和维护是确保系统安全稳定运行的关键。
121 3
|
Web App开发 应用服务中间件 PHP
|
1月前
|
缓存 应用服务中间件 网络安全
Nginx中配置HTTP2协议的方法
Nginx中配置HTTP2协议的方法
107 7
|
2月前
|
应用服务中间件 BI nginx
Nginx的location配置详解
【10月更文挑战第16天】Nginx的location配置详解
|
2月前
|
缓存 负载均衡 安全
Nginx常用基本配置总结:从入门到实战的全方位指南
Nginx常用基本配置总结:从入门到实战的全方位指南
350 0
|
1月前
|
缓存 负载均衡 算法
如何配置Nginx反向代理以实现负载均衡?
如何配置Nginx反向代理以实现负载均衡?