Nginx反向代理的使用及原理

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Nginx反向代理的使用及原理相关的知识,希望对你有一定的参考价值。

参考技术A 正向代理,用通俗的方式来说,就是代理服务器只起到转发的作用,例如,在顾客进商店购买东西,商店就是一个正向代理,起到的作用就是把商品从厂家代理售卖到顾客手中。

反向代理,就是顾客的请求是确定的,但将商品的需求信息发送给代理商之后,代理商通过各种方式寻找不同的供货商,再把供货商提供的商品转交给顾客。顾客是不知道代理商背后的供货商是谁的。这种方式有点类似于目前的“三只松鼠”等网络直销平台的逻辑,顾客发送芒果干的请求给三只松鼠,三只松鼠从全国进行供货商的选择,拿到货品后再打上三只松鼠的logo转交给顾客,实现反向的代理,代理的是供货商,顾客不知道具体的供应商是谁(所以才会要求包装上需要印上供应商的名称和地址,要不然出问题都不知道找谁。)

nginx的安装网络有很多资源,包括Linux和Windows的,在此不表。主要关注一下如何进行配置,来看看 nginx.conf.default 中的配置信息:

可以看到,主要的几个配置模块:

下面主要讲讲经常使用的server以及location的配置。

gzip压缩中

对于阿里云上的配置,我们直接使用一级域名 abc.com 解析阿里云服务器的IP地址:

Nginx-缓冲原理及优化

一、作用及原理

  作用: 使用缓冲释放后端服务器

  反向代理的一个问题是代理大量用户时会增加服务器进程的性能冲击影响。在大多数情况下,可以很大程度上能通过利用Nginx的缓冲和缓存功能减轻。当代理到另一台服务器,两个不同的连接速度会影响客户的体验:

    1.从客户机到Nginx代理的连接

    2.从Nginx代理到后端服务器的连接

  如果没有缓冲,数据从代理的服务器发送并立即开始被发送到客户。如果假定客户端很快,缓冲可以关闭而尽快使数据到客户端,有了缓冲,Nginx代理将暂时存储后端的响应(缓冲到内存),然后按需供给数据给客户端。如果客户端是缓慢的,允许Nginx服务器关闭到后端的连接。然后,它可以处理数据分配到客户端,以任何可能的速度。

  Nginx默认有缓冲设计,因为客户端往往有很大的不同的连接速度。我们可以用指令调节缓冲行为。可以在HTTP,server或location位置来设置。重要的是要记住,大小size指令是针对每个请求配置的,所以增加超出你需求会影响你的性能。

二、配置项详解

  fastcgi/proxy 缓冲原理和配置是一样的。

  缓冲区的大小主要由 *_buffers 和 *_buffer_size 两个值控制。下面以默认值来讲解。

    *_buffers 控制 nginx 最多创建 8 个大小为 4K 的缓冲区。

    *_buffer_size 则是处理 Response 时第一个缓冲区的大小,不包含在前者中。

  所以总计能创建的最大内存缓冲区大小是 8 * 4K + 4K = 36k。而这些缓冲区是根据实际的 Response 大小动态生成的,并不是一次性创建的。比如一个 8K 的页面,Nginx 会创建 2 * 4K 共 2 个 buffers。  当 Response 小于等于 36k 时,所有数据当然全部在内存中处理。如果 Response 大于 36k 呢?*_temp 的作用就在于此。多出来的数据会被临时写入到文件中,放在这个目录下面

  client_body_buffer_size 处理客户端请求体buffer大小。用来处理POST提交数据,上传文件等。client_body_buffer_size 需要足够大以容纳如果需要上传POST数据。

  fastcgi_buffers,proxy_buffers 处理后端响应。如果这个buffer不够大,会引起磁盘IO。需要注意的是它们有一个上限值,这个上限值受 fastcgi_max_temp_file_size 、 proxy_max_temp_file_size控制。

三、优化

以上是关于Nginx反向代理的使用及原理的主要内容,如果未能解决你的问题,请参考以下文章

问题解决1:nginx反向代理丢失js、css问题

通俗易懂正向代理与反向代理的技术原理与使用场景

k8s部署nginx的url反向代理初探

简单介绍nginx反向代理及使用

Nginx详解(正向代理反向代理负载均衡原理)

宝塔面板Nginx反向代理解决跨域问题