![]() |
Datenbank: MariaDB • Version: 10.1 • Zugriff über: UniDAC
InnoDB: HDD-Platz nach Löschen vieler Datensätze wiederbekommen
Hallo liebe DP!
Ich habe gerade eine Datenbank vor der Brust, die Energiemessdaten speichert. Ich war leider so nachlässig am Anfang, dass ich keine regelmäßige Löschung alter Daten gleich mit eingebaut habe, und sitze jetzt auf einer rund 3,5TB großen Datenbank... Und die Platte hat noch 20GB frei. :pale: Ich habe bereits angefangen alle sekündlichen Daten, die älter als März sind auf minütlich zu konsolidieren. Leider gibt InnoDB aber den Platz gelöschter Zeilen nicht wieder frei. Ich bin auf ![]() Das ganze geht noch vielleicht 3-4 Tage gut, aber dann wird's eklig. Zumal die Datenerfassung, zumindest unter der Woche, nicht für längere Zeit unterbrochen werden darf. Gibt es hier keine andere Lösung als einen kompletten Dump und Rebuild? Vielen Dank schon mal! |
AW: InnoDB: HDD-Platz nach Löschen vieler Datensätze wiederbekommen
gelöscht, weil nicht genau gelesen
|
AW: InnoDB: HDD-Platz nach Löschen vieler Datensätze wiederbekommen
Ich habe es nur überflogen, aber hilft Dir das vielleicht weiter?
![]() |
AW: InnoDB: HDD-Platz nach Löschen vieler Datensätze wiederbekommen
Hast Du denn das Problem, dass die Rows schwankende Größen haben?
Und ja, so wie beschrieben, benötigt dieser Prozess zunächst mehr Festplatten Speicherplatz. Wir war denn das Laufzeitverhalten bei start des Befehls? Läuft noch? Abgeschlossen? Ich vermute mal, dass in einem laufenden Production System 3TB belegter Platz nicht mal eben auf Knopfdruck reorganisiert werden. Da sehe ich eher Stunden. Und wenn Platz auch nicht an das OS / HDD zurückgegeben wird, kann er von der DB dennoch wieder genutzt werden oder? Also egal, wenn nichts frei wird?! Notfalls kurzzeitig runterfahren, Zusatzplatte rein und wieder hoch. Dann vielleicht neue Datafiles an den Tablespace hängen und lustig reorganisieren. Ich kenne mysql nicht wirklich, vor allen Dingen nicht diese Szenarien, also alle meine Hinweise sind mit Vorsicht zu genießen. |
AW: InnoDB: HDD-Platz nach Löschen vieler Datensätze wiederbekommen
@DeddyH: Leider nein. Ich habe leider die DB nicht mit der "one file per table" Option erstellt, wodurch ein OPTIMIZE ohne Defragmentierung letztlich genau das Gegenteil von dem macht was ich erreichen will (muss!): Die DB belegt nachher um die Länge der Tabelle MEHR Speicherplatz.
@jobo: Meine Datensätze sind alle gleich lang. Alle ~500 Tabellen mit ihren je 1-50mio. Einträgen nutzen dieselbe Satzlänge. Das OPTIMIZE mit aktiver Defragmentierung ist auf einer Tabelle mit knapp 50mio Einträgen komischerweise nach gut einer Minute durch. (Es ist zwar ein RAID10 mit ordentlich flotten HDDs dahinter, aber SO gut wird's nicht sein :)) Die Statistiken (Innodb_defragment_count) sagen mir allerdings nachher, dass durchaus Defrag-Schritte unternommen wurden. Allerdings nur ein paar Zig - da ich diesen Wert aber nicht zu interpretieren weiß (sind das Pages? Sätze? Elefanten?)... was sagt mir das? Es wurden übrigens rund 90% der Datensätze aus den Tabellen gelöscht. (Genau gesehen 98,3% aller Daten älter als 01.03.2017, und es sind knapp 2 Jahre an Daten bisher angefallen.) Zitat:
Nuja. Noch bin ich beim DELETEn. Das dauert immerhin auch schon 30min pro Tabelle, und es sind ein paar hundert... Ich hatte nur gehofft zwischendurch etwas Platz schaffen zu können um den Betrieb aufrecht halten zu können bis ich alle Löschungen durch habe. (Ja, das dauert Tage. Das ist klar.) Am Ende steht vermutlich eh ein Rebuild mit file-per-table aktiv, aber das würde ich bevorzugt an einem langen Wochenende machen dann. Am Rande übrigens: Das Löschen scheint nicht nur keinen Platz freizugeben, nein! Es sieht aktuell so aus als würde es sogar noch Platz ZUSÄTZLICH futtern! Dadurch wird der Count-Down bis zum GAU ganz schön kurz :? |
AW: InnoDB: HDD-Platz nach Löschen vieler Datensätze wiederbekommen
Bei Oracle sind gelöschte Daten erstmal nicht gleich weg, da muss man zusätlich noch Trunc oder sowas in den Deletebefehl mit einbauen. Andernfalls ist das wie der Papierkorb und man kann das wiederherstellen, weswegen es aber noch Platz belegt.
Ist das in Mysql vllt. ähnlich? |
AW: InnoDB: HDD-Platz nach Löschen vieler Datensätze wiederbekommen
Also ich würde sagen egal welche DB, ein Delete von 50T records plus commit muss letztlich Speicherplatz freigeben, egal welches System.
Bei Oracle entstehen bei sowas logfiles (außer bei einem NO_LOGGING Tablespace oder wenn das gar nicht aktiviert ist), die zusätzlich Platz benötigen und idR gleich auf einer separaten Partition liegen. Weiß nicht wie das bei mysql ist. |
AW: InnoDB: HDD-Platz nach Löschen vieler Datensätze wiederbekommen
|
AW: InnoDB: HDD-Platz nach Löschen vieler Datensätze wiederbekommen
Indirekt bin ich dank der Links und jobo's Hinweis zur Lösung gekommen! Was mir dermaßen die Platte voll gejodelt hat waren NICHT die eigentlichen Daten, sondern das binary logging! Da ich auf der DB die entsprechenden Funktionen die mir dieses bietet nicht unbedingt benötige, habe ich mich dazu durchgerungen mal beherzt RESET MASTER in die Konsole zu tippern. Und siehe da: Von vormals noch gerade 19,8GB sind nun wieder 2,77TB freier Speicher geworden. (In schlappen 2,8sek sogar nur :D)
Ich werde das bin-logging wohl mal abschalten jetzt. Und im selben Zuge wenn Zeit ist auf file-per-table umstellen. Besten Dank liebe DP! :thumb: |
Alle Zeitangaben in WEZ +1. Es ist jetzt 02:36 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz