From c4d67892751b17856b235182874c3304890dc2c3 Mon Sep 17 00:00:00 2001 From: Evan Prodromou Date: Fri, 29 Aug 2008 14:17:02 -0400 Subject: split public stream to its own queue handler Add another queue handler for the public stream. Should further parallelize the work of sending out messages. darcs-hash:20080829181702-84dde-594505aa73d2380b13bd98917b70b02bac597d12.gz --- scripts/publicqueuehandler.php | 66 ++++++++++++++++++++++++++++++++++++++++++ scripts/startdaemons.sh | 1 + scripts/stopdaemons.sh | 1 + scripts/xmppdaemon.php | 2 +- scripts/xmppqueuehandler.php | 4 +-- 5 files changed, 71 insertions(+), 3 deletions(-) create mode 100755 scripts/publicqueuehandler.php (limited to 'scripts') diff --git a/scripts/publicqueuehandler.php b/scripts/publicqueuehandler.php new file mode 100755 index 000000000..0d95a489f --- /dev/null +++ b/scripts/publicqueuehandler.php @@ -0,0 +1,66 @@ +#!/usr/bin/env php +. + */ + +# Abort if called from a web server +if (isset($_SERVER) && array_key_exists('REQUEST_METHOD', $_SERVER)) { + print "This script must be run from the command line\n"; + exit(); +} + +define('INSTALLDIR', realpath(dirname(__FILE__) . '/..')); +define('LACONICA', true); + +require_once(INSTALLDIR . '/lib/common.php'); +require_once(INSTALLDIR . '/lib/jabber.php'); +require_once(INSTALLDIR . '/lib/queuehandler.php'); + +set_error_handler('common_error_handler'); + +class PublicQueueHandler extends QueueHandler { + + function transport() { + return 'public'; + } + + function start() { + # Low priority; we don't want to receive messages + $this->conn = jabber_connect($this->_id, NULL, -1); + return !is_null($this->conn); + } + + function handle_notice($notice) { + return jabber_public_notice($notice); + } + + function finish() { + } +} + +mb_internal_encoding('UTF-8'); + +$resource = ($argc > 1) ? $argv[1] : (common_config('xmpp','resource') . '-public'); + +$handler = new XmppQueueHandler($resource); + +if ($handler->start()) { + $handler->handle_queue(); +} + +$handler->finish(); diff --git a/scripts/startdaemons.sh b/scripts/startdaemons.sh index 37d30cdb4..8c054417d 100755 --- a/scripts/startdaemons.sh +++ b/scripts/startdaemons.sh @@ -22,6 +22,7 @@ export INSTALLDIR=$1 /sbin/start-stop-daemon -S --exec $INSTALLDIR/scripts/xmppdaemon.php -b -m --pidfile=/var/run/xmppdaemon.pid /sbin/start-stop-daemon -S --exec $INSTALLDIR/scripts/xmppqueuehandler.php -b -m --pidfile=/var/run/xmppqueuehandler.pid +/sbin/start-stop-daemon -S --exec $INSTALLDIR/scripts/publicqueuehandler.php -b -m --pidfile=/var/run/publicqueuehandler.pid /sbin/start-stop-daemon -S --exec $INSTALLDIR/scripts/xmppconfirmhandler.php -b -m --pidfile=/var/run/xmppconfirmhandler.pid /sbin/start-stop-daemon -S --exec $INSTALLDIR/scripts/smsqueuehandler.php -b -m --pidfile=/var/run/smsqueuehandler.pid /sbin/start-stop-daemon -S --exec $INSTALLDIR/scripts/ombqueuehandler.php -b -m --pidfile=/var/run/ombqueuehandler.pid diff --git a/scripts/stopdaemons.sh b/scripts/stopdaemons.sh index d620472f0..6814101cb 100755 --- a/scripts/stopdaemons.sh +++ b/scripts/stopdaemons.sh @@ -22,6 +22,7 @@ export INSTALLDIR=$1 /sbin/start-stop-daemon -K -m --pidfile=/var/run/xmppdaemon.pid /sbin/start-stop-daemon -K -m --pidfile=/var/run/xmppqueuehandler.pid +/sbin/start-stop-daemon -K -m --pidfile=/var/run/publicqueuehandler.pid /sbin/start-stop-daemon -K -m --pidfile=/var/run/xmppconfirmhandler.pid /sbin/start-stop-daemon -K -m --pidfile=/var/run/smsqueuehandler.pid /sbin/start-stop-daemon -K -m --pidfile=/var/run/ombqueuehandler.pid diff --git a/scripts/xmppdaemon.php b/scripts/xmppdaemon.php index b013a34c9..153ab5149 100755 --- a/scripts/xmppdaemon.php +++ b/scripts/xmppdaemon.php @@ -259,7 +259,7 @@ class XMPPDaemon { mb_internal_encoding('UTF-8'); -$resource = ($argc > 1) ? $argv[1] : NULL; +$resource = ($argc > 1) ? $argv[1] : (common_config('xmpp','resource') . '-listen'); $daemon = new XMPPDaemon($resource); diff --git a/scripts/xmppqueuehandler.php b/scripts/xmppqueuehandler.php index 8fe8b1360..3f632d5a8 100755 --- a/scripts/xmppqueuehandler.php +++ b/scripts/xmppqueuehandler.php @@ -41,7 +41,7 @@ class XmppQueueHandler extends QueueHandler { function start() { # Low priority; we don't want to receive messages - $this->conn = jabber_connect($this->resource, NULL, -100); + $this->conn = jabber_connect($this->_id, NULL, -1); return !is_null($this->conn); } @@ -55,7 +55,7 @@ class XmppQueueHandler extends QueueHandler { mb_internal_encoding('UTF-8'); -$resource = ($argc > 1) ? $argv[1] : NULL; +$resource = ($argc > 1) ? $argv[1] : (common_config('xmpp','resource') . '-queuehandler'); $handler = new XmppQueueHandler($resource); -- cgit v1.2.3-54-g00ecf