勉強したことのメモ

Webエンジニア / プログラマが勉強したことのメモ。

MySQLのバイナリログ(/var/lib/mysql/binlog)を適切に削除する方法

   2024/05/23  MySQL データベース

レンタルしている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日設定になるようなので特に変更する必要は無さそう。

 - MySQL データベース

  関連記事

MySQLでオートインクリメントを使用せずにグループ毎に連番を設定する方法

MySQLでオートインクリメントを使用せずにグループ毎で連番を割り振りたかった。 ...

お名前.comのレンタルサーバ(SDサーバ)にMySQLデータのインポートする方法

お名前.comのレンタルサーバにそこそこ大きいサイズのMySQLデータを移行した ...

MySQLで検索した件数の取得

ページングとかで必要になる総件数について、 いつもググってしまっていたのでメモ。 ...

MySQLでスレッドの実行状況を表示しスレッドの経過時間チェックや特定スレッドを強制終了する方法

データベースサーバが重たく、原因を調査する機会があった。サーバ自体のメモリやCP ...

Codeigniter4でMySQLに接続しCRUD操作する方法

Codeigniter4.4.4でMySQLに接続しCRUD操作したい。また、任 ...