My specification:
- MySQL 8.0.41
- Ubuntu server 24.0.1 LTS
An issue in my Ubuntu is the remaining storage shrink so fast. After trying to calculate the size of each folder, i found a strange thing.
du -sh /var/lib/*
data:image/s3,"s3://crabby-images/c158c/c158c875b3763cea15c3355f63fb6a8473a95246" alt=""
/var/lib/mysql
has 3.8GiB, however i just have a database with small data in it. I then go into mysql folder, then calculating again with du -sh
du -sh /var/lib/mysql/*
data:image/s3,"s3://crabby-images/7ee99/7ee9957bda30ca62d47f11d4bcb5e803ee999d98" alt="disable binary log mysql"
As you see above, it created many binlog file that have 100MB of each file. That means, your mysql binary log is on, that consumes a lot of size.
If you don't need to use binary log, then you can disable it to keep your storage free.
Disable binary log MySQL 8
Before disabling binary log permanently in MySQL 8, let’s remove the existing binary logs, by:
FLUSH BINARY LOGS;
PURGE BINARY LOGS BEFORE NOW();
Now, if you look it back to mysql folder, the binary log files are gone.
ls -al
data:image/s3,"s3://crabby-images/31b35/31b35f89011f3e23ea43258ad074880824c53706" alt="disable binary log mysql"
Next, disable mysql from binary log creation, open mysqld.conf
vi /etc/mysql/mysql.conf.d/mysqld.cnf
Add the following parameter to the [mysqld] section to disable binary log.
skip-log-bin
data:image/s3,"s3://crabby-images/3a26c/3a26c2950722d563ef63e84d9f380f3b5eaa6cb7" alt="disable binary log mysql"
Save it, then restart your mysql to take the effect.
systemctl restart mysql
After restarted, you can check if binary log is already OFF, by typing this query:
SHOW VARIABLES LIKE 'log_bin'
data:image/s3,"s3://crabby-images/522c4/522c48df444c88d2754951490d1f0cd802f80f46" alt=""
And my available storage size get back (previously: 2.GiB, after binlog OFF: 6.3GiB)
df -h
data:image/s3,"s3://crabby-images/db795/db79541be5227ff7d9876bf6fc3e1c56280a44d2" alt=""
Hope this help !