Skip to content

Commit

Permalink
Usage within supervisord
Browse files Browse the repository at this point in the history
  • Loading branch information
CatoTH committed Dec 7, 2024
1 parent c06730a commit a21f0ae
Show file tree
Hide file tree
Showing 5 changed files with 74 additions and 18 deletions.
18 changes: 17 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -280,7 +280,7 @@ Instead of "antragsgruen_sites", a custom plugin managing the authentication and

Redis can be used to cache the changes in amendments, user sessions, and many other aspects of the site. To enable redis, simply add a `redis` configuration key to the `config.json` and point it to your setup:

Add the following settings to your config.json (and adapt them to your needs):
Add the following settings to your `config.json` (and adapt them to your needs):
```json
{
"redis": {
Expand All @@ -292,6 +292,22 @@ Add the following settings to your config.json (and adapt them to your needs):
}
```

### Enable background job processing

Some processes that are potentially blocking or long-running can be executed as background jobs, by using a permanently running worker-job that executes these jobs asynchonously.

The following example on how to run the background job processor uses [Supervisord](http://supervisord.org), but it is just as possible running it via any other process manager.
- Copy [supervisor.conf](docs/supervisor.conf) to your supervisord configuration directory, modify it to your needs, and run it.
- Enable background jobs by adding the following settings to your `config.json`:

```json
{
"backgroundJobs": true
}
```

Currently, this only affects the sending of e-mails.

### File-based View Caching (very large consultations)

Antragsgrün already does a decent amount of caching by default, and even more when enabling Redis. An even more aggressive caching mode that caches some fully rendered HTML pages and PDFs can be enabled by enabling the following option in the `config.json`:
Expand Down
44 changes: 36 additions & 8 deletions commands/BackgroundJobController.php
Original file line number Diff line number Diff line change
Expand Up @@ -12,17 +12,30 @@
*/
class BackgroundJobController extends Controller
{
private const MAX_EVENTS = 1000;
private const MAX_RUNTIME_SECONDS = 600;
private const MAX_MEMORY_USAGE = 64_000_000;
private const DEFAULT_MAX_EVENTS = 1000;
private const DEFAULT_MAX_RUNTIME_SECONDS = 600;
private const DEFAULT_MAX_MEMORY_USAGE = 64_000_000;

protected int $maxEvents = self::DEFAULT_MAX_EVENTS;
protected int $maxRuntimeSeconds = self::DEFAULT_MAX_RUNTIME_SECONDS;
protected int $maxMemoryUsage = self::DEFAULT_MAX_MEMORY_USAGE;

public function options($actionID): array
{
return ['maxEvents', 'maxRuntimeSeconds', 'maxMemoryUsage'];
}

/**
* Runs the background job processor
*
* @throws \yii\db\Exception
* Options:
* --max-runtime-seconds 600
* --max-events 1000
* --max-memory-usage 64000000
*/
public function actionRun(): void
{
echo "Starting background job processor at: " . (new \DateTimeImmutable())->format("Y-m-d H:i:s.u") . "\n";

$connection = \Yii::$app->getDb();
$connection->enableLogging = false;

Expand All @@ -35,12 +48,27 @@ public function actionRun(): void
usleep(100_000);
}
}

echo "Stopping background job processor at: " . (new \DateTimeImmutable())->format("Y-m-d H:i:s.u") . "\n";
}

private function needsRestart(BackgroundJobProcessor $processor): bool
{
return $processor->getProcessedEvents() >= self::MAX_EVENTS
|| $processor->getRuntimeInSeconds() >= self::MAX_RUNTIME_SECONDS
|| memory_get_peak_usage() >= self::MAX_MEMORY_USAGE;
if ($processor->getProcessedEvents() >= $this->maxEvents) {
echo "Stopping because maximum number of processed events has been reached.\n";
return true;
}

if ($processor->getRuntimeInSeconds() >= $this->maxRuntimeSeconds) {
echo "Stopping because maximum runtime has been reached.\n";
return true;
}

if (memory_get_peak_usage() >= $this->maxMemoryUsage) {
echo "Stopping because maximum memory usage has been reached.\n";
return true;
}

return false;
}
}
23 changes: 14 additions & 9 deletions components/BackgroundJobScheduler.php
Original file line number Diff line number Diff line change
Expand Up @@ -5,19 +5,24 @@
namespace app\components;

use app\models\backgroundJobs\IBackgroundJob;
use app\models\settings\AntragsgruenApp;

class BackgroundJobScheduler
{
public static function executeOrScheduleJob(IBackgroundJob $job): void
{
\Yii::$app->getDb()->createCommand(
'INSERT INTO backgroundJob (`siteId`, `consultationId`, `type`, `dateCreation`, `payload`) VALUES (:siteId, :consultationId, :type, NOW(), :payload)',
[
':siteId' => $job->getSite()?->id,
':consultationId' => $job->getConsultation()?->id,
':type' => $job->getTypeId(),
':payload' => $job->toJson(),
]
)->execute();
if (AntragsgruenApp::getInstance()->backgroundJobs) {
\Yii::$app->getDb()->createCommand(
'INSERT INTO `backgroundJob` (`siteId`, `consultationId`, `type`, `dateCreation`, `payload`) VALUES (:siteId, :consultationId, :type, NOW(), :payload)',
[
':siteId' => $job->getSite()?->id,
':consultationId' => $job->getConsultation()?->id,
':type' => $job->getTypeId(),
':payload' => $job->toJson(),
]
)->execute();
} else {
$job->execute();
}
}
}
6 changes: 6 additions & 0 deletions docs/supervisor.conf
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
[program:antragsgruen-background-jobs]
command=/var/www/antragsgruen/yii background-job/run
redirect_stderr=true
user=www-data
environment=ANTRAGSGRUEN_CONFIG="/var/www/antragsgruen/config/config.json"
autorestart=true
1 change: 1 addition & 0 deletions models/settings/AntragsgruenApp.php
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@ class AntragsgruenApp implements \JsonSerializable
public bool $confirmEmailAddresses = true;
public bool $enforceTwoFactorAuthentication = false;
public bool $dataPrivacyCheckbox = false;
public bool $backgroundJobs = false;
public string $mailFromName = 'Antragsgrün';
public string $mailFromEmail = '';
public ?string $mailDefaultReplyTo = null;
Expand Down

0 comments on commit a21f0ae

Please sign in to comment.