max_binlog_size & log-bin size

8

Ich habe ein Problem mit der vollen Festplatte

-rw-rw----  1 mysql mysql 1073741982 2012-07-03 18:14 mysql-bin.000034
-rw-rw----  1 mysql mysql 1073741890 2012-07-04 14:39 mysql-bin.000035
-rw-rw----  1 mysql mysql 1073741988 2012-07-05 09:16 mysql-bin.000036
-rw-rw----  1 mysql mysql 1073741964 2012-07-06 00:04 mysql-bin.000037
-rw-rw----  1 mysql mysql 1073741974 2012-07-06 21:45 mysql-bin.000038
-rw-rw----  1 mysql mysql 1073741923 2012-07-07 19:05 mysql-bin.000039
-rw-rw----  1 mysql mysql  356167680 2012-07-07 23:47 mysql-bin.000040

my.cnf:

max_binlog_size = 1073741824
log-bin = mysql-bin
max_relay_log_size = 1G
relay_log_space_limit = 2G

mysql erstellt Dateien mysql-bin.xxxxx und meine Festplatte ist nach einigen Tagen voll.

Wie mache ich MySQL, um alte Protokolle zu löschen?

waza123
quelle
3
SET GLOBAL expire_logs_days = 2
waza123

Antworten:

8

Zusätzlich zur Einstellung können expire_logs_daysSie sofort einen Befehl ausführen, um alte Protokolle zu löschen:

mysql> PURGE BINARY LOGS TO 'mysql-bin.000039';

Stellen Sie sicher, dass keine Slaves aus Protokollen lesen, die Sie löschen möchten, da sonst die Replikation unterbrochen wird.

Siehe das MySQL-Referenzhandbuch: Binäre Protokolle

Gavin Towey
quelle
2
kleinere Korrektur - es ist expire_logs_days (beachten Sie 'logs' anstelle von 'log') - siehe dev.mysql.com/doc/refman/5.5/en/… für weitere Details
Richlv