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

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日
  • 展开全部

悬赏问题

  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭
  • ¥15 2020长安杯与连接网探
  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂