3 * @defgroup StatCounter StatCounter
5 * StatCounter is used to increment arbitrary keys for profiling reasons.
6 * The key/values are persisted in several possible ways (see $wgStatsMethod).
10 * Aggregator for wfIncrStats() that batches updates per request.
12 * This program is free software; you can redistribute it and/or modify
13 * it under the terms of the GNU General Public License as published by
14 * the Free Software Foundation; either version 2 of the License, or
15 * (at your option) any later version.
17 * This program is distributed in the hope that it will be useful,
18 * but WITHOUT ANY WARRANTY; without even the implied warranty of
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20 * GNU General Public License for more details.
22 * You should have received a copy of the GNU General Public License along
23 * with this program; if not, write to the Free Software Foundation, Inc.,
24 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
25 * http://www.gnu.org/copyleft/gpl.html
28 * @ingroup StatCounter
29 * @author Aaron Schulz
33 * Aggregator for wfIncrStats() that batches updates per request.
34 * This avoids spamming the collector many times for the same key.
36 * @ingroup StatCounter
40 protected $deltas = array(); // (key => count)
42 protected function __construct() {}
47 public static function singleton() {
48 static $instance = null;
50 $instance = new self();
56 * Increment a key by delta $count
59 * @param integer $count
62 public function incr( $key, $count = 1 ) {
63 $this->deltas
[$key] = isset( $this->deltas
[$key] ) ?
$this->deltas
[$key] : 0;
64 $this->deltas
[$key] +
= $count;
65 if ( PHP_SAPI
=== 'cli' ) {
71 * Flush all pending deltas to persistent storage
75 public function flush() {
76 global $wgStatsMethod;
78 $deltas = array_filter( $this->deltas
); // remove 0 valued entries
79 if ( $wgStatsMethod === 'udp' ) {
80 $this->sendDeltasUDP( $deltas );
81 } elseif ( $wgStatsMethod === 'cache' ) {
82 $this->sendDeltasMemc( $deltas );
86 $this->deltas
= array();
90 * @param array $deltas
93 protected function sendDeltasUDP( array $deltas ) {
94 global $wgUDPProfilerHost, $wgUDPProfilerPort, $wgAggregateStatsID,
97 $id = strlen( $wgAggregateStatsID ) ?
$wgAggregateStatsID : wfWikiID();
100 foreach ( $deltas as $key => $count ) {
101 $lines[] = sprintf( $wgStatsFormatString, $id, $count, $key );
104 if ( count( $lines ) ) {
105 static $socket = null;
107 $socket = socket_create( AF_INET
, SOCK_DGRAM
, SOL_UDP
);
111 foreach ( $lines as $line ) {
112 if ( ( strlen( $packet ) +
strlen( $line ) ) > 1450 ) {
113 $packets[] = $packet;
118 if ( $packet != '' ) {
119 $packets[] = $packet;
121 foreach ( $packets as $packet ) {
122 wfSuppressWarnings();
137 * @param array $deltas
140 protected function sendDeltasMemc( array $deltas ) {
143 foreach ( $deltas as $key => $count ) {
144 $ckey = wfMemcKey( 'stats', $key );
145 if ( $wgMemc->incr( $ckey, $count ) === null ) {
146 $wgMemc->add( $ckey, $count );