logrotate mysql滿日誌太大分割
logrotate介紹
logrotate是管理日誌檔案的工具,在CentOS系統中,命令的位置在/usr/sbin/logrotate,常用的操作如:-d, --debug Don't do anything, just test (implies -v)
-f, --force Force file rotation
注意:帶有d引數,並不會產生新日誌.
logrotate一般每天由cron執行一次.標準的配置檔案是/etc/logrotate.conf,而/etc/logrotate.d目錄也是儲存配置檔案的位置.
logrotate常見選項:
選項 | 含義 |
compress | 壓縮日誌檔案的所有非當前版本 |
copy | 複製當前的日誌檔案,忽略create引數 |
copytruncate | 複製當前的日誌檔案,並置空當前檔案 |
daily | 每天輪日誌檔案i |
dateext | 輪換的日誌字尾為-YYYYMMDD格式 |
delaycompress | 壓縮除了當前和最近之外的所有其他版本 |
missingok | 如果日誌不存在,不會報錯 |
notifempty | 如果日誌為空,則不輪換 |
rotate n | 在輪換方案中包含n個版本的日誌 |
size=logsize | 如果日誌檔案大於logsize才輪換 |
輪換MySQL日誌的配置檔案
- /var/log/mysql/slow_3306.log
- /var/log/mysql/slow_3307.log {
- # compress
- copytruncate
- # create 644 mysql mysql
- daily
- dateext
- delaycompress
- missingok
- notifempty
- rotate 7
- # size 1M
- }
可以切換兩個配置檔案.或者用*.log,切換目錄下所有的.
除錯命令
/usr/sbin/logrotate -d /etc/logrotate.d/mysql-slow
/usr/sbin/logrotate -f /etc/logrotate.d/mysql-slow