Skip to content

Commit

Permalink
Revert "perf: Optimize average_time_cost calculation in job model"
Browse files Browse the repository at this point in the history
This reverts commit eafb5ec.
  • Loading branch information
w940853815 authored and BaiJiangJie committed Jan 14, 2025
1 parent e721ec1 commit c088437
Showing 1 changed file with 6 additions and 13 deletions.
19 changes: 6 additions & 13 deletions apps/ops/models/job.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,7 @@
from celery import current_task
from django.conf import settings
from django.db import models
from django.db.models import Q, Avg, F, FloatField
from django.db.models.functions import Coalesce, Now, Extract
from django.db.models import Q
from django.utils import timezone
from django.utils.translation import gettext_lazy as _

Expand Down Expand Up @@ -189,17 +188,11 @@ def summary(self):

@property
def average_time_cost(self):
executions = self.executions.filter(status__in=['success', 'failed'])
if not executions.exists():
return 0
average = executions.annotate(
time_cost=Coalesce(F('date_finished'), Now()) - F('date_start')
).annotate(
time_cost_seconds=Extract('time_cost', 'epoch')
).aggregate(
avg_time=Avg('time_cost_seconds')
)['avg_time']
return average if average is not None else 0
total_cost = 0
finished_count = self.executions.filter(status__in=['success', 'failed']).count()
for execution in self.executions.filter(status__in=['success', 'failed']).all():
total_cost += execution.time_cost
return total_cost / finished_count if finished_count else 0

def get_register_task(self):
from ..tasks import run_ops_job
Expand Down

0 comments on commit c088437

Please sign in to comment.