通常情况下,部署Django应用到生产环境时都会通过uwsgi部署,uwsgi一些配置项配置问题有可能会导致服务出现502状态码或者其他超时等的情况
常用到的配置项如下:
reload-on-as = 600 reload-on-rss = 500 evil-reload-on-rss = 800 ignore-sigpipe = true ignore-write-errors = true disable-write-exception = true buffer-size=16384 http-timeout=300
1. reload-on-as/reload-on-rss/evil-reload-on-rss: 内存占用相关配置,单位M,当worker占用内存超过这些配置时该worker会重启,worker频繁重启可能会导致每次请求worker都要重启加载所有的资源,建立所有的数据库连接,进而导致正常的api请求超时
2. buffer-size: 请求头大小限制,后台管理经常会出现超出默认配置4096的情况,此时会出现502状态码
定位流程:
查看uwsgi.log日志,观察是否有异常的重启日志
本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Django uwsgi问题解析 - Python技术站