天天看點

logrotate工具日志管理

[技巧]用logrotate進行MySQL日志管理2013-05-15 14:15:34

分類: Mysql/postgreSQL

原因:面對累計長時間的慢查詢日志,檢索起來非常不友善. 目的:按天分割慢查詢日志. 方法:利用logrotate工具 實作

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日志的配置檔案

  1. /var/log/mysql/slow_3306.log  
  2. /var/log/mysql/slow_3307.log {
  3. # compress
  4. # create 644 mysql mysql
  5. rotate 7

可以切換兩個配置檔案.或者用*.log,切換目錄下所有的.

調試指令