Merge commit 'origin/master' into testing

This commit is contained in:
Brion Vibber 2010-01-28 13:35:09 -08:00
commit d00ce38549
6 changed files with 81 additions and 21 deletions

View File

@ -147,6 +147,7 @@ class Memcached_DataObject extends DB_DataObject
{ {
$result = parent::insert(); $result = parent::insert();
if ($result) { if ($result) {
$this->fixupTimestamps();
$this->encache(); // in case of cached negative lookups $this->encache(); // in case of cached negative lookups
} }
return $result; return $result;
@ -159,6 +160,7 @@ class Memcached_DataObject extends DB_DataObject
} }
$result = parent::update($orig); $result = parent::update($orig);
if ($result) { if ($result) {
$this->fixupTimestamps();
$this->encache(); $this->encache();
} }
return $result; return $result;
@ -366,7 +368,7 @@ class Memcached_DataObject extends DB_DataObject
} }
/** /**
* sends query to database - this is the private one that must work * sends query to database - this is the private one that must work
* - internal functions use this rather than $this->query() * - internal functions use this rather than $this->query()
* *
* Overridden to do logging. * Overridden to do logging.
@ -428,7 +430,7 @@ class Memcached_DataObject extends DB_DataObject
// //
// WARNING WARNING if we end up actually using multiple DBs at a time // WARNING WARNING if we end up actually using multiple DBs at a time
// we'll need some fancier logic here. // we'll need some fancier logic here.
if (!$exists && !empty($_DB_DATAOBJECT['CONNECTIONS'])) { if (!$exists && !empty($_DB_DATAOBJECT['CONNECTIONS']) && php_sapi_name() == 'cli') {
foreach ($_DB_DATAOBJECT['CONNECTIONS'] as $index => $conn) { foreach ($_DB_DATAOBJECT['CONNECTIONS'] as $index => $conn) {
if (!empty($conn)) { if (!empty($conn)) {
$conn->disconnect(); $conn->disconnect();
@ -529,4 +531,25 @@ class Memcached_DataObject extends DB_DataObject
return $c->delete($cacheKey); return $c->delete($cacheKey);
} }
function fixupTimestamps()
{
// Fake up timestamp columns
$columns = $this->table();
foreach ($columns as $name => $type) {
if ($type & DB_DATAOBJECT_MYSQLTIMESTAMP) {
$this->$name = common_sql_now();
}
}
}
function debugDump()
{
common_debug("debugDump: " . common_log_objstring($this));
}
function raiseError($message, $type = null, $behaviour = null)
{
throw new ServerException("DB_DataObject error [$type]: $message");
}
} }

View File

@ -64,8 +64,12 @@ class Session extends Memcached_DataObject
$session = Session::staticGet('id', $id); $session = Session::staticGet('id', $id);
if (empty($session)) { if (empty($session)) {
self::logdeb("Couldn't find '$id'");
return ''; return '';
} else { } else {
self::logdeb("Found '$id', returning " .
strlen($session->session_data) .
" chars of data");
return (string)$session->session_data; return (string)$session->session_data;
} }
} }
@ -77,14 +81,24 @@ class Session extends Memcached_DataObject
$session = Session::staticGet('id', $id); $session = Session::staticGet('id', $id);
if (empty($session)) { if (empty($session)) {
self::logdeb("'$id' doesn't yet exist; inserting.");
$session = new Session(); $session = new Session();
$session->id = $id; $session->id = $id;
$session->session_data = $session_data; $session->session_data = $session_data;
$session->created = common_sql_now(); $session->created = common_sql_now();
return $session->insert(); $result = $session->insert();
if (!$result) {
common_log_db_error($session, 'INSERT', __FILE__);
self::logdeb("Failed to insert '$id'.");
} else {
self::logdeb("Successfully inserted '$id' (result = $result).");
}
return $result;
} else { } else {
self::logdeb("'$id' already exists; updating.");
if (strcmp($session->session_data, $session_data) == 0) { if (strcmp($session->session_data, $session_data) == 0) {
self::logdeb("Not writing session '$id'; unchanged"); self::logdeb("Not writing session '$id'; unchanged");
return true; return true;
@ -95,7 +109,16 @@ class Session extends Memcached_DataObject
$session->session_data = $session_data; $session->session_data = $session_data;
return $session->update($orig); $result = $session->update($orig);
if (!$result) {
common_log_db_error($session, 'UPDATE', __FILE__);
self::logdeb("Failed to update '$id'.");
} else {
self::logdeb("Successfully updated '$id' (result = $result).");
}
return $result;
} }
} }
} }
@ -106,8 +129,17 @@ class Session extends Memcached_DataObject
$session = Session::staticGet('id', $id); $session = Session::staticGet('id', $id);
if (!empty($session)) { if (empty($session)) {
return $session->delete(); self::logdeb("Can't find '$id' to delete.");
} else {
$result = $session->delete();
if (!$result) {
common_log_db_error($session, 'DELETE', __FILE__);
self::logdeb("Failed to delete '$id'.");
} else {
self::logdeb("Successfully deleted '$id' (result = $result).");
}
return $result;
} }
} }
@ -132,7 +164,10 @@ class Session extends Memcached_DataObject
$session->free(); $session->free();
self::logdeb("Found " . count($ids) . " ids to delete.");
foreach ($ids as $id) { foreach ($ids as $id) {
self::logdeb("Destroying session '$id'.");
self::destroy($id); self::destroy($id);
} }
} }

View File

@ -152,6 +152,16 @@ function checkMirror($action_obj, $args)
static $alwaysRW = array('session', 'remember_me'); static $alwaysRW = array('session', 'remember_me');
// We ensure that these tables always are used
// on the master DB
$config['db']['database_rw'] = $config['db']['database'];
$config['db']['ini_rw'] = INSTALLDIR.'/classes/statusnet.ini';
foreach ($alwaysRW as $table) {
$config['db']['table_'.$table] = 'rw';
}
if (common_config('db', 'mirror') && $action_obj->isReadOnly($args)) { if (common_config('db', 'mirror') && $action_obj->isReadOnly($args)) {
if (is_array(common_config('db', 'mirror'))) { if (is_array(common_config('db', 'mirror'))) {
// "load balancing", ha ha // "load balancing", ha ha
@ -162,16 +172,6 @@ function checkMirror($action_obj, $args)
$mirror = common_config('db', 'mirror'); $mirror = common_config('db', 'mirror');
} }
// We ensure that these tables always are used
// on the master DB
$config['db']['database_rw'] = $config['db']['database'];
$config['db']['ini_rw'] = INSTALLDIR.'/classes/statusnet.ini';
foreach ($alwaysRW as $table) {
$config['db']['table_'.$table] = 'rw';
}
// everyone else uses the mirror // everyone else uses the mirror
$config['db']['database'] = $mirror; $config['db']['database'] = $mirror;

View File

@ -84,6 +84,7 @@ $default =
'control_channel' => '/topic/statusnet-control', // broadcasts to all queue daemons 'control_channel' => '/topic/statusnet-control', // broadcasts to all queue daemons
'stomp_username' => null, 'stomp_username' => null,
'stomp_password' => null, 'stomp_password' => null,
'stomp_persistent' => true, // keep items across queue server restart, if persistence is enabled
'monitor' => null, // URL to monitor ping endpoint (work in progress) 'monitor' => null, // URL to monitor ping endpoint (work in progress)
'softlimit' => '90%', // total size or % of memory_limit at which to restart queue threads gracefully 'softlimit' => '90%', // total size or % of memory_limit at which to restart queue threads gracefully
'debug_memory' => false, // true to spit memory usage to log 'debug_memory' => false, // true to spit memory usage to log

View File

@ -174,12 +174,13 @@ class StompQueueManager extends QueueManager
$this->_connect(); $this->_connect();
// XXX: serialize and send entire notice $props = array('created' => common_sql_now());
if (common_config('queue', 'stomp_persistent')) {
$props['persistent'] = 'true';
}
$result = $this->con->send($this->queueName($queue), $result = $this->con->send($this->queueName($queue),
$msg, // BODY of the message $msg, // BODY of the message
array ('created' => common_sql_now(), $props);
'persistent' => 'true'));
if (!$result) { if (!$result) {
common_log(LOG_ERR, "Error sending $rep to $queue queue"); common_log(LOG_ERR, "Error sending $rep to $queue queue");
@ -242,6 +243,7 @@ class StompQueueManager extends QueueManager
parent::start($master); parent::start($master);
$this->_connect(); $this->_connect();
common_log(LOG_INFO, "Subscribing to $this->control");
$this->con->subscribe($this->control); $this->con->subscribe($this->control);
if ($this->sites) { if ($this->sites) {
foreach ($this->sites as $server) { foreach ($this->sites as $server) {

View File

@ -178,7 +178,6 @@ function common_ensure_session()
} }
if (isset($id)) { if (isset($id)) {
session_id($id); session_id($id);
setcookie(session_name(), $id);
} }
@session_start(); @session_start();
if (!isset($_SESSION['started'])) { if (!isset($_SESSION['started'])) {