<div dir="ltr"><div><div>Recently we've seen the issue of labsdb replicas falling out of sync with upstream, which has been tricky to debug. At different times there have been:<br><br></div><div>- Duplicate key errors<br></div><div>- Missing key errors<br></div><div><div>- The above errors sometimes irreparable by ALTER or resync<br></div>- A few out-of-memory (OOM) events killing mysqld outright<br><br></div><div>The OOM issues occur when slow, poorly optimized queries touching large amounts of data are allowed to run for too long (usually days or weeks). Previously we've tried to be hands-off and only kill these when absolutely necessary, but it is clear we'll have to impose some automated time and memory limits.<br><br>The observant reader will note that even OOM should not affect an
RDBMS properly using ACID and transactions, and that is entirely
correct. I include it because it isn't clear how OOM and subsequent
replication restarts would have interacted with MDEV-6589 (below).<br><br></div><div>As for the replication problems, the following have all been relevant at one point or another, interacting together to produce some weird results:<br><br><a href="https://mariadb.atlassian.net/browse/MDEV-6551">https://mariadb.atlassian.net/browse/MDEV-6551</a><br>(affected us prior to MariaDB 10.0.14)<br><br><a href="https://mariadb.atlassian.net/browse/MDEV-6589">https://mariadb.atlassian.net/browse/MDEV-6589</a><br>(related to 6551; potentially affected us prior to a configuration change, but only in theory)<br><br><a href="https://tokutek.atlassian.net/browse/DB-739">https://tokutek.atlassian.net/browse/DB-739</a><br>(still affects us on MariaDB 10.0.14 and TokuDB 7.5.0)<br><br></div>So, stuff to do:<br><br></div><div>1. We need some memory and time limits for user queries. Memory usage is easy to track server-side on a per-client basis, but users may find it difficult to predict or understand why specific queries trip some arbitrary memory limit. So, just time based? Thoughts?<br><br></div><div>2. The TokuDB bug DB-739 appears only on specific types of upstream transaction, so some replica tables (including but not necessarily limited to *links, user, recentchanges, and geo_tags) are being switched back to InnoDB until further notice.<br><br></div><div>3. After #2 we resync across the board, yet again.<br></div></div>