mirror of https://github.com/jumpserver/jumpserver
perf: 优化日志保存策略
parent
f7e6c14bc5
commit
dd793a4eca
|
@ -2,32 +2,44 @@
|
||||||
#
|
#
|
||||||
import datetime
|
import datetime
|
||||||
from django.utils import timezone
|
from django.utils import timezone
|
||||||
from django.conf import settings
|
|
||||||
from celery import shared_task
|
from celery import shared_task
|
||||||
|
|
||||||
from ops.celery.decorator import register_as_period_task
|
from ops.celery.decorator import (
|
||||||
|
register_as_period_task, after_app_shutdown_clean_periodic
|
||||||
|
)
|
||||||
from .models import UserLoginLog, OperateLog
|
from .models import UserLoginLog, OperateLog
|
||||||
|
from common.utils import get_log_keep_day
|
||||||
|
|
||||||
|
|
||||||
@register_as_period_task(interval=3600*24)
|
|
||||||
@shared_task
|
@shared_task
|
||||||
|
@after_app_shutdown_clean_periodic
|
||||||
def clean_login_log_period():
|
def clean_login_log_period():
|
||||||
now = timezone.now()
|
now = timezone.now()
|
||||||
try:
|
days = get_log_keep_day('LOGIN_LOG_KEEP_DAYS')
|
||||||
days = int(settings.LOGIN_LOG_KEEP_DAYS)
|
|
||||||
except ValueError:
|
|
||||||
days = 9999
|
|
||||||
expired_day = now - datetime.timedelta(days=days)
|
expired_day = now - datetime.timedelta(days=days)
|
||||||
UserLoginLog.objects.filter(datetime__lt=expired_day).delete()
|
UserLoginLog.objects.filter(datetime__lt=expired_day).delete()
|
||||||
|
|
||||||
|
|
||||||
@register_as_period_task(interval=3600*24)
|
|
||||||
@shared_task
|
@shared_task
|
||||||
|
@after_app_shutdown_clean_periodic
|
||||||
def clean_operation_log_period():
|
def clean_operation_log_period():
|
||||||
now = timezone.now()
|
now = timezone.now()
|
||||||
try:
|
days = get_log_keep_day('OPERATE_LOG_KEEP_DAYS')
|
||||||
days = int(settings.LOGIN_LOG_KEEP_DAYS)
|
|
||||||
except ValueError:
|
|
||||||
days = 9999
|
|
||||||
expired_day = now - datetime.timedelta(days=days)
|
expired_day = now - datetime.timedelta(days=days)
|
||||||
OperateLog.objects.filter(datetime__lt=expired_day).delete()
|
OperateLog.objects.filter(datetime__lt=expired_day).delete()
|
||||||
|
|
||||||
|
|
||||||
|
@shared_task
|
||||||
|
def clean_ftp_log_period():
|
||||||
|
now = timezone.now()
|
||||||
|
days = get_log_keep_day('FTP_LOG_KEEP_DAYS')
|
||||||
|
expired_day = now - datetime.timedelta(days=days)
|
||||||
|
OperateLog.objects.filter(datetime__lt=expired_day).delete()
|
||||||
|
|
||||||
|
|
||||||
|
@register_as_period_task(interval=3600*24)
|
||||||
|
@shared_task
|
||||||
|
def clean_audits_log_period():
|
||||||
|
clean_audits_log_period()
|
||||||
|
clean_operation_log_period()
|
||||||
|
clean_ftp_log_period()
|
||||||
|
|
|
@ -48,3 +48,11 @@ def union_queryset(*args, base_queryset=None):
|
||||||
base_queryset = args[0].model.objects
|
base_queryset = args[0].model.objects
|
||||||
queryset = base_queryset.filter(id__in=queryset_id)
|
queryset = base_queryset.filter(id__in=queryset_id)
|
||||||
return queryset
|
return queryset
|
||||||
|
|
||||||
|
|
||||||
|
def get_log_keep_day(s, defaults=200):
|
||||||
|
try:
|
||||||
|
days = int(getattr(settings, s))
|
||||||
|
except ValueError:
|
||||||
|
days = defaults
|
||||||
|
return days
|
||||||
|
|
|
@ -224,7 +224,7 @@ class Config(dict):
|
||||||
'TERMINAL_HEARTBEAT_INTERVAL': 20,
|
'TERMINAL_HEARTBEAT_INTERVAL': 20,
|
||||||
'TERMINAL_ASSET_LIST_SORT_BY': 'hostname',
|
'TERMINAL_ASSET_LIST_SORT_BY': 'hostname',
|
||||||
'TERMINAL_ASSET_LIST_PAGE_SIZE': 'auto',
|
'TERMINAL_ASSET_LIST_PAGE_SIZE': 'auto',
|
||||||
'TERMINAL_SESSION_KEEP_DURATION': 9999,
|
'TERMINAL_SESSION_KEEP_DURATION': 200,
|
||||||
'TERMINAL_HOST_KEY': '',
|
'TERMINAL_HOST_KEY': '',
|
||||||
'TERMINAL_TELNET_REGEX': '',
|
'TERMINAL_TELNET_REGEX': '',
|
||||||
'TERMINAL_COMMAND_STORAGE': {},
|
'TERMINAL_COMMAND_STORAGE': {},
|
||||||
|
@ -248,8 +248,10 @@ class Config(dict):
|
||||||
'HTTP_BIND_HOST': '0.0.0.0',
|
'HTTP_BIND_HOST': '0.0.0.0',
|
||||||
'HTTP_LISTEN_PORT': 8080,
|
'HTTP_LISTEN_PORT': 8080,
|
||||||
'WS_LISTEN_PORT': 8070,
|
'WS_LISTEN_PORT': 8070,
|
||||||
'LOGIN_LOG_KEEP_DAYS': 9999,
|
'LOGIN_LOG_KEEP_DAYS': 200,
|
||||||
'TASK_LOG_KEEP_DAYS': 10,
|
'TASK_LOG_KEEP_DAYS': 90,
|
||||||
|
'OPERATE_LOG_KEEP_DAYS': 200,
|
||||||
|
'FTP_LOG_KEEP_DAYS': 200,
|
||||||
'ASSETS_PERM_CACHE_TIME': 3600 * 24,
|
'ASSETS_PERM_CACHE_TIME': 3600 * 24,
|
||||||
'SECURITY_MFA_VERIFY_TTL': 3600,
|
'SECURITY_MFA_VERIFY_TTL': 3600,
|
||||||
'ASSETS_PERM_CACHE_ENABLE': HAS_XPACK,
|
'ASSETS_PERM_CACHE_ENABLE': HAS_XPACK,
|
||||||
|
|
|
@ -9,7 +9,7 @@ from celery.exceptions import SoftTimeLimitExceeded
|
||||||
from django.utils import timezone
|
from django.utils import timezone
|
||||||
from django.utils.translation import ugettext_lazy as _
|
from django.utils.translation import ugettext_lazy as _
|
||||||
|
|
||||||
from common.utils import get_logger, get_object_or_none, get_disk_usage
|
from common.utils import get_logger, get_object_or_none, get_disk_usage, get_log_keep_day
|
||||||
from orgs.utils import tmp_to_root_org, tmp_to_org
|
from orgs.utils import tmp_to_root_org, tmp_to_org
|
||||||
from .celery.decorator import (
|
from .celery.decorator import (
|
||||||
register_as_period_task, after_app_shutdown_clean_periodic,
|
register_as_period_task, after_app_shutdown_clean_periodic,
|
||||||
|
@ -83,10 +83,10 @@ def clean_tasks_adhoc_period():
|
||||||
@after_app_shutdown_clean_periodic
|
@after_app_shutdown_clean_periodic
|
||||||
@register_as_period_task(interval=3600*24, description=_("Clean celery log period"))
|
@register_as_period_task(interval=3600*24, description=_("Clean celery log period"))
|
||||||
def clean_celery_tasks_period():
|
def clean_celery_tasks_period():
|
||||||
expire_days = settings.TASK_LOG_KEEP_DAYS
|
|
||||||
logger.debug("Start clean celery task history")
|
logger.debug("Start clean celery task history")
|
||||||
one_month_ago = timezone.now() - timezone.timedelta(days=expire_days)
|
expire_days = get_log_keep_day('TASK_LOG_KEEP_DAYS')
|
||||||
tasks = CeleryTask.objects.filter(date_start__lt=one_month_ago)
|
days_ago = timezone.now() - timezone.timedelta(days=expire_days)
|
||||||
|
tasks = CeleryTask.objects.filter(date_start__lt=days_ago)
|
||||||
tasks.delete()
|
tasks.delete()
|
||||||
tasks = CeleryTask.objects.filter(date_start__isnull=True)
|
tasks = CeleryTask.objects.filter(date_start__isnull=True)
|
||||||
tasks.delete()
|
tasks.delete()
|
||||||
|
|
|
@ -75,4 +75,3 @@ def send_server_performance_mail(path, usage, usages):
|
||||||
send_mail_async(subject, message, recipient_list, html_message=message)
|
send_mail_async(subject, message, recipient_list, html_message=message)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue