django – 如果你只发送JSON对象,那么适当的NGINX配置是什么?

我是iOS开发人员,我的后端都是用Django编写的.我使用gunicorn作为我的HTTP服务器.我有三个工人在一个小EC2实例上运行.

我的iOS应用不需要任何图像或静态内容.最多,我每次请求一次发送1-20个JSON对象.每个JSON对象最多包含5-10个字段.

我对NGINX很新.我听说它可以做代理缓冲.我想为慢速客户端添加代理缓冲,但我不知道用于以下模块的适当特定设置:

proxy_buffers
Syntax:     proxy_buffers number size
Default:    8 4k|8k
Context:    http server location
Reference:  proxy_buffers


proxy_busy_buffers_size
Syntax:     proxy_busy_buffers_size size
Default:    8k|16k
Context:    http server location
Reference:  proxy_busy_buffers_size

proxy_buffer_size
Syntax:     proxy_buffer_size size
Default:    4k|8k
Context:    http server location
Reference:  proxy_buffer_size

我知道如何使用的唯一设置(非常悲伤)如下所示:

proxy_buffering
Syntax:     proxy_buffering on | off
Default:    on
Context:    http server location
Reference:  proxy_buffering

这种失落的灵魂将非常感谢您在这方面的专业知识!

最佳答案:

proxy_buffers

该数字定义了nginx将创建的缓冲区数量以及每个缓冲区的大小.当nginx开始从上游接收数据时,它开始填充这些缓冲区,直到缓冲区已满或上游发送EOF或EOT.如果满足这两个条件中的任何一个,nginx会将缓冲区的内容发送到客户端.

如果客户端没有足够快地读取缓冲区,它将尝试将它们的内容写入磁盘并在客户端能够接收时发送它们.

获取JSON响应的平均大小.现代磁盘和文件系统甚至可以处理巨大的缓冲区大小,但是您应该使用2的强大功能,并通过在数量和大小之间创建良好的平衡来加速缓冲过程.

proxy_busy_buffers_size

这些缓冲区已经传递到下游但尚未完全发送,因此无法重复使用.该指令限制了此类缓冲区的最大总大小,因此允许使用剩余的缓冲区来读取上游响应.

proxy_buffer_size

始终在使用的主缓冲区.即使你禁用了proxy_buffering,nginx仍然会填满这个缓冲区,并在它满或EOF / EOT时立即刷新它.

proxy_max_temp_file_size

如果缓冲区已满,则该指令控制可以将多少数据写入磁盘(仍然使用内存缓冲区,因为您需要它们与磁盘通信).如果所有缓冲区和此文件都已满,nginx将停止从上游读取,并且必须等待下游才能获取数据,然后才能继续执行相同的过程.

上一篇:Django频道制作Nginx


下一篇:python – Flask Gunicorn app无法让__name__等于’__main__’