Python系列(极具参考意义):配置nginx+uwsgi+django遇到的那些坑

配置nginx+uwsgi+django遇到的那些坑

      • 问题一:`uwsgi`--配置出错 `bind(): Address already in use [core/socket.c line 769]`
      • 问题二:`nginx`转发`WebSocket`请求 `502 Bad Gateway`
      • 问题三:`Django`部署`WebSocket 400`错误处理
      • 问题四:`uwsgi ASYNC call without async mode !!!`




问题一:uwsgi–配置出错 bind(): Address already in use [core/socket.c line 769]

uwsgi已经启动,之前并没有彻底清除进程

#.pid文件中存储的是PID,也可用kill进行清除
uwsgi --stop uwsgi.pid
#8000为使用uwsgi绑定的端口号
sudo fuser -k 8000/tcp

问题二:nginx转发WebSocket请求 502 Bad Gateway

阿里云的网络问题

uwsgi.ini配置里的socket这里不能写127.0.0.1,要写阿里的内网ip地址。

nginx.conf中的uwsgi_pass这里学要写公网ip地址。

问题三:Django部署WebSocket 400错误处理

由于使用协议不一样,所以在请求头中需要做一些修改,在nginx.conf配置文件中修改

location / {
    proxy_http_version 1.1; 
	proxy_set_header Upgrade $http_upgrade;
	proxy_set_header Connection "upgrade";
    uwsgi_pass ......
}

uwsgi.ini配置文件中添加

WEBSOCKET_FACTORY_CLASS = 'dwebsocket.backends.uwsgi.factory.uWsgiWebSocketFactory

问题四:uwsgi ASYNC call without async mode !!!

uwsgi.ini配置文件中修改

#Solution
#threads = 3 #删掉!
async = 30
ugreen = True

注:

1.Websocket请求需要使用ws://......而不是http://......

2.Django中使用使用@accept_websocket进行标注,允许接收websocket报文

3.使用nginx进行转发时,uwsgi.ini配置文件中需要使用socket通信socket=172.17.95.118:8000

4.如果遇到了错误却不知道因何而起,请查看日志记录uwsgi.log,观察其中日志错误,这一条十分重要!!!







编程小菜鸟123

配置nginx+uwsgi+django遇到的那些坑

你可能感兴趣的:(#,python,python,nginx,django)