AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken InnoDB: HDD-Platz nach Löschen vieler Datensätze wiederbekommen

InnoDB: HDD-Platz nach Löschen vieler Datensätze wiederbekommen

Ein Thema von Medium · begonnen am 7. Jun 2017 · letzter Beitrag vom 7. Jun 2017
Antwort Antwort
Medium

Registriert seit: 23. Jan 2008
3.689 Beiträge
 
Delphi 2007 Enterprise
 
#1

AW: InnoDB: HDD-Platz nach Löschen vieler Datensätze wiederbekommen

  Alt 7. Jun 2017, 14:55
@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:
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?!
Gut möglich dass die DB das kann, aber ich habe keinen Weg gefunden dies mit Sicherheit so auch sagen zu können. Auch weiß ich nicht, wie sie das DBMS verhält wenn die Platte randvoll ist. Ich könnte natürlich auf gut Glück alles laufen lassen erstmal, aber mir ist dabei ganz schön unwohl.

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
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)

Geändert von Medium ( 7. Jun 2017 um 14:57 Uhr)
  Mit Zitat antworten Zitat
Jumpy

Registriert seit: 9. Dez 2010
Ort: Mönchengladbach
1.740 Beiträge
 
Delphi 6 Enterprise
 
#2

AW: InnoDB: HDD-Platz nach Löschen vieler Datensätze wiederbekommen

  Alt 7. Jun 2017, 15:08
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?
Ralph
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#3

AW: InnoDB: HDD-Platz nach Löschen vieler Datensätze wiederbekommen

  Alt 7. Jun 2017, 15:23
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.
Gruß, Jo
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#4

AW: InnoDB: HDD-Platz nach Löschen vieler Datensätze wiederbekommen

  Alt 7. Jun 2017, 15:30
passende Info eventuell hier: https://lists.mysql.com/mysql-de/1002

https://lists.mysql.com/mysql-de/1391

https://www.alexander-langer.de/2014...speichern.html

https://www.thomas-krenn.com/de/wiki...Optimize_Table
  Mit Zitat antworten Zitat
Medium

Registriert seit: 23. Jan 2008
3.689 Beiträge
 
Delphi 2007 Enterprise
 
#5

AW: InnoDB: HDD-Platz nach Löschen vieler Datensätze wiederbekommen

  Alt 7. Jun 2017, 16:26
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 )

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!
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)

Geändert von Medium ( 7. Jun 2017 um 16:52 Uhr)
  Mit Zitat antworten Zitat
Antwort Antwort

Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 03:25 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-2025 by Thomas Breitkreuz