首页 > 解决方案 > 如何用户计划库每分钟运行一次功能

问题描述

当我使用计划(库链接)每 1 分钟运行一次函数时。它工作正常,但我的其他 URL 不起作用。只有预定的功能工作。

#import scheduler library
import schedule
import time    

#update every hour global table no of players and totol payouts
def updateTotalPayoutsAndTotalPlayers():
    try:
        querysetGlobal = Global.objects.filter().first()
        querysetUser = Players.objects.filter(is_active=1).count()
        querysetTotalPayouts = Game.objects.filter(gameStatusId=3).aggregate(Sum('pot'))
        totalPayouts = querysetTotalPayouts['pot__sum']
        # print("total payouts : ",totalPayouts)
        querysetGlobal.totalPlayers = querysetUser
        querysetGlobal.totalPayouts = 0 if totalPayouts==None else totalPayouts

        querysetGlobal.save()
        # print("completed task......")

    except Exception as e:
        print("error updating payouts and no of players : ", e) 


#update globals table called ever one minute
schedule.every(1).minutes.do(updateTotalPayoutsAndTotalPlayers)

while True:
    schedule.run_pending()
    time.sleep(1) 

当我在其他 API 工作时删除。但我的日程安排不会运行。

运行服务器我使用了命令:python manage.py runserver

标签: pythondjangodjango-rest-frameworkschedule

解决方案


from celery import shared_task
@shared_task(bind=True, default_retry_delay=10, max_retries=5)
    def my_func(self):
        ***some code***

或者尝试这样的事情:

@periodic_task(run_every=timedelta(seconds=60))
def my_func():
    ***some code***

在此之前在 Linux/Windows/Mac 上安装 redis 服务器并使pip install redis

在您的设置中:

# Redis/Celery application definition
REDIS_HOST = '127.0.0.1'
REDIS_PORT = '6379'
BROKER_URL = 'redis://' + REDIS_HOST + ':' + REDIS_PORT + '/0'
BROKER_TRANSPORT_OPTIONS = {'visibility_timeout': 3600}
CELERY_RESULT_BACKEND = 'redis://' + REDIS_HOST + ':' + REDIS_PORT + '/0'

推荐阅读