目录

一.前端配置

二.django项目中配置

三.nginx配置

四.uwsgi配置

参考链接:


若不使用uwsgi+nginx部署项目,则不需要相关配置,且不需要ws转为wss(即ws+ssl),当在服务器中使用https访问,且通过uwsgi+nginx实现负载均衡等功能时,需要进行相关配置后才可使用。

一.前端配置

ws转wss,主要是为了提高安全性,wss是websocket的加密形式,需要配置ssl证书,如果服务器已在nginx中配置https访问(已安装证书),则不需要则配置ssl证书。

前端配置改变不多,只需要将ws换为wss即可。

// var socket = new WebSocket("ws://"+window.location.host+"/ws/ecpy/wsconnect/");
    var socket = new WebSocket("wss://"+window.location.host+"/ws/ecpy/wsconnect/");

其余地方和使用ws没有区别,就不再展开叙述.

二.django项目中配置

首先说明websocket是使用的第三方库dwebsocket,没有使用官方推荐的channels模块,因为channles文档很繁琐,讲的不清楚,而dwebsocket开箱即用很方便,官网地址如下:GitHub - duanhongyi/dwebsocket: A websocket Protocol for django

为了使用uwsgi启动项目,需要在django项目中的settings.py中设置如下参数:

nginx转发太卡 nginx转发ws_django

 具体的视图函数处理不需要改变。

三.nginx配置

使用nginx+uwsgi+django部署项目客户端发起websocket连接时,首先会将wss连接发送给nginx服务器,然后再转发给django服务器,返回时刚好相反。

nginx的详细配置也不再展开,只讲一下websocket的配置部分。

location /ws/app/yqwsconnect {
		             access_log /usr/local/nginx/logs/come-websocket.log;
		             proxy_pass http://localhost:8000; 
 # 这里的端口号要和uwsgi配置中的http对应的参数一直
		             proxy_read_timeout 60s;
		             proxy_http_version 1.1;
		            proxy_set_header Upgrade $http_upgrade;
		             proxy_set_header Connection 'Upgrade';
		   }

nginx转发太卡 nginx转发ws_django_02

 8000端口是uwsgi启动django项目时服务器所在端口号

这里的nginx配置是默认已配置了ssl证书用于支持https,所以需要重新配置.

四.uwsgi配置

#uwsgi配置文件
[uwsgi]
#Django程序所在服务器端口号,配置wss时需要和nginx中对应的端口号一致
http=:8000
#django项目根目录,全路径
chdir=/home/lighthouse/code/myweb/datamanger
#django项目中wsgi.py文件路径,以.分隔
module=keshihua.wsgi
#masyer=True表示以主进程模式运行
master=true
#websocket
http-websockets = True
#运行进程数目
processes=10
#设置socket,用于与nginx通信
socket=127.0.0.1:8001
chmod-socket=662
#退出时清楚Python、Django虚拟环境变量
vacuum=true
buffer-size = 65536

参考链接:

关于dwebsocket部署 uwsgi、nginx的那些报错 坑我一天