version 0.6.1

git-svn-id: http://plugins.svn.wordpress.org/wp-ffpc/trunk@677998 b8457f37-d9ea-0310-8a92-e5e31aec5664
This commit is contained in:
cadeyrn 2013-03-08 11:19:34 +00:00
parent c41f847093
commit 4310614a3c
3 changed files with 72 additions and 25 deletions

View file

@ -4,7 +4,7 @@ Donate link: https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_i
Tags: cache, APC, memcache, memcached, page cache, full page cache, nginx Tags: cache, APC, memcache, memcached, page cache, full page cache, nginx
Requires at least: 3.0 Requires at least: 3.0
Tested up to: 3.5.1 Tested up to: 3.5.1
Stable tag: 0.5.1 Stable tag: 0.6.1
Store WordPress pages in memcached and serve them with nginx - unbeatable speed! Store WordPress pages in memcached and serve them with nginx - unbeatable speed!
@ -56,8 +56,13 @@ You have to remove the default yum package, named `php-pecl-memcache` and instal
== Changelog == == Changelog ==
= 0.6.1 =
*2013.03.08*
* refactored & corrected backend status check for memcached driver
= 0.6 = = 0.6 =
*development branch* *2013.03.08*
* true WordPress Network support: * true WordPress Network support:
* if enabled network-wide, settings will be the same for every site * if enabled network-wide, settings will be the same for every site

View file

@ -56,17 +56,20 @@ function wp_ffpc_init( $wp_ffpc_config ) {
if (!class_exists('Memcache')) if (!class_exists('Memcache'))
return false; return false;
if ( $wp_ffpc_backend == NULL ) if ( $wp_ffpc_backend == NULL )
{
$wp_ffpc_backend = new Memcache(); $wp_ffpc_backend = new Memcache();
foreach ( $wp_ffpc_config['servers'] as $server_id => $server ) {
$wp_ffpc_backend_status[$server_id] = $wp_ffpc_backend->connect( $server['host'] , $server['port'] );
$wp_ffpc_config['persistent'] = ( $wp_ffpc_config['persistent'] == '1' ) ? true : false; foreach ( $wp_ffpc_config['servers'] as $server_id => $server ) {
if ( $wp_ffpc_backend_status[$server_id] ) $wp_ffpc_backend_status[$server_id] = $wp_ffpc_backend->connect( $server['host'] , $server['port'] );
$wp_ffpc_backend->addServer( $server['host'] , $server['port'], $wp_ffpc_config['persistent'] );
wp_ffpc_log ( "server " . $server_id . " added, persistent mode: " . $wp_ffpc_config['persistent'] ); $wp_ffpc_config['persistent'] = ( $wp_ffpc_config['persistent'] == '1' ) ? true : false;
if ( $wp_ffpc_backend_status[$server_id] )
{
$wp_ffpc_backend_status[$server_id] = true;
$wp_ffpc_backend->addServer( $server['host'] , $server['port'], $wp_ffpc_config['persistent'] );
wp_ffpc_log ( "server " . $server_id . " added, persistent mode: " . $wp_ffpc_config['persistent'] );
} }
} }
return $wp_ffpc_backend_status;
break; break;
/* in case of Memcached */ /* in case of Memcached */
@ -74,34 +77,62 @@ function wp_ffpc_init( $wp_ffpc_config ) {
/* Memcached class does not exist, Memcached extension is not available */ /* Memcached class does not exist, Memcached extension is not available */
if (!class_exists('Memcached')) if (!class_exists('Memcached'))
return false; return false;
/* check is there's no backend connection yet */
if ( $wp_ffpc_backend == NULL ) if ( $wp_ffpc_backend == NULL )
{ {
/* persistent backend needs an identifier */
if ( $wp_ffpc_config['persistent'] == '1' ) if ( $wp_ffpc_config['persistent'] == '1' )
$wp_ffpc_backend = new Memcached( WP_FFPC_PARAM ); $wp_ffpc_backend = new Memcached( WP_FFPC_PARAM );
else else
$wp_ffpc_backend = new Memcached(); $wp_ffpc_backend = new Memcached();
/* use binary and not compressed format, good for nginx and still fast */
$wp_ffpc_backend->setOption( Memcached::OPT_COMPRESSION , false ); $wp_ffpc_backend->setOption( Memcached::OPT_COMPRESSION , false );
$wp_ffpc_backend->setOption( Memcached::OPT_BINARY_PROTOCOL , true ); $wp_ffpc_backend->setOption( Memcached::OPT_BINARY_PROTOCOL , true );
$wp_ffpc_serverlist = $wp_ffpc_backend->getServerList();
if ( empty ( $wp_ffpc_serverlist ) )
$wp_ffpc_backend->addServers( $wp_ffpc_config['servers'] );
wp_ffpc_log ( "servers added, persistent mode: " . $wp_ffpc_config['persistent'] );
} }
$wp_ffpc_backend_report = $wp_ffpc_backend->getStats();
foreach ( $wp_ffpc_config['servers'] as $server_id => $server ) { /* check if we already have list of servers, only add server if it's not already connected */
$wp_ffpc_backend_status[$server_id] = false; $wp_ffpc_serverlist = $wp_ffpc_backend->getServerList();
if ( array_key_exists( $server_id, $wp_ffpc_backend_report ) && $wp_ffpc_backend_report[ $server_id ]['pid'] != -1 ) {
$wp_ffpc_backend_status[$server_id] = true; /* create check array if backend servers are already connected */
if ( !empty ( $wp_ffpc_serverlist ) )
foreach ( $wp_ffpc_serverlist as $server )
$wp_ffpc_serverlist_[ $server['host'] . ":" . $server['port'] ] = true;
/* reset all configured server status to unknown */
foreach ( $wp_ffpc_config['servers'] as $server_id => $server )
$wp_ffpc_backend_status[$server_id] = -1;
/* if there's no server to add, don't add them */
if ( empty ( $wp_ffpc_config['servers'] ) )
{
wp_ffpc_log ( "not adding empty set of servers, please check your settings!" );
}
else
{
foreach ( $wp_ffpc_config['servers'] as $server_id => $server ) {
if (!@array_key_exists($server_id , $wp_ffpc_serverlist_ ))
{
$wp_ffpc_backend->addServer( $server['host'], $server['port'] );
wp_ffpc_log ( "server ". $server_id ." added, persistent mode: " . $wp_ffpc_config['persistent'] );
}
} }
} }
/* server status will be calculated by getting server stats */
$wp_ffpc_backend_report = $wp_ffpc_backend->getStats();
foreach ( $wp_ffpc_backend_report as $server_id => $server ) {
$wp_ffpc_backend_status[$server_id] = false;
/* if server uptime is not empty, it's most probably up & running */
if ( !empty($server['uptime']) )
$wp_ffpc_backend_status[$server_id] = true;
}
break; break;
/* cache type is invalid */ /* cache type is invalid */
default: default:
return false; break;
} }
return ( empty ( $wp_ffpc_backend_status ) ? false : $wp_ffpc_backend_status ); return ( empty ( $wp_ffpc_backend_status ) ? false : $wp_ffpc_backend_status );

View file

@ -1,7 +1,7 @@
<?php <?php
/* /*
Plugin Name: WP-FFPC Plugin Name: WP-FFPC
Version: 0.6 Version: 0.6.1
Plugin URI: http://petermolnar.eu/wordpress/wp-ffpc Plugin URI: http://petermolnar.eu/wordpress/wp-ffpc
Description: Fast Full Page Cache, backend can be memcached or APC Description: Fast Full Page Cache, backend can be memcached or APC
Author: Peter Molnar Author: Peter Molnar
@ -66,7 +66,7 @@ define ( 'WP_FFPC_SERVER_SEPARATOR', ':' );
define ( 'WP_FFPC_DONATION_LINK', 'https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=XU3DG7LLA76WC' ); define ( 'WP_FFPC_DONATION_LINK', 'https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=XU3DG7LLA76WC' );
define ( 'WP_FFPC_FILE' , plugin_basename(__FILE__) ); define ( 'WP_FFPC_FILE' , plugin_basename(__FILE__) );
define ( 'WP_FFPC_PLUGIN' , 'wp-ffpc/wp-ffpc.php' ); define ( 'WP_FFPC_PLUGIN' , 'wp-ffpc/wp-ffpc.php' );
define ( 'WP_FFPC_VERSION' , '0.6' ); define ( 'WP_FFPC_VERSION' , '0.6.1' );
if ( ! function_exists( 'is_plugin_active_for_network' ) ) if ( ! function_exists( 'is_plugin_active_for_network' ) )
require_once( ABSPATH . 'wp-admin/includes/plugin.php' ); require_once( ABSPATH . 'wp-admin/includes/plugin.php' );
@ -163,6 +163,13 @@ if (!class_exists('WPFFPC')) {
/* not network, will be in simple admin menu */ /* not network, will be in simple admin menu */
else else
add_action('admin_menu', array( $this , 'admin_init') ); add_action('admin_menu', array( $this , 'admin_init') );
if ( $this->all_options['version'] < WP_FFPC_VERSION ) {
$this->save_settings ();
if ( @file_exists( WP_FFPC_ACACHE_MAIN_FILE )) {
$this->generate_config();
}
}
} }
/** /**
@ -291,8 +298,12 @@ if (!class_exists('WPFFPC')) {
/* we need to go through all servers */ /* we need to go through all servers */
foreach ( $this->options['servers'] as $server_string => $server ) { foreach ( $this->options['servers'] as $server_string => $server ) {
echo $server['host'] . ":" . $server['port'] ." => "; echo $server['host'] . ":" . $server['port'] ." => ";
$server_status = ( empty($init) || $init[$server_string] == 0 ) ? '<span class="error-msg">down</span>' : '<span class="ok-msg">up & running</span>' ; if ( is_array($init) && $init[$server_string] === false )
echo $server_status ."<br />\n"; _e ( '<span class="error-msg">down</span><br />', WP_FFPC_PARAM );
elseif ( is_array($init) && $init[$server_string] === true )
_e ( '<span class="ok-msg">up & running</span><br />', WP_FFPC_PARAM );
else
_e ( '<span class="error-msg">unknown, please try re-saving settings!</span><br />', WP_FFPC_PARAM );
} }
?> ?>
</p> </p>
@ -686,7 +697,7 @@ if (!class_exists('WPFFPC')) {
'prefix_data' =>'data-', 'prefix_data' =>'data-',
'charset' => 'utf-8', 'charset' => 'utf-8',
'pingback_status'=> false, 'pingback_status'=> false,
'debug' => true, 'debug' => false,
'syslog' => false, 'syslog' => false,
'cache_type' => 'memcached', 'cache_type' => 'memcached',
'cache_loggedin' => false, 'cache_loggedin' => false,