在开发过程中,耗时长,超时的任务经常发生,比如:获取后端某个大文件数据超时、需要后端计算任务超时,等等,

此时我们就会很自然的想到异步方式,根据需要完成的任务创建一个task_id, 由前端来监听该任务是否完成。

本文主要分享:flask中实现异步功能--celery,【后续django异步待更新】

flask 中使用celery,只需要简单四步:

1.初始化celery【配置broker 和 backend】

  celery = Celery('celery_demo', broker=app.config.get('CELERY_BROKER_URL'),backend=app.config.get('CELERY_BACKEND_URL'))

2.在需要异步执行的方法上使用@celery.task装饰器

  @celery.task

  def add(a,b):

    return a+b

3.在方法调用时,需要使用fun.delay(args)

  add.delay(1,2)

4.celery 启动

  celery -A apps.celery worker -l info --concurrency=3

坑:在使用celery异步进行数据库进行交互时,务必手动断开连接,否则容易造成,lost connection error

最新文章

  1. 应用程序框架实战二十一:DDD分层架构之仓储(介绍篇)
  2. Zxing库
  3. Android学习十一:高德地图使用
  4. redis启动流程介绍
  5. [deviceone开发]-数据绑定示例
  6. Windows Azure 上传 VM
  7. Uncaught RangeError: Maximum call stack size exceeded解决思路
  8. Java注解全面解析
  9. Angular2 从0到1 (二)
  10. 分页控件AspNetPager学习笔记
  11. App 监控、推广
  12. plugins/python/uwsgi_python.h:2:20: fatal error: Python.h: No such file or directory
  13. python写一个DDos脚本(DOS)
  14. 信用卡3D验证相关资料
  15. 将img设置成div背景图片
  16. CentOS7编译安装MySQL5.7.24
  17. Liferay7 BPM门户开发之10: 通用流程实现从Servlet到Portlet(Part1)
  18. Qt_颜色选择对话框(QColorDialog)
  19. 到浏览器顶部的获取js和jquery
  20. Python进阶【第四篇】函数

热门文章

  1. GRPC与.net core
  2. MYSQL事务之Yii2.0商户提现
  3. TCP/IP网络协议
  4. top命令输出详解
  5. Anemic Model
  6. S7-1200 的运动控制
  7. 关于AndroidStudio在编译时无法解析和拉取依赖的问题和无法访问Jcenter服务器的问题
  8. 5. xadmin 后台搭建
  9. Bzoj 1537: [POI2005]Aut- The Bus 题解 [由暴力到正解]
  10. 【动态规划DP】传娃娃-C++