ZBLOG

gin Post请求执行时间过长,怎么实现先返回一个jobid,然后通过jobid获取Post最后执行的结果 示例

以下是一个示例实现:

  1. 客户端发起POST请求,服务端返回一个jobid,表示任务已经开始处理。

  2. 客户端可以通过GET请求访问/job/来获取任务的执行状态。如果任务正在执行,则返回状态码200和一个JSON对象,包含当前状态和进度信息;如果任务已经完成,则返回状态码200和最终结果数据;如果jobid不存在或已经过期,则返回状态码404。

  3. 服务端在处理完POST请求之后,将结果存储到数据库中,并标记该jobid为已完成。当客户端发送GET请求时,服务端从数据库中读取相应的数据并返回给客户端。

  4. 可以设置一个超时时间,在超时时间内未能完成任务则自动取消并删除该任务。

示例代码如下(仅供参考):

  1. from flask import Flask, jsonify, request
  2. import time
  3. import uuid
  4. app = Flask(__name__)
  5. # 存储job状态的字典
  6. jobs = {}
  7. @app.route('/post', methods=['POST'])
  8. def post():
  9. # 生成随机的jobid
  10. jobid = str(uuid.uuid4())
  11. # 记录job开始时间
  12. start_time = time.time()
  13. # 将job信息存储到jobs字典中
  14. jobs[jobid] = {'status': 'running', 'progress': 0}
  15. # 模拟长时间处理任务(这里sleep了10秒)
  16. time.sleep(10)
  17. # 更新job信息,将结果存入数据库等操作...
  18. jobs[jobid]['status'] = 'done'
  19. jobs[jobid]['result'] = {'data': 'some data'}
  20. return jsonify({'jobid': jobid}), 200
  21. @app.route('/job/<jobid>', methods=['GET'])
  22. def get_job_status(jobid):
  23. if jobid not in jobs:
  24. return jsonify({'error': 'Job not found'}), 404
  25. # 模拟长时间处理任务,更新progress
  26. time.sleep(1)
  27. jobs[jobid]['progress'] += 10
  28. # 如果任务已经完成,则返回最终结果
  29. if jobs[jobid]['status'] == 'done':
  30. return jsonify(jobs[jobid]['result']), 200
  31. # 如果任务正在执行,则返回当前进度和状态信息
  32. elif jobs[jobid]['status'] == 'running':
  33. return jsonify(jobs[jobid]), 200
  34. if __name__ == '__main__':
  35. app.run(debug=True)

在这个示例中,我们通过将job信息存储到jobs字典中来跟踪任务的执行状态。当客户端发起POST请求时,我们生成一个随机的jobid并记录该任务开始时间,并将其状态设置为’running’。在模拟长时间处理任务后,我们更新了job信息,并将其状态设置为’done’。当客户端发送GET请求时,我们从jobs字典中读取相应的数据并返回给客户端。注意,在获取任务状态时需要模拟长时间处理以更新进度信息。

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://golang.0voice.com/?id=4573

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?