MySQL NDB Cluster: increase MaxNoOf
Weitere Beiträge der Artikelserie „MySQL NDB Cluster“ findest du an dieser Stelle.
Im laufenden Betrieb häufen sich dann erst einmal die Fehlermeldungen in meinem MySQL NDB Cluster; seinen Anfang nahm alles, nachdem ich einen Dump meiner WordPress-Datenbank eingespielt hatte und die Engine der Tabellen per ALTER TABLE
auf NDBCLUSTER
umstellen wollte…
ERROR 1296 (HY000) at line 1: Got error 708 'No more attribute metadata records (increase MaxNoOfAttributes)' from NDBCLUSTER
MaxNoOfAttributes, aha. Der Default für diesen Wert liegt bei 1000, der maximal mögliche Wert bei 4294967039 (0xFFFFFEFF). Dazwischen liegt ja schon etwas Spielraum, also: auf was soll ich den erhöhen?
Eine Möglichkeit, dieser Fragestellung zu Leibe zu rücken, ist das Script ndb_size.pl (benötigt Class::MethodMaker
) auf den Data Nodes, das sich, wenn ihr meinem Tutorial zum Aufsetzen des experimentellen MySQL-NDB-Clusters in VirtualBox gefolgt seid, in /usr/local/mysql/bin
befindet. Es wertet die Datenbanken aus und erzeugt mit nachfolgendem Aufruf Ausgabe im HTML-Format – an den angegebenen Werten kann man sich orientieren. Und wie wir in nebenstehendem Screenshot erkennen können: die benötigten Werte weichen deutlich vom Default ab!
$ ndb_size.pl --user=root --password=PASSWORT --socket=/tmp/mysql.sock --format=html > /tmp/output.html
Wie sind die aktuellen Werte überhaupt gerade?
root@datanode1:~/bin# ndb_config -q MaxNoOfAttributes
1000 1000
Das ist nur ein Beispiel – ihr seht ja in dem Screenshot, dass MaxNoOfAttributes
nicht der einzige Wert ist, der angepasst werden muss. Die Details zu den einzelnen Werten erfahrt ihr auf der MySQL-Website, und insbesondere findet ihr hier auch Angaben zum Restart Type, also wie die einzelnen Knoten anschließend durchgestartet werden müssen, um die geänderte Konfiguration zu übernehmen. Der überarbeitete [NDBD DEFAULT]
-Abschnitt der config.ini könnte etwa so aussehen:
## file: "/var/lib/mysql-cluster/config.ini"
[NDBD DEFAULT]
NoOfReplicas=2
DataMemory=512M
MaxNoOfTriggers=4096
MaxNoOfAttributes=32768
MaxNoOfOrderedIndexes=512
IndexMemory=64M
MaxNoOfUniqueHashIndexes=64
MaxNoOfTables=512
[...]
Startet die einzelnen Knoten nun neu, haltet die Log-Files im Auge – anschließend lief mein ALTER TABLE
jedenfalls sauber durch, die Änderung war also erfolgreich. Und so langsam stellt sich auch eine gewisse Sicherheit im Umgang mit dem MySQL NDB Cluster ein, ich entwickle Routine und verliere ein Stück weit die Scheu. Kaputt gespielt hat man hier nämlich recht schnell etwas – leider :D Doch davon ein andermal mehr…
Hintergrundbild: Bild genauer anschauen – © Marianne Spiller – Alle Rechte vorbehalten