1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-13 16:21:07 +01:00

Track total time from task creation to task archival

Summary:
Ref T5401. Depends on D20201. Add timestamps to worker tasks to track task creation, and pass that through to archive tasks. This lets us measure the total time the task spent in the queue, not just the duration it was actually running.

Also displays this information in the daemon status console; see screenshot: {F6225726}

Test Plan:
Stopped daemons, ran `bin/search index --all --background` to create lots of tasks, restarted daemons, observed expected values for `dateCreated` and `epochArchived` in the archive worker table.

Also tested the changes to `unarchiveTask` by forcing a search task to permanently fail and then `bin/worker retry`ing it.

Reviewers: epriestley

Reviewed By: epriestley

Subscribers: Korvin, epriestley, PHID-OPKG-gm6ozazyms6q6i22gyam

Maniphest Tasks: T5401

Differential Revision: https://secure.phabricator.com/D20200
This commit is contained in:
Austin McKinley 2019-02-20 10:24:33 -08:00
parent 1b83256421
commit abc26aa96f
5 changed files with 34 additions and 4 deletions

View file

@ -0,0 +1,2 @@
ALTER TABLE {$NAMESPACE}_worker.worker_archivetask
ADD archivedEpoch INT UNSIGNED NULL;

View file

@ -0,0 +1,3 @@
ALTER TABLE {$NAMESPACE}_worker.worker_activetask
ADD dateCreated int unsigned NOT NULL,
ADD dateModified int unsigned NOT NULL;

View file

@ -31,6 +31,7 @@ final class PhabricatorDaemonConsoleController
$completed_info[$class] = array(
'n' => 0,
'duration' => 0,
'queueTime' => 0,
);
}
$completed_info[$class]['n']++;
@ -41,16 +42,33 @@ final class PhabricatorDaemonConsoleController
// compute utilization.
$usage_total += $lease_overhead + ($duration / 1000000);
$usage_start = min($usage_start, $completed_task->getDateModified());
$date_archived = $completed_task->getArchivedEpoch();
$queue_seconds = $date_archived - $completed_task->getDateCreated();
// Don't measure queue time for tasks that completed in the same
// epoch-second they were created in.
if ($queue_seconds > 0) {
$sec_in_us = phutil_units('1 second in microseconds');
$queue_us = $queue_seconds * $sec_in_us;
$queue_exclusive_us = $queue_us - $duration;
$queue_exclusive_seconds = $queue_exclusive_us / $sec_in_us;
$rounded = floor($queue_exclusive_seconds);
$completed_info[$class]['queueTime'] += $rounded;
}
}
$completed_info = isort($completed_info, 'n');
$rows = array();
foreach ($completed_info as $class => $info) {
$duration_avg = new PhutilNumber((int)($info['duration'] / $info['n']));
$queue_avg = new PhutilNumber((int)($info['queueTime'] / $info['n']));
$rows[] = array(
$class,
number_format($info['n']),
pht('%s us', new PhutilNumber((int)($info['duration'] / $info['n']))),
pht('%s us', $duration_avg),
pht('%s s', $queue_avg),
);
}
@ -98,6 +116,7 @@ final class PhabricatorDaemonConsoleController
phutil_tag('em', array(), pht('Queue Utilization (Approximate)')),
sprintf('%.1f%%', 100 * $used_time),
null,
null,
);
}
@ -108,13 +127,15 @@ final class PhabricatorDaemonConsoleController
array(
pht('Class'),
pht('Count'),
pht('Avg'),
pht('Average Duration'),
pht('Average Queue Time'),
));
$completed_table->setColumnClasses(
array(
'wide',
'n',
'n',
'n',
));
$completed_panel = id(new PHUIObjectBoxView())

View file

@ -12,7 +12,6 @@ final class PhabricatorWorkerActiveTask extends PhabricatorWorkerTask {
$config = array(
self::CONFIG_IDS => self::IDS_COUNTER,
self::CONFIG_TIMESTAMPS => false,
self::CONFIG_KEY_SCHEMA => array(
'taskClass' => array(
'columns' => array('taskClass'),
@ -118,7 +117,9 @@ final class PhabricatorWorkerActiveTask extends PhabricatorWorkerTask {
->setPriority($this->getPriority())
->setObjectPHID($this->getObjectPHID())
->setResult($result)
->setDuration($duration);
->setDuration($duration)
->setDateCreated($this->getDateCreated())
->setArchivedEpoch(PhabricatorTime::getNow());
// NOTE: This deletes the active task (this object)!
$archive->save();

View file

@ -8,6 +8,7 @@ final class PhabricatorWorkerArchiveTask extends PhabricatorWorkerTask {
protected $duration;
protected $result;
protected $archivedEpoch;
protected function getConfiguration() {
$parent = parent::getConfiguration();
@ -22,6 +23,7 @@ final class PhabricatorWorkerArchiveTask extends PhabricatorWorkerTask {
$config[self::CONFIG_COLUMN_SCHEMA] = array(
'result' => 'uint32',
'duration' => 'uint64',
'archivedEpoch' => 'epoch?',
) + $config[self::CONFIG_COLUMN_SCHEMA];
$config[self::CONFIG_KEY_SCHEMA] = array(
@ -85,6 +87,7 @@ final class PhabricatorWorkerArchiveTask extends PhabricatorWorkerTask {
->setDataID($this->getDataID())
->setPriority($this->getPriority())
->setObjectPHID($this->getObjectPHID())
->setDateCreated($this->getDateCreated())
->insert();
$this->setDataID(null);