Converted some section profiling to scopedProfileIn
[mediawiki.git] / maintenance / showJobs.php
bloba9f7d8b41936c048166e902453a6b5b11540c03d
1 <?php
2 /**
3 * Report number of jobs currently waiting in master database.
5 * Based on runJobs.php
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License along
18 * with this program; if not, write to the Free Software Foundation, Inc.,
19 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
20 * http://www.gnu.org/copyleft/gpl.html
22 * @file
23 * @ingroup Maintenance
24 * @author Tim Starling
25 * @author Antoine Musso
28 require_once __DIR__ . '/Maintenance.php';
30 /**
31 * Maintenance script that reports the number of jobs currently waiting
32 * in master database.
34 * @ingroup Maintenance
36 class ShowJobs extends Maintenance {
37 public function __construct() {
38 parent::__construct();
39 $this->mDescription = "Show number of jobs waiting in master database";
40 $this->addOption( 'group', 'Show number of jobs per job type' );
41 $this->addOption( 'list',
42 'Show a list of all jobs in a machine-readable format, instead of statistics' );
43 $this->addOption( 'type', 'Only show/count jobs of a given type', false, true );
46 public function execute() {
47 $filterType = $this->getOption( 'type', '' );
48 $group = JobQueueGroup::singleton();
49 if ( $this->hasOption( 'list' ) ) {
50 foreach ( $group->getQueueTypes() as $type ) {
51 if ( $filterType != '' && $type != $filterType ) {
52 continue;
54 $queue = $group->get( $type );
55 foreach ( $queue->getAllQueuedJobs() as $job ) {
56 $this->output( $job->toString() . " status=unclaimed\n" );
58 foreach ( $queue->getAllDelayedJobs() as $job ) {
59 $this->output( $job->toString() . " status=delayed\n" );
62 } elseif ( $this->hasOption( 'group' ) ) {
63 foreach ( $group->getQueueTypes() as $type ) {
64 if ( $filterType != '' && $type != $filterType ) {
65 continue;
67 $queue = $group->get( $type );
68 $delayed = $queue->getDelayedCount();
69 $pending = $queue->getSize();
70 $claimed = $queue->getAcquiredCount();
71 $abandoned = $queue->getAbandonedCount();
72 $active = max( 0, $claimed - $abandoned );
73 if ( ( $pending + $claimed + $delayed + $abandoned ) > 0 ) {
74 $this->output(
75 "{$type}: $pending queued; " .
76 "$claimed claimed ($active active, $abandoned abandoned); " .
77 "$delayed delayed\n"
81 } else {
82 $count = 0;
83 foreach ( $group->getQueueTypes() as $type ) {
84 if ( $filterType != '' && $type != $filterType ) {
85 continue;
87 $count += $group->get( $type )->getSize();
89 $this->output( "$count\n" );
94 $maintClass = "ShowJobs";
95 require_once RUN_MAINTENANCE_IF_MAIN;