MySQL Purge Binary Logs: Difference between revisions

From WikiMLT
Spas (talk | contribs)
m Стадий: 6 [Фаза:Утвърждаване, Статус:Утвърден]; Категория:Databases
 
Spas (talk | contribs)
mNo edit summary
 
(2 intermediate revisions by the same user not shown)
Line 4: Line 4:
sudo mysql
sudo mysql
</syntaxhighlight>
</syntaxhighlight>
<syntaxhighlight lang="mysql">
<syntaxhighlight lang="mysql" line="1" class="mysql-prompt code-continue">
mysql> PURGE BINARY LOGS BEFORE '2021-03-07 23:00:00';
PURGE BINARY LOGS BEFORE '2021-03-07 23:00:00';
</syntaxhighlight>
<syntaxhighlight lang="mysql" class="code-continue">
Query OK, 0 rows affected (0.05 sec)
Query OK, 0 rows affected (0.05 sec)
 
</syntaxhighlight>
mysql> exit
<syntaxhighlight lang="mysql" line="1" class="mysql-prompt code-continue">exit
</syntaxhighlight>
<syntaxhighlight lang="mysql" class="code-continue">
Bye
Bye
</syntaxhighlight>
</syntaxhighlight>
Line 23: Line 27:
</syntaxhighlight>
</syntaxhighlight>


References:
Also you can remove the <code>automysql</code> backups older than 7 days by the following command.<syntaxhighlight lang="shell" line="1">
sudo find /var/lib/automysqlbackup/ -mtime +7 -type f -delete
</syntaxhighlight>References:
* [https://dev.mysql.com/doc/refman/8.0/en/purge-binary-logs.html MySQL 8.0 Reference Manual: 13.4.1.1 PURGE BINARY LOGS Statement]
* [https://dev.mysql.com/doc/refman/8.0/en/purge-binary-logs.html MySQL 8.0 Reference Manual: 13.4.1.1 PURGE BINARY LOGS Statement]
* [https://www.christophe-casalegno.com/mysql-how-to-purge-binary-logs-when-you-have-no-space-left-on-device/ Christophe Casalegno: MySQL - how to purge binary logs when you have no space left on device?]
* [https://www.christophe-casalegno.com/mysql-how-to-purge-binary-logs-when-you-have-no-space-left-on-device/ Christophe Casalegno: MySQL - how to purge binary logs when you have no space left on device?]

Latest revision as of 11:32, 12 January 2023

If you are us­ing VPS with lim­it­ed space prob­a­bly it is a good idea to free up some space time to time. One way is by purg­ing the bi­na­ry logs of MySQL. Here are the rel­e­vant com­mands to do that at Ubun­tu 20.04 with MySQL 8 and the de­fault sock­et au­then­ti­ca­tion.

sudo mysql
PURGE BINARY LOGS BEFORE '2021-03-07 23:00:00';
Query OK, 0 rows affected (0.05 sec)
exit
Bye

In ad­di­tion you could mod­i­fy the bin­log ex­pire time as fol­low (restart the MySQL ser­vice af­ter that):

cat /etc/mysql/mysql.conf.d/mysql.binlog.cnf
# SZS: setup binlog expire time - one week in seconds
[mysqld]
binlog_expire_logs_seconds = 604800

Al­so you can re­move the au­to­mysql back­ups old­er than 7 days by the fol­low­ing com­mand.

sudo find /var/lib/automysqlbackup/ -mtime +7 -type f -delete

Ref­er­ences: