run_task.py 1006 B

123456789101112131415161718192021222324
  1. import datetime
  2. import logging
  3. from app.core.runner.pub_handler import StreamEventHandler
  4. from app.core.runner.thread_runner import ThreadRunner
  5. from app.providers.celery_app import celery_app
  6. from app.providers.database import session
  7. from app.services.run.run import RunService
  8. @celery_app.task(bind=True, autoretry_for=())
  9. def run_task(self, run_id: str, stream: bool = False):
  10. logging.info(f"[run_task] [{run_id}] running at {datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S')}")
  11. print("vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv")
  12. try:
  13. ThreadRunner(run_id, session, stream).run()
  14. except Exception as e:
  15. print("aawwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwww")
  16. logging.exception(e)
  17. StreamEventHandler(run_id=run_id, is_stream=True).pub_error(str(e))
  18. RunService.to_failed(session=session, run_id=run_id, last_error=e)
  19. finally:
  20. session.close()
  21. print(run_task.apply_async(args=('676588628cba3cec56de2be5', True)))