在项目中使用了webscoket进行实时通讯,但是生产环境又使用了django+nginx+uwsgi的部署方式,我们都知道uwsgi并不能处理websocket请求,所以需要asgi服务器来处理websocket请求,官方推荐的asgi服务器是daphne

1.部署daphne

项目配置文件目录(wsgi.py同级)下创创建文件asgi.py,加入应用:

  1. """
  2. ASGI entrypoint. Configures Django and then runs the application
  3. defined in the ASGI_APPLICATION setting.
  4. """
  5. import os
  6. import django
  7. from channels.routing import get_default_application
  8. os.environ.setdefault("DJANGO_SETTINGS_MODULE", "myproject.settings")
  9. django.setup()
  10. application = get_default_application()
  11. 启动daphne 测试是否正常运行(成功以后退出)
  12. daphne -p 8001 devops.asgi:application

2.安装supervisor

  supervisor是由python实现的一个进程管理工具,可以确保所管理的进程一直运行,当进 

程一点中断supervisord会自动进行重启。

安装步骤

yum安装:

  1. yum install python-setuptools
  2. easy_install supervisor
  3. 或者
  4. yum install -y epel-release
  5. yum install -y supervisor

手动安装:

  1. wget https://pypi.python.org/packages/source/s/supervisor/supervisor-3.1.3.tar.gz
  2. tar zxf supervisor-3.1.3.tar.gz
  3. cd supervisor
  4. python setup.py install

pip安装:

  1. pip install supervisor
  2. 生成配置文件
  3. echo_supervisord_conf > /etc/supervisord.conf

3.使用supervisor管理daphne进程

编辑/etc/supervisord.conf加入配置

  1. [program:daphne]
  2. directory=/opt/app/devops #项目目录
  3. command=daphne -b 127.0.0.1 -p 8001 --proxy-headers devops.asgi:application #启动命令
  4. autostart=true
  5. autorestart=true
  6. stdout_logfile=/tmp/websocket.log #日志
  7. redirect_stderr=true
  8. 启动supervisor
  9. supervisord -c /etc/supervisord.conf
  10. 启动或者停止daphne
  11. supervisorctl start daphne
  12. supervisorctl stop daphne

三、代理webscoket

修改nginx配置文件

  1. /#####转发配置
  2. upstream wsbackend {
  3. server 127.0.0.1:8001;
  4. }
  5. /######location配置
  6. location /ws/deploy {
  7. proxy_pass http://wsbackend;
  8. proxy_http_version 1.1;
  9. proxy_set_header Upgrade $http_upgrade;
  10. proxy_set_header Connection "upgrade";
  11. proxy_redirect off;
  12. proxy_set_header Host $host;
  13. proxy_set_header X-Real-IP $remote_addr;
  14. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  15. proxy_set_header X-Forwarded-Host $server_name;
  16. }

配置asgi来达到能处理websocket的更多相关文章

  1. SpringBoot WebSocket STOMP 广播配置

    目录 1. 前言 2. STOMP协议 3. SpringBoot WebSocket集成 3.1 导入websocket包 3.2 配置WebSocket 3.3 对外暴露接口 4. 前端对接测试 ...

  2. WebSocket长连接

    WebSocket长连接 1.概述 1.1 定义 1.2 原理 2.Django中配置WebSocket 2.1安装第三方法包 pip install channels 2.2 Django 中的配置 ...

  3. Spring 4 官方文档学习(十四)WebSocket支持

    个人提示:如果需要用到页面推送,高频且要低延迟,WebSocket无疑是最佳选择.否则还是轮询和long polling吧. 做了一个小demo放在码云上,有兴趣的可以看一下,简单易懂:websock ...

  4. tomcat 7下spring 4.x mvc集成websocket以及sockjs完全参考指南

    之所以sockjs会存在,说得不好听点,就是因为微软是个流氓,现在使用windows 7的系统仍然有近半,而windows 7默认自带的是ie 8,有些会自动更新到ie 9,但是大部分非IT用户其实都 ...

  5. websocket总结

    一.WebSocket简介 WebSocket  protocol是HTML5一种新的协议,WebSocket 是目前唯一真正实现全双工通信的服务器向客户端推送的互联网技术.WebSocket的出现使 ...

  6. Nginx+uWSIG+Django+websocket的实现

    1.Django+websocket django-websocket dwebsocket django-websocket是旧版的,现在已经没有人维护,dwebsocket是新版的,推荐使用dwe ...

  7. 玩转spring boot——websocket

    前言 QQ这类即时通讯工具多数是以桌面应用的方式存在.在没有websocket出现之前,如果开发一个网页版的即时通讯应用,则需要定时刷新页面或定时调用ajax请求,这无疑会加大服务器的负载和增加了客户 ...

  8. WebSocket 详解教程

    WebSocket 详解教程 概述 WebSocket 是什么? WebSocket 是一种网络通信协议.RFC6455 定义了它的通信标准. WebSocket 是 HTML5 开始提供的一种在单个 ...

  9. websocket+rabbitmq实战

    1. websocket+rabbitmq实战 1.1. 前言   接到的需求是后台定向给指定web登录用户推送消息,且可能同一账号会登录多个客户端都要接收到消息 1.2. 遇坑 基于springbo ...

随机推荐

  1. Android手机的分区以及一些刷机术语的了解

    最早以前的手机基本都是下载一个刷机软件(像刷机精灵.刷机大师),一键root,一键刷机,这就以前的傻瓜式刷机,至少我在高中(2015年开始接触)的时候也是这么干的.那时候,好像有种手机开机界面会出现“ ...

  2. 查看线程CPU利用率

    查看线程CPU利用率 方法1:利用ps命令查看对应的线程 1. ps -ef | grep 进程名称 2. ps -mp 进程ID -o THREAD,pid,tid,cmd,time,%cpu,%m ...

  3. Java隐式类型转换和强制类型转换

    一.强制类型转换 char 和 整型之间的类型转换 char a7 = 'a'; System.out.println(a7); System.out.println( (int)a7 ); Syst ...

  4. 修改Excel脚本

    批量修改Excel TODO: 批量修改Excel 功能: 将图片防止在本地,读取excel数据,拆分数据之后根本地照片名称对比,然后上传服务器,创建新得excel. #!/usr/bin/pytho ...

  5. jq + 面向对象实现拼图游戏

    jq + 面向对象实现拼图游戏 知识点 拖拽事件 es6面向对象 jquery事件 效果图 html: <div class="wraper"> <div cla ...

  6. 前端 JS 获取 Image 图像 宽高 尺寸

    前端 JS 获取 Image 图像 宽高 尺寸 简介 项目中用到获取图片的原始尺寸,然后适配宽高:网上的大部分前端解决方案,都是new Image()后,在onload事件中获取image的尺寸. 在 ...

  7. adb server is out of date. killing... ADB server didn't ACK * failed to start daemon *……

    问题 使用 adb 命令的时候报错如下: adb server is out of date. killing... ADB server didn't ACK * failed to start d ...

  8. number与string的转换

    // number -> string // toString() /* var num = 10; var res = num.toString(); alert(typeof (num)); ...

  9. Synopsys DC综合脚本示例

    #****************************************************************************** # File : syn_example ...

  10. android 子线程使用handle修改主线线程内容

    1.子线程使用handle修改主线线程内容简单案例 1).activity_handle.xml <?xml version="1.0" encoding="utf ...