西芹Flask

2024-04-24 20:44:56 发布

您现在位置:Python中文网/ 问答频道 /正文

我有一个简单的flask restful API,我想把请求作为芹菜任务来执行,因为有些端点需要大量的执行时间。你知道吗

你知道吗主.py地址:

from flask import Flask
from flask_restful import Api
from flask_celery import make_celery

app = Flask(__name__)
app.config['CELERY_BROKER_URL'] = 'redis://localhost:6379/0',
app.config['CELERY_RESULT_BACKEND'] = 'redis://localhost:6379/0'

celery = make_celery(app)
api = Api(app)

api.add_resource(someResource, '/someendpoint/')

if __name__ == '__main__':
    app.run(debug=True)

带make_芹菜.py地址:

from celery import Celery

def make_celery(app):
    celery = Celery(
        app.import_name,
        backend=app.config['CELERY_RESULT_BACKEND'],
        broker=app.config['CELERY_BROKER_URL']
    )
    celery.conf.update(app.config)

    class ContextTask(celery.Task):
        def __call__(self, *args, **kwargs):
            with app.app_context():
                return self.run(*args, **kwargs)

    celery.Task = ContextTask
    return celery

我现在要定义我在中定义的资源资源.py是芹菜任务:

class Cost(Resource):

    def get(self):

        result = some_code 

        return result

让get方法成为芹菜任务最方便的方法是什么?你知道吗

非常感谢!你知道吗


Tags: namefrompyimportselfrestfulconfigapp