摘要:在輪循任務完成后,已輪循的歸檔將使用進行壓縮。在日志輪循期間,任何錯誤將被忽略,例如文件無法找到之類的錯誤。在這種情況下,進程將立即再次讀取其配置并繼續運行。表示,每隔分鐘,執行打印一次命令第二步添加定時任務。
1、關于日志切割
日志文件包含了關于系統中發生的事件的有用信息,在排障過程中或者系統性能分析時經常被用到。對于忙碌的服務器,日志文件大小會增長極快,服務器會很快消耗磁盤空間,這成了個問題。除此之外,處理一個單個的龐大日志文件也常常是件十分棘手的事。
logrotate是個十分有用的工具,它可以自動對日志進行截斷(或輪循)、壓縮以及刪除舊的日志文件。例如,你可以設置logrotate,讓/var/log/foo日志文件每30天輪循,并刪除超過6個月的日志。配置完后,logrotate的運作完全自動化,不必進行任何進一步的人為干預。
2、安裝logrotate
[root@localhost ~]# cat /etc/redhat-release CentOS release 6.9 (Final) [root@localhost ~]# uname -r 2.6.32-696.23.1.el6.x86_64
默認centos系統安裝自帶logrotate,如果沒有安裝可以使用yum安裝,安裝方法如下:
yum -y install logrotate crontabs
軟件包信息說明:
[root@localhost ~]# rpm -ql logrotate /etc/cron.daily/logrotate /etc/logrotate.conf /etc/logrotate.d
安裝完成之后需要啟動rsyslog:
service rsyslog start
logrotate的配置文件是/etc/logrotate.conf,通常不需要對它進行修改。日志文件的輪循設置在獨立的配置文件中,它(們)放在/etc/logrotate.d/目錄下。
3、實踐配置logrotate
3.1
測試logrotate如何管理日志
這里我們將創建一個10MB的日志文件/var/log/log-file。我們將展示怎樣使用logrotate來管理該日志文件。我們從創建一個日志文件開始吧,然后在其中填入一個10MB的隨機比特流數據文件。
[root@localhost ~]# dd if=/dev/zero of=/var/log/log_file bs=1M count=10
現在日志文件已經準備好,我們將配置logrotate來輪循該日志文件。讓我們為該文件創建一個配置文件。
[root@localhost ~]# vim /etc/logrotate.d/log_file /var/log/log_file { monthly rotate 5 compress delaycompress missingok notifempty create 644 root root postrotate /usr/bin/killall -HUP rsyslogd endscript }
3.2配置文件說明
monthly:日志文件將按月輪循。其它可用值為‘daily’,‘weekly’或者‘yearly’。
rotate 5: 一次將存儲5個歸檔日志。對于第六個歸檔,時間最久的歸檔將被刪除。
compress: 在輪循任務完成后,已輪循的歸檔將使用gzip進行壓縮。
delaycompress:總是與compress選項一起用,delaycompress選項指示logrotate不要將最近的歸檔壓縮,壓縮 將在下一次輪循周期進行。這在你或任何軟件仍然需要讀取最新歸檔時很有用。
missingok: 在日志輪循期間,任何錯誤將被忽略,例如“文件無法找到”之類的錯誤。
notifempty: 如果日志文件為空,輪循不會進行。
create 644 root root: 以指定的權限創建全新的日志文件,同時logrotate也會重命名原始日志文件。
postrotate/endscript:在所有其它指令完成后,postrotate和endscript里面指定的命令將被執行。在這種情
況下,rsyslogd進程將立即再次讀取其配置并繼續運行。
上面的模板是通用的,而配置參數則根據你的需求進行調整,不是所有的參數都是必要的。
/var/log/log_file { size=50M rotate 5 dateext create 644 root root postrotate /usr/bin/killall -HUP rsyslogd endscript }
在上面的配置文件中,我們只想要輪詢一個日志文件,size=50M指定日志文件大小可以增長到50MB,dateext指
示讓舊日志文件以創建日期命名。
3.3手動運行logrotate
logrotate可以在任何時候從命令行手動調用。
調用/etc/lograte.d/下配置的所有日志:
[root@localhost ~]# logrotate /etc/logrotate.conf
要為某個特定的配置調用logrotate:
[root@localhost ~]# logrotate /etc/logrotate.d/log_file
排障過程中的最佳選擇是使用‘-d’選項以預演方式運行logrotate。要進行驗證,不用實際輪循任何日志文件,
可以模擬演練日志輪循并顯示其輸出。
[root@localhost ~]# logrotate -d /etc/logrotate.d/log_file
reading config file /etc/logrotate.d/log_file reading config info for /var/log/log_file Handling 1 logs rotating pattern: /var/log/log_file monthly (5 rotations) empty log files are not rotated, old logs are removed considering log /var/log/log_file log does not need rotating not running postrotate script, since no logs were rotated
正如我們從上面的輸出結果可以看到的,logrotate判斷該輪循是不必要的。如果文件的時間小于一天,這就會發生了。
3.4強制輪循即使輪循條件沒有滿足,我們也可以通過使用‘-f’選項來強制logrotate輪循日志文件,‘-v’參數提供了詳細的輸出。
[root@localhost ~]# logrotate -vf /etc/logrotate.d/log_file reading config file /etc/logrotate.d/log_file reading config info for /var/log/log_file Handling 1 logs rotating pattern: /var/log/log_file forced from command line (5 rotations) empty log files are not rotated, old logs are removed considering log /var/log/log_file log needs rotating rotating log /var/log/log_file, log->rotateCount is 5 dateext suffix "-20180503" glob pattern "-[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]" previous log /var/log/log_file.1 does not exist renaming /var/log/log_file.5.gz to /var/log/log_file.6.gz (rotatecount 5, logstart 1, i 5), old log /var/log/log_file.5.gz does not exist renaming /var/log/log_file.4.gz to /var/log/log_file.5.gz (rotatecount 5, logstart 1, i 4), old log /var/log/log_file.4.gz does not exist renaming /var/log/log_file.3.gz to /var/log/log_file.4.gz (rotatecount 5, logstart 1, i 3), old log /var/log/log_file.3.gz does not exist renaming /var/log/log_file.2.gz to /var/log/log_file.3.gz (rotatecount 5, logstart 1, i 2), old log /var/log/log_file.2.gz does not exist renaming /var/log/log_file.1.gz to /var/log/log_file.2.gz (rotatecount 5, logstart 1, i 1), old log /var/log/log_file.1.gz does not exist renaming /var/log/log_file.0.gz to /var/log/log_file.1.gz (rotatecount 5, logstart 1, i 0), old log /var/log/log_file.0.gz does not exist log /var/log/log_file.6.gz doesn"t exist -- won"t try to dispose of it fscreate context set to unconfined_u:object_r:var_log_t:s0 renaming /var/log/log_file to /var/log/log_file.1 creating new /var/log/log_file mode = 0644 uid = 0 gid = 0 running postrotate script set default create context
3.5 logrotate定時任務
logrotate需要的cron任務應該在安裝時就自動創建了,我把cron文件的內容貼出來,以供大家參考。
[root@localhost ~]# cat /etc/cron.daily/logrotate #!/bin/sh /usr/sbin/logrotate /etc/logrotate.conf EXITVALUE=$? if [ $EXITVALUE != 0 ]; then /usr/bin/logger -t logrotate "ALERT exited abnormally with [$EXITVALUE]" fi exit 0
4、logrotate生產應用
4.1為nginx設置日志切割、防止日志文件過大
[root@localhost ~]# cat /etc/logrotate.d/nginx /var/log/nginx/*.log { daily rotate 5 missingok notifempty create 644 www www postrotate if [ -f /application/nginx/logs/nginx.pid ]; then kill -USR1 `cat /application/nginx/logs/nginx.pid` fi endscript }
logrotate工具對于防止因龐大的日志文件而耗盡存儲空間是十分有用的。配置完畢后,進程是全自動的,可以長
時間在不需要人為干預下運行。本教程重點關注幾個使用logrotate的幾個基本樣例,你也可以定制它以滿足你的
需求。
5、常見配置參數小結:
daily :指定轉儲周期為每天
weekly :指定轉儲周期為每周
monthly :指定轉儲周期為每月
rotate count :指定日志文件刪除之前轉儲的次數,0指沒有備份,5 指保留5 個備份
tabooext [+] list:讓logrotate不轉儲指定擴展名的文件,缺省的擴展名是:.rpm-orig, .rpmsave,
v, 和 ~
missingok:在日志輪循期間,任何錯誤將被忽略,例如“文件無法找到”之類的錯誤。
size size:當日志文件到達指定的大小時才轉儲,bytes(缺省)及KB(sizek)或MB(sizem)
compress: 通過gzip壓縮轉儲以后的日志
nocompress: 不壓縮
copytruncate:用于還在打開中的日志文件,把當前日志備份并截斷
nocopytruncate: 備份日志文件但是不截斷
create mode owner group : 轉儲文件,使用指定的文件模式創建新的日志文件
nocreate: 不建立新的日志文件
delaycompress: 和 compress 一起使用時,轉儲的日志文件到下一次轉儲時才壓縮
nodelaycompress: 覆蓋 delaycompress選項,轉儲同時壓縮。
errors address : 專儲時的錯誤信息發送到指定的Email 地址
ifempty :即使是空文件也轉儲,這個是logrotate 的缺省選項。
notifempty :如果是空文件的話,不轉儲
mail address : 把轉儲的日志文件發送到指定的E-mail地址
nomail : 轉儲時不發送日志文件
olddir directory:儲后的日志文件放入指定的目錄,必須和當前日志文件在同一個文件系統
noolddir: 轉儲后的日志文件和當前日志文件放在同一個目錄下
prerotate/endscript: 在轉儲以前需要執行的命令可以放入這個對,這兩個關鍵字必須多帶帶成行
Linux下的crontab定時執行任務命令詳解
在LINUX中,周期執行的任務一般由cron這個守護進程來處理[ps -ef|grep cron]。cron讀取一個或多個配置文件,這些配置文件中包含了命令行及其調用時間。
cron的配置文件稱為“crontab”,是“cron table”的簡寫。
一、cron服務
cron是一個linux下 的定時執行工具,可以在無需人工干預的情況下運行作業。
service crond start //啟動服務
service crond stop //關閉服務
service crond restart //重啟服務
service crond reload //重新載入配置
service crond status //查看服務狀態
二、cron在3個地方查找配置文件:
1、/var/spool/cron/ 這個目錄下存放的是每個用戶包括root的crontab任務,每個任務以創建者的名字命名,比如tom建的crontab任務對應的文件就是/var/spool/cron/tom。一般一個用戶最多只有一個crontab文件。
三、/etc/crontab 這個文件負責安排由系統管理員制定的維護系統以及其他任務的crontab:
[root@localhost cron]# cat /etc/crontab SHELL=/bin/bash PATH=/sbin:/bin:/usr/sbin:/usr/bin MAILTO=root HOME=/ # For details see man 4 crontabs # Example of job definition: # .---------------- minute (0 - 59) # | .------------- hour (0 - 23) # | | .---------- day of month (1 - 31) # | | | .------- month (1 - 12) OR jan,feb,mar,apr ... # | | | | .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat # | | | | | # * * * * * user-name command to be executed
MAILTO=root:是說,當 /etc/crontab 這個檔案中的例行性命令發生錯誤時,會將錯誤訊息或者是屏幕顯示的訊息傳給誰?由于 root 并無法再用戶端收信,因此,我通常都將這個 e-mail 改成自己的賬號,好讓我隨時了解系統的狀態!
[root@localhost cron]# cat /etc/cron.d/0hourly SHELL=/bin/bash PATH=/sbin:/bin:/usr/sbin:/usr/bin MAILTO=root HOME=/ 01 * * * * root run-parts /etc/cron.hourly
01 root run-parts /etc/cron.hourly:在 #run-parts 這一行以后的命令,我們可以發現,五個數字后面接的是 root ,這一行代表的是『執行的級別為root身份』當然,你也可以將這一行改為成其他的身份!而 run-parts代表后面接的 /etc/cron.hourly 是『一個目錄內(/etc/cron.hourly)的所有可執行文件』,也就是說,每個小時的01分,系統會以root身份去/etc/cron.hourly這個目錄下執行所有可執行的文件!后面三行也是類似的意思!你可以到 /etc/ 底下去看看,系統本來就預設了這4個目錄!你可以將每天需要執行的命令直接寫到/etc/cron.daily即可,還不需要使用到crontab -e的程式!
四、/etc/cron.d/ 這個目錄用來存放任何要執行的crontab文件或腳本。
五、權限
crontab權限問題到/etc下一看,文件cron.allow和cron.deny是否存在
用法如下:
1、如果兩個文件都不存在,則只有root用戶才能使用crontab命令。
2、如果cron.allow存在但cron.deny不存在,則只有列在cron.allow文件里的用戶才能使用crontab命令,如果root用戶也不在里面,則root用戶也不能使用crontab。
3、如果cron.allow不存在, cron.deny存在,則只有列在cron.deny文件里面的用戶不能使用crontab命令,其它用戶都能使用。
4、如果兩個文件都存在,則列在cron.allow文件中而且沒有列在cron.deny中的用戶可以使用crontab,如果兩個文件中都有同一個用戶,以cron.allow文件里面是否有該用戶為準,如果cron.allow中有該用戶,則可以使用crontab命令。
AIX 中 普通用戶默認都有 crontab 權限,如果要限制用戶使用 crontab ,就需要編輯/etc/cron.deny
HP-UNIX 中默認普通用戶沒得crontab 權限 ,要想放開普通用戶的crontab 權限可以編
六、創建cron腳本
第一步:寫cron腳本文件,命名為crontest.cron。
15,30,45,59 echo "xgmtest....." >> xgmtest.txt 表示,每隔15分鐘,執行打印一次命令
第二步:添加定時任務。執行命令 "crontab crontest.cron"
第三步:"crontab -l" 查看定時任務是否成功或者檢測/var/spool/cron下是否生成對應cron腳本
注意:這操作是直接替換該用戶下的crontab,而不是新增
七、crontab用法
crontab命令用于安裝、刪除或者列出用于驅動cron后臺進程的表格。用戶把需要執行的命令序列放到crontab文件中以獲得執行。每個用戶都可以有自己的crontab文件。/var/spool/cron下的crontab文件不可以直接創建或者直接修改。該crontab文件是通過crontab命令創建的
在crontab文件中如何輸入需要執行的命令和時間。該文件中每行都包括六個域,其中前五個域是指定命令被執行的時間,最后一個域是要被執行的命令。每個域之間使用空格或者制表符分隔。格式如下:
minute hour day-of-month month-of-year day-of-week commands 合法值 00-59 00-23 01-31 01-12 0-6 (0 is sunday) 除了數字還有幾個個特殊的符號就是""、"/"和"-"、",",代表所有的取值范圍內的數字,"/"代表每的意思,"/5"表示每5個單位,"-"代表從某個數字到某個數字,","分開幾個離散的數字。
-l 在標準輸出上顯示當前的crontab。
-r 刪除當前的crontab文件。
-e 使用VISUAL或者EDITOR環境變量所指的編輯器編輯當前的crontab文件。當結束編輯離開時,編輯后的文件將自動安裝。
八、例子:
每天早上6點
0 6 * echo "Good morning." >> /tmp/test.txt //注意單純echo,從屏幕上看不到任何輸出,因為cron把任何輸出都email到root的信箱了。
每兩個小時
0 /2 echo "Have a break now." >> /tmp/test.txt
晚上11點到早上8點之間每兩個小時和早上八點
0 23-7/2,8 * echo "Have a good dream" >> /tmp/test.txt
每個月的4號和每個禮拜的禮拜一到禮拜三的早上11點
0 11 4 * 1-3 command line
1月1日早上4點
0 4 1 1 * command line SHELL=/bin/bash PATH=/sbin:/bin:/usr/sbin:/usr/bin MAILTO=root //如果出現錯誤,或者有數據輸出,數據作為郵件發給這個帳號 HOME=/
每小時執行/etc/cron.hourly內的腳本
01 root run-parts /etc/cron.hourly
每天執行/etc/cron.daily內的腳本
02 4 * root run-parts /etc/cron.daily
每星期執行/etc/cron.weekly內的腳本
22 4 0 root run-parts /etc/cron.weekly
每月去執行/etc/cron.monthly內的腳本
42 4 1 root run-parts /etc/cron.monthly
注意: "run-parts"這個參數了,如果去掉這個參數的話,后面就可以寫要運行的某個腳本名,而不是文件夾名。
每天的下午4點、5點、6點的5 min、15 min、25 min、35 min、45 min、55 min時執行命令。
5,15,25,35,45,55 16,17,18 * command
每周一,三,五的下午3:00系統進入維護狀態,重新啟動系統。
00 15 1,3,5 shutdown -r +5
每小時的10分,40分執行用戶目錄下的innd/bbslin這個指令:
10,40 innd/bbslink
每小時的1分執行用戶目錄下的bin/account這個指令:
1 bin/account
每天早晨三點二十分執行用戶目錄下如下所示的兩個指令(每個指令以;分隔):
20 3 * (/bin/rm -f expire.ls logins.bad;bin/expire$#@62;expire.1st)
每年的一月和四月,4號到9號的3點12分和3點55分執行/bin/rm -f expire.1st這個指令,并把結果添加在mm.txt這個文件之后(mm.txt文件位于用戶自己的目錄位置)。
12,55 3 4-9 1,4 * /bin/rm -f expire.1st$#@62;$#@62;mm.txt
6、參考:
1、https://www.nmtui.com/clsn/lx...
2、https://linux.cn/article-4126...
3、https://www.cnblogs.com/longj...
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/39912.html
摘要:日志文件總管日志輪轉工具可以自動對日志文件提供截斷壓縮以及輪轉的功能。使用假設我們現在有一個日志文件存儲在,需要對其每日進行切分為新舊兩個日志文件,并刪除天前的舊日志。以后系統就會對該日志進行自動的輪轉管理。 部署網絡應用時,會對請求進行日志保存,用于數據統計分析以及故障排除,但對于高并發請求的服務器,日志文件會迅速增長,快速的消耗磁盤空間,同時,分析一個大文件來排查問題也會非常慢。因...
閱讀 2236·2021-11-24 11:15
閱讀 3080·2021-11-24 10:46
閱讀 1378·2021-11-24 09:39
閱讀 3924·2021-08-18 10:21
閱讀 1478·2019-08-30 15:53
閱讀 1395·2019-08-30 11:19
閱讀 3321·2019-08-29 18:42
閱讀 2321·2019-08-29 16:58