MySQLのバイナリログ(/var/lib/mysql/binlog)を適切に削除する方法
2024/05/23
レンタルしているVPS内のファイルを整理していると「/var/lib/mysql/binlog.xxxxxx」というファイルがあり、1ファイルあたり1GB近くと容量を圧迫しているので出来ることなら削除したかった。調べてみるとMySQLのバイナリログらしく、rmコマンド等で削除するとまずいらしい。以下に適切な対応方法のメモ。
対応方法
SSH接続して以下を実行。日時部分は適宜変更する。
#MySQLにrootで接続 mysql -u root -p #以下SQL文を実行 mysql> PURGE MASTER LOGS BEFORE '2022-12-31 23:59:59';
上記の場合だと「2022-12-31 23:59:59」以前のログが削除される。
リファレンス
https://dev.mysql.com/doc/refman/8.0/ja/purge-binary-logs.html
注意点
MySQL8.0.3以降の場合、ログ設定の「expire_logs_days」は非推奨のためか設定及び再起動を行うとMySQLが立ち上がらなかった。
代わりに設定するのであれば「binlog_expire_logs_seconds」を用いるのが良さそう。ただ、こちらは「expire_logs_days」と違ってデフォルトで30日設定になるようなので特に変更する必要は無さそう。
関連記事
-
-
SortableJSを使ってデータの並べ替え&保存
あるシステムを拝見した際にtableタグ内に並んでいる項目をドラッグ&ド ...
-
-
MySQLでグループ化したものを条件で絞る(HAVING)
正規化したテーブルがあってその中には idとtagのカラムがある。 でtagの方 ...
-
-
MySQLでユーザー作成時にエラーが発生
SSHからrootアカウントでMySQLにログインし、ユーザーを作成しようとする ...
-
-
MySQLでストアドプロシージャ戻り値対応版であるストアドファンクションの設定と利用方法
先日MySQLのストアドプロシージャに関するメモを書いたが、今回はストアドファン ...
-
-
Codeigniter4でMySQLに接続しCRUD操作する方法
Codeigniter4.4.4でMySQLに接続しCRUD操作したい。また、任 ...