nohup命令 將程序以忽略掛起信號的方式運行起來,被運行的程序的輸出信息將不會顯示到終端。一般用于將程序的輸出、報錯信息重定向到一個指定路徑的指定文件。
創(chuàng)新互聯(lián)公司,專注為中小企業(yè)提供官網(wǎng)建設(shè)、營銷型網(wǎng)站制作、自適應(yīng)網(wǎng)站建設(shè)、展示型成都網(wǎng)站設(shè)計、成都網(wǎng)站建設(shè)、外貿(mào)網(wǎng)站建設(shè)等服務(wù),幫助中小企業(yè)通過網(wǎng)站體現(xiàn)價值、有效益。幫助企業(yè)快速建站、解決網(wǎng)站建設(shè)與網(wǎng)站營銷推廣問題。
語法 :nohup [command] [args] [] ? ?
nohup命令 最后要帶個作為結(jié)束
例:nohup python XXX.py abc/def/XXX.log 21
args: 0 – stdin (standard input),1 – stdout (standard output),2 – stderr (standard error) ;
21是將標(biāo)準錯誤(2)重定向到標(biāo)準輸出(1),標(biāo)準輸出(1)再被重定向輸入到文件,即XXX.log中。
nohup命令的缺點:日志文件文件越來越大,占內(nèi)存且查看麻煩。因為這個日志文件和程序是共生死的,因為只要程序運行起來,就一直對log文件進行讀寫,直接刪除XXX.log會導(dǎo)致程序也被結(jié)束了。
目前想到的一些相關(guān)方法如下,并未完全解決問題。
參考: linux下nohup日志輸出過大問題解決方案
split命令:
參數(shù):-b:值為每一輸出檔案的大小,單位為 byte。
? ? ?? -C:每一輸出檔中,單行的最大 byte 數(shù)。
? ? ?? -d:使用數(shù)字作為后綴。默認這個數(shù)字后綴是兩位的,例如00,01,11. -a: 指定位數(shù),例如 -a 4表示后綴是四位的。
? ? ?? -l:值為每一輸出檔的列數(shù)大小。
? ? ?? PREFIX:代表前導(dǎo)符,可作為切割文件的前導(dǎo)文件。
例如:
可以用split命令把很大的日志文件分成多個小文件,分割完成后 原文件不變 。不會影響nohup運行的程序。
缺點:split文件分割依賴手動,當(dāng)程序出故障或調(diào)試時,將日志分割以便查看最新的日志信息。沒法定時做到定時自動清理。
首先介紹find命令的參數(shù)
參考: linux find命令詳解
在這里主要用到的是這幾個參數(shù):
-atime n 查找系統(tǒng)中最后n*24小時訪問的文件
-ctime n? 查找系統(tǒng)中最后n*24小時被改變文件狀態(tài)的文件
-mtime n? 查找系統(tǒng)中最后n*24小時被改變文件數(shù)據(jù)的文件
+n: n天前; -n: n天之內(nèi)
find命令還可以和下一條命令連用(xargs或exec)
或
注:{}表示find到的東西;{}和 \;之間要有一個空格
我感覺exec不是很好用,怪怪的
cat dev/null
在 Linux 中, null 設(shè)備基本上被用來丟棄某個進程不再需要的輸出流,或者作為某個輸入流的空白文件,這些通常可以利用重定向機制來達到。
所以 /dev/null 設(shè)備文件是一個特殊的文件,它將清空送到它這里來的所有輸入,而它的輸出則可被視為一個空文件。另外,你可以通過使用 cat 命令顯示 /dev/null 的內(nèi)容然后重定向輸出到某個文件,以此來達到清空該文件的目的。通過使用cat /dev/null,文件大小為0字節(jié)。
用cat刪除文件:
但是我發(fā)現(xiàn)對于nohup的程序的日志,這樣是無效的。因為nohup的程序持續(xù)不斷地在讀寫日志文件,此時無法重定向,我試了幾次,日志文件都壓根沒動。
crontab用于設(shè)置定時任務(wù)
參考:? linux crontab定時執(zhí)行shell腳本
crontab命令被用來提交和管理用戶的需要周期性執(zhí)行的任務(wù),與windows下的計劃任務(wù)類似,當(dāng)安裝完成操作系統(tǒng)后,默認會安裝此服務(wù)工具,并且會自動啟動crond進程,crond進程每分鐘會定期檢查是否有要執(zhí)行的任務(wù),如果有要執(zhí)行的任務(wù),則自動執(zhí)行該任務(wù)。
語法
crontab(選項)(參數(shù))
選項
-e:編輯該用戶的計時器設(shè)置;
-l:列出該用戶的計時器設(shè)置;
-r:刪除該用戶的計時器設(shè)置;
-u用戶名稱:指定要設(shè)定計時器的用戶名稱。
參數(shù)
crontab文件:指定包含待執(zhí)行任務(wù)的crontab文件。
首先crontab -e,就會進入vi編輯界面。然后直接把新的命令輸進去就行了。
minute hour day month week command /XXX/XXX.log 順序:分 時 日 月 周
minute: 表示分鐘,可以是從0到59之間的任何整數(shù)。
hour:表示小時,可以是從0到23之間的任何整數(shù)。
day:表示日期,可以是從1到31之間的任何整數(shù)。
month:表示月份,可以是從1到12之間的任何整數(shù)。
week:表示星期幾,可以是從0到7之間的任何整數(shù),這里的0或7代表星期日。
/n表示每個n的單位執(zhí)行一次
command:要執(zhí)行的命令,可以是系統(tǒng)命令,也可以是自己編寫的腳本文件。
意為每周的1:00執(zhí)行,且輸出重定向到黑洞目錄。
查看某個目錄的文件大小并排序 (單位為MB)
清空 /var/log/journal 文件的方法
1、用echo命令,將空字符串內(nèi)容重定向到指定文件中
echo "" system.journal
2、journalctl 命令自動維護文件大小
1)只保留近一周的日志
journalctl --vacuum-time=1w
2)只保留500MB的日志
journalctl --vacuum-size=500M
3)直接刪除 /var/log/journal/ 目錄下的日志文件
rm -rf /var/log/journal/f9d400c5e1e8c3a8209e990d887d4ac1
問題與分析解決
執(zhí)行 journalctl時報錯:Error was encountered while opening journal files: Input/output error
問題分析:日志文件損壞
解決方法:刪除之前的日志,并重啟 journalctl 服務(wù)
然后,再執(zhí)行 journalctl 限制日志的命令:
1.做自動部署系統(tǒng)時精簡的一個腳本,主要功能是清理所有目錄的日志
2.根據(jù)給定日志目錄,刪除時間 結(jié)合crontab進行清理日志,清理完成后,后在/var/log/deltelog/ 生成按照月的清理日志
3.擴展,因為腳本采用mtime(最后修改時間)進行刪除,所以可以適用于刪除過期備份等,不受文件名稱的限制
shell小竅門
find –type f –print 時會根據(jù)換行或者空格來輸出查找的文件,在不同的sh下有不同的`反應(yīng),如果不做處理結(jié)合xargs 進行刪除 更改操作,會有影響
所以需要增加 –print0 用 null來 作為邊界符號,才敢結(jié)婚 xargs –o 來格式化輸入
使用find 的時候 遵循最小結(jié)果集原則,find解析式從左到右,所有確保你在最左邊的過濾符號能夠過濾最大數(shù)據(jù)
你可以根據(jù)你的需要增加到crontab中
shell腳本
復(fù)制代碼 代碼如下:
#!/bin/sh
###########################
# log blog.duplicatedcode.com
# in_day_num: like 1 2 is 2day ago logs
# in_log_path like tomcat log home
###########################
in_log_path=${1}
in_day_num=${2}
tmp__log=/var/log/log/"`date +%Y%m`.log"
Log()
{
inner_num=${1}
#find log
echo "[`date`] start logs---" $tmp__log
find ${in_log_path} -type f -mtime ${inner_num} -print0 | xargs -0 rm -rf
echo "[`date`] end logs---" $tmp__log
}
init()
{
mkdir -p /var/log/log/
}
main()
{
init
if [ -z ${in_log_path} ];then
echo "[`date`] error log_path not init---" $tmp__log
return
fi
inner_day_num=+7
if [[ -n ${in_day_num} ]] [[ ${in_day_num} -ge 1 ]] ; then
${inner_day_num}=${in_day_num}
fi
Log ${inner_day_num}
}
main
例: vi /var/log/messages :set nu 查看文件中的你要刪除的時間段在幾行之間 如果是100-200行,則將光標(biāo)放在第100行,按100dd即可刪除。 還有其他方法。看你的具體需求。
使用過Windows的人都知道,在使用windows系統(tǒng)的.過程中系統(tǒng)會變得越來越慢。而對于Windows下飽受詬病的各種垃圾文件都需要自己想辦法刪除,不然系統(tǒng)將會變得越來越大,越來越遲鈍!windows怎么清理垃圾相信大家都知道的,那么linux下怎么清理系統(tǒng)垃圾呢?
Linux的文件系統(tǒng)比Windows的要優(yōu)秀,不會產(chǎn)生碎片,對于長時間運行的服務(wù)器來說尤為重要,而且Linux系統(tǒng)本身也不會像Windows一樣產(chǎn)生大量的垃圾文件。不知道這個說法有沒有可信度!至少我們可以確定的是linux系統(tǒng)的文件系統(tǒng)是比較優(yōu)秀的!
錯誤
rm -f logfile
原因
應(yīng)用已經(jīng)打開文件句柄,直接刪除會造成:
1.應(yīng)用無法正確釋放日志文件和寫入
2.顯示磁盤空間未釋放
正確
cat /dev/null logfile
把一下代碼保存為.sh后綴腳本來運行即可清除Linux系統(tǒng)日志
#!/bin/sh
cat /dev/null /var/log/syslog
cat /dev/null /var/adm/sylog
cat /dev/null /var/log/wtmp
cat /dev/null /var/log/maillog
cat /dev/null /var/log/messages
cat /dev/null /var/log/openwebmail.log
cat /dev/null /var/log/maillog
cat /dev/null /var/log/secure
cat /dev/null /var/log/httpd/error_log
cat /dev/null /var/log/httpd/ssl_error_log
cat /dev/null /var/log/httpd/ssl_request_log
cat /dev/null /var/log/httpd/ssl_access_log
另外清理linux系統(tǒng)垃圾還有以下命令
sudo apt-get autoclean 清理舊版本的軟件緩存
sudo apt-get clean 清理所有軟件緩存
sudo apt-get autoremove 刪除系統(tǒng)不再使用的孤立軟件
新聞標(biāo)題:linux清除日志命令,linux 日志刪除
轉(zhuǎn)載注明:http://vcdvsql.cn/article20/hchjjo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)、域名注冊、移動網(wǎng)站建設(shè)、App設(shè)計、網(wǎng)站建設(shè)、微信小程序
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)