gnu-social/docs/developer/src/queue.md
Diogo Peralta Cordeiro cc9f2d6ff2
[DOCUMENTATION] Three books instead of only one
The User one is intended to illustrate the various common use cases, possibilities regarding customization and introduce the existing functionalities.

The Administrator one explains the step by step of how to install and maintain a GNU social instance, be it as node of The Free Network or as an intranet social network in a company setting.

The Developer one starts by introducing the Modules system and architecture, then the plugin development process and finally the exciting internals of GNU social for those looking forward to make the most advanced contributions.
2021-09-14 13:11:49 +01:00

3.9 KiB

Queues and daemons

Some activities that GNU social needs to do, like broadcasting with OStatus or ActivityPub, SMS, XMPP messages and TwitterBridge operations, can be 'queued' and done by off-line bots instead.

Run the queue handler with:

php bin/console messenger:consume async --limit=10 --memory-limit=128M --time-limit=3600

GNU social uses Symfony, therefore the documentation on queues might be useful.

TODO queuing

OpportunisticQM plugin

This plugin is enabled by default. It tries its best to do background jobs during regular HTTP requests, like API or HTML pages calls.

Since queueing system is enabled by default, notices to be broadcasted will be stored, by default, into DB (table queue_item).

Whenever it has time, OpportunisticQM will try to handle some of them.

This is a good solution whether you:

  • have no access to command line (shared hosting)
  • do not want to deal with long-running PHP processes
  • run a low traffic GNU social instance

In other case, you really should consider enabling the queuedaemon for performance reasons. Background daemons are necessary anyway if you wish to use the Instant Messaging features such as communicating via XMPP.

Queue deamon

It's recommended you use the deamon, you must be able to run long-running offline processes, either on your main Web server or on another server you control. (Your other server will still need all the above prerequisites, with the exception of Apache.) Installing on a separate server is probably a good idea for high-volume sites.

  1. You'll need the "CLI" (command-line interface) version of PHP installed on whatever server you use.

    Modern PHP versions in some operating systems have disabled functions related to forking, which is required for daemons to operate. To make this work, make sure that your php-cli config (/etc/php5/cli/php.ini) does NOT have these functions listed under 'disable_functions':

    * pcntl_fork, pcntl_wait, pcntl_wifexited, pcntl_wexitstatus,
      pcntl_wifsignaled, pcntl_wtermsig
    

    Other recommended settings for optimal performance are: * mysqli.allow_persistent = On * mysqli.reconnect = On

  2. If you're using a separate server for queues, install StatusNet somewhere on the server. You don't need to worry about the .htaccess file, but make sure that your config.php file is close to, or identical to, your Web server's version.

  3. In your config.php files (on the server where you run the queue daemon), set the following variable:

    $config['queue']['daemon'] = true;
    

    You may also want to look at the 'Queues and Daemons' section in this file for more background processing options.

  4. On the queues server, run the command scripts/startdaemons.sh.

This will run the queue handlers:

  • queuedaemon.php - polls for queued items for inbox processing and pushing out to OStatus, SMS, XMPP, etc.
  • imdaemon.php - if an IM plugin is enabled (like XMPP)
  • other daemons, like TwitterBridge ones, that you may have enabled

These daemons will automatically restart in most cases of failure including memory leaks (if a memory_limit is set), but may still die or behave oddly if they lose connections to the XMPP or queue servers.

It may be a good idea to use a daemon-monitoring service, like 'monit', to check their status and keep them running.

All the daemons write their process IDs (pids) to /var/run/ by default. This can be useful for starting, stopping, and monitoring the daemons. If you are running multiple sites on the same machine, it will be necessary to avoid collisions of these PID files by setting a site- specific directory in config.php:

   $config['daemon']['piddir'] = __DIR__ . '/../run/';

It is also possible to use a STOMP server instead of our kind of hacky home-grown DB-based queue solution. This is strongly recommended for best response time, especially when using XMPP.