shiter 2023-03-01 18:56 采纳率: 71.4%
浏览 191
已结题

django channels 运行一段时间后自动断开

我做了一个目标检测的程序,

  1. 发送端一直检测摄像头的图形,使用websocket 发送检测完成的图像和结果给 django channel
  2. django channel 作为 后端 把接收到的结果 用consumer 给前端页面
  3. 前端页面 在 body 的onload 中 使用js 处理传过来的数据并显示在 img 中

前端核心代码如下:

var ws = new WebSocket(websocket_url);                                                
ws.onmessage = function (evt)                
 { // 处理逻辑 }

https://github.com/django/channels/issues/1981

比较迷惑,而且异常全都是 autobahn.exception.Disconnected

在consumer 中的code 如下:

try:    
    await super().send(json_text_data)
except autobahn.exception.Disconnected:
    await self.disconnect()
    await self.close()

使用的是django channel 4.0 ,发现如果是只用self.close() 是下面的报错,一段时间后还要清除 channel_layer 中的东西应该是

Application instance <Task pending name='Task-2388' coro=<ASGIStaticFilesHandler.__call__() running at C:\Users\wyaning.conda\envs\qalab\lib\site-packages\django\contrib\staticfiles\handlers.py:101> wait_for=<Future pending cb=[<TaskWakeupMethWrapper object at 0x0000027CDCB1B5B0>()]>> for connection <WebSocketProtocol client=['10.167.118.211', 58719] path=b'/ws/ObjectDetection/ObjectDetection0/'> took too long to shut down and was killed.

如果是先用disconnect 那么就是程序发送端也就断了,需要10秒左右重新建立链接,很头大。

报错如下:

img

  • 写回答

6条回答 默认 最新

  • shiter 领域专家: 人工智能技术领域 2023-03-01 19:19
    关注
    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 3月8日
  • 修改了问题 3月2日
  • 修改了问题 3月2日
  • 赞助了问题酬金50元 3月2日
  • 展开全部