mysql日志爆滿,刪除日志文件,定時(shí)清理日志

今天發(fā)現(xiàn)網(wǎng)站不能正常訪問(wèn),于是登陸服務(wù)器查找問(wèn)題。

創(chuàng)新互聯(lián)成立于2013年,我們提供高端重慶網(wǎng)站建設(shè)、網(wǎng)站制作、成都網(wǎng)站設(shè)計(jì)、網(wǎng)站定制、網(wǎng)絡(luò)營(yíng)銷推廣、小程序制作、微信公眾號(hào)開(kāi)發(fā)、網(wǎng)站推廣服務(wù),提供專業(yè)營(yíng)銷思路、內(nèi)容策劃、視覺(jué)設(shè)計(jì)、程序開(kāi)發(fā)來(lái)完成項(xiàng)目落地,為加固企業(yè)提供源源不斷的流量和訂單咨詢。

機(jī)智的我隨手用命令:df -l 發(fā)現(xiàn) 硬盤爆滿了,于是就知道問(wèn)題所在了。

Filesystem     1K-blocks     Used Available Use% Mounted on/dev/xvda1      20641404 16963004   16929876  100% /tmpfs             960368        0    960368   0% /dev/shm/dev/xvdb1      51599192  4845536  44132564  10% /home/sam/share

然后通過(guò)命令 du -sh * 一路檢查,發(fā)現(xiàn)mysql的日志文件占據(jù)了大部分空間 , 整整27G,于是現(xiàn)在的任務(wù)就是清理mysql的日志文件(主要是清理.log文件和mysql-bin.00000X二進(jìn)制日志文件)

一、刪除mysql日志文件
第一步:登陸進(jìn)入mysql,并使用 show binary logs; 查看日志文件。

mysql>show binary logs;+------------------+-----------+| Log_name         | File_size |+------------------+-----------+| mysql-bin.000001 | 234592362 || mysql-bin.000002 | 425234342 || mysql-bin.000003 | 425345345 || mysql-bin.000004 | 234234222 || mysql-bin.000005 | 425994852 |+------------------+-----------+1 row in set (0.00 sec)

第二步:查看正在使用的日志文件:show master status;

mysql>show master status;+------------------+-----------+--------------+------------------+-------------------+| File             | Position  | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |+------------------+-----------+--------------+------------------+-------------------+| mysql-bin.000005 | 425994852 |              |                  |                   |+------------------+-----------+--------------+------------------+-------------------+1 row in set (0.00 sec)
當(dāng)前正在使用的日志文件是mysql-bin.000005,那么刪除日志文件的時(shí)候應(yīng)該排除掉該文件。刪除日志文件的命令:purge binary logs to 'mysql-bin.000005';
mysql>purge binary logs to 'mysql-bin.000005';

刪除除mysql-bin.000005以外的日志文件。

刪除后就能釋放大部分空間。

二、mysql 定時(shí)清理日志文件
如果每次等到發(fā)現(xiàn)空間不足的時(shí)候才去手動(dòng)刪除日志文件,這種方式是很不理想的。

那么,我們就需要設(shè)置mysql,讓它能自動(dòng)清理日志文件。

編輯mysql的配置文件,設(shè)置expire_logs_days(mysql定時(shí)刪除日志文件)

[root@sam ~]# vim /etc/my.cnf

在my.cnf中,添加或修改expire_logs_days的值 (這里設(shè)置的自動(dòng)刪除時(shí)間為10天, 默認(rèn)為0不自動(dòng)刪除)

expire_logs_days=10
修改后,重啟mysql就會(huì)生效。

但是,在生產(chǎn)環(huán)境中,重啟mysql數(shù)據(jù)庫(kù)往往會(huì)付出很高的代價(jià)。

于是,可以在不重啟mysql的情況下,修改expire_logs_days值

如下:

登陸到mysql,并輸入一下命令。

mysql>show variables like '%log%';mysql>set global expire_logs_days = 10;

設(shè)置完后,可以通過(guò) show variables like '%log%'; 看到expire_logs_days的值已被修改成10。

注意:通過(guò)這種方式設(shè)置expire_logs_days雖然不需要重啟mysql即可生效,但是該方式在重啟mysql之后,值會(huì)被恢復(fù)。

于是,建議通過(guò)mysql命令設(shè)置expire_logs_days的同時(shí),也修改/etc/my.cnf下的expire_logs_days=10配置,這樣在下次重啟mysql的時(shí)候,expire_logs_days也一樣是10;

當(dāng)前名稱:mysql日志爆滿,刪除日志文件,定時(shí)清理日志
分享地址:http://muchs.cn/article40/spoho.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供ChatGPT外貿(mào)網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)全網(wǎng)營(yíng)銷推廣、企業(yè)網(wǎng)站制作、靜態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

網(wǎng)站建設(shè)網(wǎng)站維護(hù)公司