DBERROR db4: Logging region out of memory
Es ist zum Auswachsen: auf einem OpenExchange-Setup, das sich auf cyrus-imapd
und postfix
stützt und das lange, sehr lange einfach vor sich hin funktioniert hat, erscheinen plötzlich nachfolgende Meldungen im Log:
Nov 5 08:31:39 ox pop3s[6110]: DBERROR db4: Logging region out of memory; you may need to increase its size
Nov 5 08:31:39 ox pop3s[6110]: DBERROR: opening /var/lib/imap/tls_sessions.db: Cannot allocate memory
Nov 5 08:31:39 ox pop3s[6110]: DBERROR: opening /var/lib/imap/tls_sessions.db: cyrusdb error
DBERROR: xxx lockers
Parallel zu diesen Meldungen lässt sich eine enorm hohe Load auf dem System beobachten, überdurchschnittlich viele lmtpd connection
-Timeouts bis hin zum völligen Stillstand des cyrus
– der läuft zwar noch als Prozess, schafft es jedoch nicht mehr, auch nur ansatzweise E-Mails zu verarbeiten (in dem Moment geht dann auch die Load das Gesamtsystems nahezu auf Null). Auch interessant: nach einem Restart des Prozesses läuft eine Weile lang wieder alles wie gewünscht – in meinem Fall wurden die Intervalle bis zum nächsten Knall jedoch immer kürzer, da in der Queue immer mehr Kram auflief. Wie konnte ich den Fehler beheben?
Auf dem System handelt es sich um eine Standard-Installation, sprich: keine außergewöhnlichen Pfade und ähnliches. Also bestand der erste Schritt darin herauszufinden, welches das configdirectory
des cyrus
ist:
$ grep configdirectory /etc/imapd.conf
configdirectory: /var/lib/imap
In diesem /var/lib/imap
findet sich ein Ordner namens db
, in den ich unverzüglich hinein bewegte:
$ cd /var/lib/imap/db
Und dort habe ich ein File DB_CONFIG
mit nachfolgendem Inhalt angelegt:
set_cachesize 0 2097152 1
set_lg_regionmax 2097152
Das File wird bei einem Restart des cyrus
automatisch ausgewertet, und das Problem ist gelöst – einfach so. Die Fehlermeldung tauchte nicht wieder auf, das System ist sehr viel performanter.
Per Default werden nur wenige kB (256?) als Cache bereitgestellt; durch die Erhöhung der Cache-Size wurden die Plattenzugriffe deutlich reduziert!
Hintergrundbild: 612x 612px, Bild genauer anschauen – © Marianne Spiller – Alle Rechte vorbehalten