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
22 * @ingroup Maintenance
25 require_once __DIR__
. '/Maintenance.php';
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->mDescription
= "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 );
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 = array( $this->getArg() );
55 } elseif ( $wgMainCacheType === CACHE_MEMCACHED
) {
56 global $wgMemCachedServers;
57 $servers = $wgMemCachedServers;
58 } elseif ( isset( $wgObjectCaches[$wgMainCacheType]['servers'] ) ) {
59 $servers = $wgObjectCaches[$wgMainCacheType]['servers'];
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 ) {
69 str_pad( $server, $maxSrvLen ),
70 $server # output channel
73 $mcc = new MemCachedClientforWiki( array(
75 'timeout' => $wgMemCachedTimeout
77 $mcc->set_servers( array( $server ) );
81 $time_start = $this->microtime_float();
82 for ( $i = 1; $i <= $iterations; $i++
) {
83 if ( $mcc->set( "test$i", $i ) ) {
87 for ( $i = 1; $i <= $iterations; $i++
) {
88 if ( !is_null( $mcc->incr( "test$i", $i ) ) ) {
92 for ( $i = 1; $i <= $iterations; $i++
) {
93 $value = $mcc->get( "test$i" );
94 if ( $value == $i * 2 ) {
98 $exectime = $this->microtime_float() - $time_start;
100 $this->output( " set: $set incr: $incr get: $get time: $exectime", $server );
105 * Return microtime() as a float
108 private function microtime_float() {
109 list( $usec, $sec ) = explode( " ", microtime() );
111 return ( (float)$usec +
(float)$sec );
115 $maintClass = "McTest";
116 require_once RUN_MAINTENANCE_IF_MAIN
;