Merge "Add more $wgPoolCounterConf comments"
[mediawiki.git] / maintenance / mctest.php
blob60f94a5fa639a6fe3c3a6c2aff7fbe5f7e81918c
1 <?php
2 /**
3 * Makes several 'set', 'incr' and 'get' requests on every memcached
4 * server and shows a report.
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License along
17 * with this program; if not, write to the Free Software Foundation, Inc.,
18 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
19 * http://www.gnu.org/copyleft/gpl.html
21 * @file
22 * @ingroup Maintenance
25 require_once __DIR__ . '/Maintenance.php';
27 /**
28 * Maintenance script that makes several 'set', 'incr' and 'get' requests
29 * on every memcached server and shows a report.
31 * @ingroup Maintenance
33 class McTest extends Maintenance {
34 public function __construct() {
35 parent::__construct();
36 $this->addDescription( "Makes several 'set', 'incr' and 'get' requests on every"
37 . " memcached server and shows a report" );
38 $this->addOption( 'i', 'Number of iterations', false, true );
39 $this->addOption( 'cache', 'Use servers from this $wgObjectCaches store', false, true );
40 $this->addArg( 'server[:port]', 'Memcached server to test, with optional port', false );
43 public function execute() {
44 global $wgMainCacheType, $wgMemCachedTimeout, $wgObjectCaches;
46 $cache = $this->getOption( 'cache' );
47 $iterations = $this->getOption( 'i', 100 );
48 if ( $cache ) {
49 if ( !isset( $wgObjectCaches[$cache] ) ) {
50 $this->error( "MediaWiki isn't configured with a cache named '$cache'", 1 );
52 $servers = $wgObjectCaches[$cache]['servers'];
53 } elseif ( $this->hasArg() ) {
54 $servers = [ $this->getArg() ];
55 } elseif ( $wgMainCacheType === CACHE_MEMCACHED ) {
56 global $wgMemCachedServers;
57 $servers = $wgMemCachedServers;
58 } elseif ( isset( $wgObjectCaches[$wgMainCacheType]['servers'] ) ) {
59 $servers = $wgObjectCaches[$wgMainCacheType]['servers'];
60 } else {
61 $this->error( "MediaWiki isn't configured for Memcached usage", 1 );
64 # find out the longest server string to nicely align output later on
65 $maxSrvLen = $servers ? max( array_map( 'strlen', $servers ) ) : 0;
67 foreach ( $servers as $server ) {
68 $this->output(
69 str_pad( $server, $maxSrvLen ),
70 $server # output channel
73 $mcc = new MemcachedClient( [
74 'persistant' => true,
75 'timeout' => $wgMemCachedTimeout
76 ] );
77 $mcc->set_servers( [ $server ] );
78 $set = 0;
79 $incr = 0;
80 $get = 0;
81 $time_start = microtime( true );
82 for ( $i = 1; $i <= $iterations; $i++ ) {
83 if ( $mcc->set( "test$i", $i ) ) {
84 $set++;
87 for ( $i = 1; $i <= $iterations; $i++ ) {
88 if ( !is_null( $mcc->incr( "test$i", $i ) ) ) {
89 $incr++;
92 for ( $i = 1; $i <= $iterations; $i++ ) {
93 $value = $mcc->get( "test$i" );
94 if ( $value == $i * 2 ) {
95 $get++;
98 $exectime = microtime( true ) - $time_start;
100 $this->output( " set: $set incr: $incr get: $get time: $exectime", $server );
105 $maintClass = "McTest";
106 require_once RUN_MAINTENANCE_IF_MAIN;