2015-10-13 11:13:13 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
if (!class_exists('WP_FFPC_Backend_memcached')):
|
|
|
|
|
|
|
|
class WP_FFPC_Backend_memcached extends WP_FFPC_Backend {
|
|
|
|
|
|
|
|
protected function _init () {
|
|
|
|
/* Memcached class does not exist, Memcached extension is not available */
|
|
|
|
if (!class_exists('Memcached')) {
|
2015-10-18 18:32:10 +01:00
|
|
|
$this->log ( __translate__(' Memcached extension missing, wp-ffpc will not be able to function correctly!', 'wp-ffpc' ), LOG_WARNING );
|
2015-10-13 11:13:13 +01:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* check for existing server list, otherwise we cannot add backends */
|
|
|
|
if ( empty ( $this->options['servers'] ) && ! $this->alive ) {
|
2015-10-18 18:32:10 +01:00
|
|
|
$this->log ( __translate__("Memcached servers list is empty, init failed", 'wp-ffpc' ), LOG_WARNING );
|
2015-10-13 11:13:13 +01:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* check is there's no backend connection yet */
|
|
|
|
if ( $this->connection === NULL ) {
|
|
|
|
$this->connection = new Memcached();
|
|
|
|
|
|
|
|
/* use binary and not compressed format, good for nginx and still fast */
|
|
|
|
$this->connection->setOption( Memcached::OPT_COMPRESSION , false );
|
|
|
|
if ($this->options['memcached_binary']){
|
|
|
|
$this->connection->setOption( Memcached::OPT_BINARY_PROTOCOL , true );
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( version_compare( phpversion( 'memcached' ) , '2.0.0', '>=' ) && ini_get( 'memcached.use_sasl' ) == 1 && isset($this->options['authpass']) && !empty($this->options['authpass']) && isset($this->options['authuser']) && !empty($this->options['authuser']) ) {
|
|
|
|
$this->connection->setSaslAuthData ( $this->options['authuser'], $this->options['authpass']);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* check if initialization was success or not */
|
|
|
|
if ( $this->connection === NULL ) {
|
2015-10-18 18:32:10 +01:00
|
|
|
$this->log ( __translate__( 'error initializing Memcached PHP extension, exiting', 'wp-ffpc' ) );
|
2015-10-13 11:13:13 +01:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* check if we already have list of servers, only add server(s) if it's not already connected */
|
|
|
|
$servers_alive = array();
|
|
|
|
if ( !empty ( $this->status ) ) {
|
|
|
|
$servers_alive = $this->connection->getServerList();
|
|
|
|
/* create check array if backend servers are already connected */
|
|
|
|
if ( !empty ( $servers ) ) {
|
|
|
|
foreach ( $servers_alive as $skey => $server ) {
|
|
|
|
$skey = $server['host'] . ":" . $server['port'];
|
|
|
|
$servers_alive[ $skey ] = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* adding servers */
|
|
|
|
foreach ( $this->options['servers'] as $server_id => $server ) {
|
|
|
|
/* reset server status to unknown */
|
|
|
|
//$this->status[$server_id] = -1;
|
|
|
|
|
|
|
|
/* only add servers that does not exists already in connection pool */
|
|
|
|
if ( !@array_key_exists($server_id , $servers_alive ) ) {
|
|
|
|
$this->connection->addServer( $server['host'], $server['port'] );
|
2015-10-18 18:32:10 +01:00
|
|
|
$this->log ( sprintf( __translate__( '%s added', 'wp-ffpc' ), $server_id ) );
|
2015-10-13 11:13:13 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* backend is now alive */
|
|
|
|
$this->alive = true;
|
|
|
|
$this->_status();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* sets current backend alive status for Memcached servers
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
protected function _status () {
|
|
|
|
/* server status will be calculated by getting server stats */
|
2015-10-18 18:32:10 +01:00
|
|
|
$this->log ( __translate__("checking server statuses", 'wp-ffpc' ));
|
2015-10-13 11:13:13 +01:00
|
|
|
/* get server list from connection */
|
|
|
|
$servers = $this->connection->getServerList();
|
|
|
|
|
|
|
|
foreach ( $servers as $server ) {
|
|
|
|
$server_id = $server['host'] . self::port_separator . $server['port'];
|
|
|
|
/* reset server status to offline */
|
|
|
|
$this->status[$server_id] = 0;
|
2015-10-18 18:32:10 +01:00
|
|
|
if ($this->connection->set('wp-ffpc', time())) {
|
|
|
|
$this->log ( sprintf( __translate__( '%s server is up & running', 'wp-ffpc' ), $server_id ) );
|
2015-10-13 11:13:13 +01:00
|
|
|
$this->status[$server_id] = 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* get function for Memcached backend
|
|
|
|
*
|
|
|
|
* @param string $key Key to get values for
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
protected function _get ( &$key ) {
|
|
|
|
return $this->connection->get($key);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set function for Memcached backend
|
|
|
|
*
|
|
|
|
* @param string $key Key to set with
|
|
|
|
* @param mixed $data Data to set
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
protected function _set ( &$key, &$data, &$expire ) {
|
|
|
|
$result = $this->connection->set ( $key, $data , $expire );
|
|
|
|
|
|
|
|
/* if storing failed, log the error code */
|
|
|
|
if ( $result === false ) {
|
|
|
|
$code = $this->connection->getResultCode();
|
2015-10-18 18:32:10 +01:00
|
|
|
$this->log ( sprintf( __translate__( 'unable to set entry: %s', 'wp-ffpc' ), $key ) );
|
|
|
|
$this->log ( sprintf( __translate__( 'Memcached error code: %s', 'wp-ffpc' ), $code ) );
|
|
|
|
//throw new Exception ( __translate__('Unable to store Memcached entry ', 'wp-ffpc' ) . $key . __translate__( ', error code: ', 'wp-ffpc' ) . $code );
|
2015-10-13 11:13:13 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* Flush memcached entries
|
|
|
|
*/
|
|
|
|
protected function _flush ( ) {
|
|
|
|
return $this->connection->flush();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Removes entry from Memcached or flushes Memcached storage
|
|
|
|
*
|
|
|
|
* @param mixed $keys String / array of string of keys to delete entries with
|
|
|
|
*/
|
|
|
|
protected function _clear ( &$keys ) {
|
|
|
|
|
|
|
|
/* make an array if only one string is present, easier processing */
|
|
|
|
if ( !is_array ( $keys ) )
|
|
|
|
$keys = array ( $keys => true );
|
|
|
|
|
|
|
|
foreach ( $keys as $key => $dummy ) {
|
|
|
|
$kresult = $this->connection->delete( $key );
|
|
|
|
|
|
|
|
if ( $kresult === false ) {
|
|
|
|
$code = $this->connection->getResultCode();
|
2015-10-18 18:32:10 +01:00
|
|
|
$this->log ( sprintf( __translate__( 'unable to delete entry: %s', 'wp-ffpc' ), $key ) );
|
|
|
|
$this->log ( sprintf( __translate__( 'Memcached error code: %s', 'wp-ffpc' ), $code ) );
|
2015-10-13 11:13:13 +01:00
|
|
|
}
|
|
|
|
else {
|
2015-10-18 18:32:10 +01:00
|
|
|
$this->log ( sprintf( __translate__( 'entry deleted: %s', 'wp-ffpc' ), $key ) );
|
2015-10-13 11:13:13 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
endif;
|