python - 在 python 中使用异步或并发技术控制重复检测任务
问题描述
我正在开发一种检测工具,我希望能够通过网络控制它。Web 服务应支持工具启动和停止以及修改检测配置。但我不知道如何使服务和工具并行工作,因为检测工具不断循环通过检测。
我对网络和异步有一些了解。但是我知道的那些方法是关于“阻塞并等待所有可并行任务最终完成”,但我的探测任务应该在激活后不断执行,这让我感到困惑。
我写了一个小例子来说明这一点:</p>
from typing import Optional, List
from fastapi import FastAPI, Query
from pydantic import BaseModel
config = {}
should_detecting = False
is_detecting = False
config_changed = False
def detect_task():
global is_detecting
global config_changed
while should_detecting:
is_detecting = True
result = do_time_consuming_detect(config)
if should_detecting and not config_changed:
send(result)
config_changed = False
is_detecting = False
@app.get(root_route + "/detect")
def do_detect(start_flag: int):
global should_detecting
if start_flag == 1 and is_detecting != True:
should_detecting = True
execute_asynchronously(detect_task)
elif start_flag == 0:
should_detecting = False
return {}
@app.get(root_route + "/update_config")
def update_config(new_config: dict):
global config_changed
config_changed = True
config.update(new_config)
return {}
所以我想知道如何让这个 Web 服务与 detect_task() 并行工作。在此先感谢您的帮助!
解决方案
我找到了答案。因为 fastAPI 提供了 BackgroundTasks 功能,所以你要做的就是把任务放进去。
def detect(flags, ips):
flags['is_detecting'] = True
while flags['should_detect']:
do_some_detect()
flags['is_detecting'] = False
@app.get(root_route + "/detect")
def read_detect(start_flag: int, background_tasks: BackgroundTasks):
if start_flag == 1 and not flags['is_detecting']:
flags['should_detect'] = True
background_tasks.add_task(detect, flags, detecors)
elif start_flag == 0:
flags['should_detect'] = False
return {}
标志和检测器只是作为参数传递给任务的全局变量。
推荐阅读
- python - 导入时的 Pandas 运行时警告
- python - 从许多文件中成对打开两个文件 - python
- php - 如何使用 PHPmailer 发送多封电子邮件
- wpf - 不同大小的 DevExpress-Wpf LayoutItems
- python - 在 numpy 数组中一次访问块
- symfony - Symfony | 表格 | 自引用 CollectionType 字段 - 错误:内存不足
- python - 如何使用 matplotlib 在 Python 3 中操作数据?
- ruby-on-rails - 耙任务以发送电子邮件。我需要排队吗?
- html - 元素超出父级
- python-3.x - tesseract ocr 不适用于文本长度仅为 2 或更少的图像。适用于文本长度大于 3 的图像