mirror of https://github.com/jumpserver/jumpserver
45 lines
1.5 KiB
Python
45 lines
1.5 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
import os
|
|
|
|
from kombu import Exchange, Queue
|
|
from celery import Celery
|
|
from celery.schedules import crontab
|
|
|
|
# set the default Django settings module for the 'celery' program.
|
|
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'jumpserver.settings')
|
|
from jumpserver import settings
|
|
# from django.conf import settings
|
|
|
|
app = Celery('jumpserver')
|
|
|
|
configs = {k: v for k, v in settings.__dict__.items() if k.startswith('CELERY')}
|
|
# Using a string here means the worker will not have to
|
|
# pickle the object when using Windows.
|
|
# app.config_from_object('django.conf:settings', namespace='CELERY')
|
|
configs["CELERY_QUEUES"] = [
|
|
Queue("celery", Exchange("celery"), routing_key="celery"),
|
|
Queue("ansible", Exchange("ansible"), routing_key="ansible"),
|
|
Queue("celery_node_tree", Exchange("celery_node_tree"), routing_key="celery_node_tree")
|
|
]
|
|
configs["CELERY_ROUTES"] = {
|
|
"ops.tasks.run_ansible_task": {'exchange': 'ansible', 'routing_key': 'ansible'},
|
|
}
|
|
|
|
app.namespace = 'CELERY'
|
|
app.conf.update(configs)
|
|
app.autodiscover_tasks(lambda: [app_config.split('.')[0] for app_config in settings.INSTALLED_APPS])
|
|
|
|
app.conf.beat_schedule = {
|
|
'check-asset-permission-expired': {
|
|
'task': 'perms.tasks.check_asset_permission_expired',
|
|
'schedule': settings.PERM_EXPIRED_CHECK_PERIODIC,
|
|
'args': ()
|
|
},
|
|
'check-node-assets-amount': {
|
|
'task': 'assets.tasks.nodes_amount.check_node_assets_amount_celery_task',
|
|
'schedule': crontab(minute=0, hour=0),
|
|
'args': ()
|
|
},
|
|
}
|