通常情况下,部署Django应用到生产环境时都会通过uwsgi部署,uwsgi一些配置项配置问题有可能会导致服务出现502状态码或者其他超时等的情况
常用到的配置项如下:
reload-on-as = 600reload-on-rss = 500evil-reload-on-rss = 800ignore-sigpipe = trueignore-write-errors = truedisable-write-exception = truebuffer-size=16384http-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日志,观察是否有异常的重启日志
菜鸟程序员,博客只做记录,可能问题很多,有问题,还望不吝指出!转载请附上原文地址,谢谢!