欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Linux自帶的logrotate管理日志用法

 更新時(shí)間:2024年10月14日 11:02:03   作者:it-wangxiaobai  
Linux系統(tǒng)中,logrotate工具用于管理和輪轉(zhuǎn)日志文件,防止系統(tǒng)因日志文件過大導(dǎo)致磁盤爆滿,通過配置/etc/logrotate.conf和/etc/logrotate.d/下的文件,用戶可以定義日志處理規(guī)則,如壓縮、備份

利用Linux自帶的logrotate管理日志

日常運(yùn)維中,經(jīng)常要對各類日志進(jìn)行管理,清理,監(jiān)控,尤其是因?yàn)閼?yīng)用bug,在1小時(shí)內(nèi)就能寫幾十個G日志,導(dǎo)致磁盤爆滿,系統(tǒng)掛掉。

nohup.out,access.log,catalina.out

本文簡單介紹利用Linux自帶的logrotate來對操作系統(tǒng)中各類日志進(jìn)行管理

1. logrotate簡介

為了使用它,主要有兩個地方需要修改一下:一個是/etc/logrotate.conf,另一個是/etc/logrotate.d/下面的文件。

你既可以在logrotate.conf中直接定義如何處理你的log文件,也可以在/logrotate.d/下面針對自己的log新建一個對應(yīng)的文件來定義處理log的行為。

推薦在目錄 /logrotate.d/ 下面創(chuàng)建自己的文件來對個性化的日志進(jìn)行處理。

logrotate定義了如何處理日志,而它本身則是被crond定時(shí)調(diào)用的。

我使用的一個生產(chǎn)實(shí)例:

/usr/local/nginx/logs/*.log {
    create 0644 root root
    daily
    rotate 2
    missingok
    copytruncate
    ifempty
    compress
    noolddir
}

上述內(nèi)容保存到nginxlog文件,存放到目錄:/etc/logrotate.d/nginxlog

設(shè)置權(quán)限:

owner=root group=root mode=0644

測試配置是否正確:

lograte -d /etc/logrotate.d/nginxlog

執(zhí)行配置

lograte -f /etc/logrotate.d/nginxlog

2. logrotate配置參數(shù)

logrotate 全局配置文件: /etc/logrotate.conf

配置參數(shù)功能說明
compress通過gzip 壓縮轉(zhuǎn)儲以后的日志
nocompress不需要壓縮時(shí),用這個參數(shù)
copytruncate用于還在打開中的日志文件,把當(dāng)前日志備份并截?cái)?;是先拷貝再清空的方式,拷貝和清空之間有一個時(shí)間差,可能會丟失部分日志數(shù)據(jù)。
nocopytruncate備份日志文件但是不截?cái)?/td>
create mode owner group轉(zhuǎn)儲文件,使用指定的文件模式創(chuàng)建新的日志文件。輪轉(zhuǎn)時(shí)指定創(chuàng)建新文件的屬性,如create 0777 nobody nobody
nocreate不建立新的日志文件
delaycompress和 compress 一起使用時(shí),轉(zhuǎn)儲的日志文件到下一次轉(zhuǎn)儲時(shí)才壓縮
nodelaycompress覆蓋 delaycompress 選項(xiàng),轉(zhuǎn)儲同時(shí)壓縮
errors address專儲時(shí)的錯誤信息發(fā)送到指定的Email 地址
ifempty即使是空文件也轉(zhuǎn)儲,這個是 logrotate 的缺省選項(xiàng)。
notifempty如果是空文件的話,不轉(zhuǎn)儲
mail address把轉(zhuǎn)儲的日志文件發(fā)送到指定的E-mail 地址
nomail轉(zhuǎn)儲時(shí)不發(fā)送日志文件
olddir directory轉(zhuǎn)儲后的日志文件放入指定的目錄,必須和當(dāng)前日志文件在同一個文件系統(tǒng)
noolddir轉(zhuǎn)儲后的日志文件和當(dāng)前日志文件放在同一個目錄下
prerotate/endscript在logrotate轉(zhuǎn)儲之前需要執(zhí)行的指令,例如修改文件的屬性等動作;這兩個關(guān)鍵字必須單獨(dú)成行;
postrotate/endscript在logrotate轉(zhuǎn)儲之后需要執(zhí)行的指令,例如重新啟動 (kill -HUP) 某個服務(wù)!必須獨(dú)立成行;
daily指定轉(zhuǎn)儲周期為每天
weekly指定轉(zhuǎn)儲周期為每周
monthly指定轉(zhuǎn)儲周期為每月
rotate count指定日志文件刪除之前轉(zhuǎn)儲的個數(shù),0 指沒有備份,5 指保留5個備份
tabootext [+] list 讓logrotate不轉(zhuǎn)儲指定擴(kuò)展名的文件,缺省的擴(kuò)展名是:.rpm-orig, .rpmsave, v, 和 ~
sizesize當(dāng)日志文件到達(dá)指定的大小時(shí)才轉(zhuǎn)儲,Size 可以指定 bytes (缺省)以及KB (sizek)或者M(jìn)B (sizem).
missingok如果日志丟失,不報(bào)錯繼續(xù)滾動下一個日志
notifempty當(dāng)日志文件為空時(shí),不進(jìn)行輪轉(zhuǎn)
sharedscripts運(yùn)行postrotate腳本,作用是在所有日志都輪轉(zhuǎn)后統(tǒng)一執(zhí)行一次腳本。如果沒有配置這個,那么每個日志輪轉(zhuǎn)后都會執(zhí)行一次腳本
dateext使用當(dāng)期日期作為命名格式
dateformat .%s配合dateext使用,緊跟在下一行出現(xiàn),定義文件切割后的文件名,必須配合dateext使用,只支持 %Y %m %d %s 這四個參數(shù)
size(或minsize) log-size當(dāng)日志文件到達(dá)指定的大小時(shí)才轉(zhuǎn)儲,log-size能指定bytes(缺省)及KB (sizek)或MB(sizem).

說明:

當(dāng)日志文件 >= log-size 的時(shí)候就轉(zhuǎn)儲。

以下為合法格式:(其他格式的單位大小寫沒有試過)

  • size = 5 或 size 5 (>= 5 個字節(jié)就轉(zhuǎn)儲)
  • size = 100k 或 size 100k
  • size = 100M 或 size 100M

實(shí)例:

/home/deploy/apps/production.log {
missingok
copytruncate
rotate 10
notifempty
sharedscripts
dateext
dateformat -%Y-%m-%d-%s
size=10M
postrotatemv /home/deploy/apps/production.log-* /data1/log/railsgzip /data1/log/rails/production.log-*
endscript
}

問題:rotate和maxage的區(qū)別是什么?

它們都是用來控制保存多少日志文件的,區(qū)別在于 rotate 是以個數(shù)為單位的,而 maxage 是以天數(shù)為單位的。如果我們是以按天來輪轉(zhuǎn)日志,那么二者的差別就不大了。

3. nginx日志切割實(shí)例

vim /etc/logrotate.d/nginx   #創(chuàng)建nginx日志切割配置文件
/application/nginx/logs/*.log{
daily
rotate 10
create
dateext
}

logrotate -d /etc/logrotate.d/nginx    調(diào)試測試   -d debug
logrotate -d /etc/logrotate.d/nginx    手動切割日志測試

ls /application/nginx/logs/           帶日期的表示是切割好的日志
access.log           bbs.log-20180228   error.log           www.log
access.log-20180228  blog.log           error.log-20180228  www.log-20180228
bbs.log              blog.log-20180228  nginx.pid

配置好nginx切割日志生效時(shí)間

# cat /etc/anacrontab    #此文件里有生效時(shí)間
# /etc/anacrontab: configuration file for anacron

# See anacron(8) and anacrontab(5) for details.
 
SHELL=/bin/sh
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root

# the maximal random delay added to the base delay of the jobs
RANDOM_DELAY=45

# the jobs will be started during the following hours only
START_HOURS_RANGE=3-22   #生效時(shí)間范圍是3點(diǎn)到22點(diǎn)

#period in days   delay in minutes   job-identifier   command1       5       cron.daily              nice run-parts /etc/cron.daily7       25      cron.weekly             nice run-parts /etc/cron.weekly
@monthly 45     cron.monthly            nice run-parts /etc/cron.monthly

也就是說,配好的nginx切割日志,生效時(shí)間是在凌晨3點(diǎn)到22點(diǎn)之間,而且隨機(jī)延遲時(shí)間是45分鐘

4. 其他配置示例

/var/log/htmlaccess.log {
 errors jim
 notifempty
 nocompress
 weekly
 prerotate
 /usr/bin/chattr -a /var/log/htmlaccess.log
 endscript
 
 postrotate
 /usr/bin/chattr +a /var/log/htmlaccess.log
 endscript
}

持續(xù)集成系統(tǒng)日志處理配置

/var/log/jenkins/jenkins.log /var/log/jenkins/access_log {
    compress
    dateext
    maxage 365      #保留最大365天
    rotate 99       #最大保留99個備份
    size=+4096k
    notifempty
    missingok
    create 644
    copytruncate
}

自定義日志處理

/medialog/*.log {
    create 0644 root root
    daily
    rotate 30
    missingok
    copytruncate
    notifempty
    compress
    delaycompress
    olddir /medialog/backlog    # 將歸檔日志單獨(dú)目錄存儲
}

總結(jié)

以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • apache集成php5.6方法分享

    apache集成php5.6方法分享

    這篇文章主要介紹了apache集成php5.6方法分享,需要的朋友可以參考下
    2015-01-01
  • Ubuntu20.04安裝Python3的虛擬環(huán)境教程詳解

    Ubuntu20.04安裝Python3的虛擬環(huán)境教程詳解

    這篇文章主要介紹了Ubuntu20.04安裝Python3的虛擬環(huán)境,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-06-06
  • Linux應(yīng)用程序管理與安裝方式

    Linux應(yīng)用程序管理與安裝方式

    這篇文章主要介紹了Linux應(yīng)用程序管理與安裝方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • Linux中查找文件夾的命令解讀

    Linux中查找文件夾的命令解讀

    這篇文章主要介紹了Linux中查找文件夾的命令,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • 嵌入式Linux重啟QT應(yīng)用程序的簡單辦法(基于QT4.8 qws)

    嵌入式Linux重啟QT應(yīng)用程序的簡單辦法(基于QT4.8 qws)

    今天小編就為大家分享一篇關(guān)于嵌入式Linux重啟QT應(yīng)用程序的簡單辦法(基于QT4.8 qws),小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2018-12-12
  • CentOS如果更改yum更新源詳解

    CentOS如果更改yum更新源詳解

    平時(shí)在安裝或更新CentOS軟件時(shí),yum方式是最簡單方便的,而為避免從國外站點(diǎn)安裝更新速度過慢,需要更改yum更新源,那么CentOS怎么修改yum更新源呢?今天小編與大家分享下CentOS修改yum更新源的具體操作步驟,有需要的朋友不妨了解下。
    2016-10-10
  • centos7防火墻如何設(shè)置只對部分端口號限源

    centos7防火墻如何設(shè)置只對部分端口號限源

    這篇文章主要介紹了centos7防火墻如何設(shè)置只對部分端口號限源問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • 在Linux服務(wù)器下啟動tomcat的三種方式

    在Linux服務(wù)器下啟動tomcat的三種方式

    這篇文章主要介紹了在Linux服務(wù)器下啟動tomcat的三種方式,Linux作為一種穩(wěn)定安全的服務(wù)器一直受到業(yè)界歡迎,那么如何啟動部署在服務(wù)器上的Tomcat呢,這篇文章帶我們來了解
    2023-03-03
  • Linux?服務(wù)器硬件數(shù)據(jù)的收集及使用案例

    Linux?服務(wù)器硬件數(shù)據(jù)的收集及使用案例

    這篇文章主要介紹了Linux?服務(wù)器硬件數(shù)據(jù)的收集,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-05-05
  • CentOS 7 安裝vsftpd 服務(wù)器的具體操作步驟

    CentOS 7 安裝vsftpd 服務(wù)器的具體操作步驟

    下面小編就為大家?guī)硪黄狢entOS 7 安裝vsftpd 服務(wù)器的具體操作步驟。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08

最新評論