濮阳杆衣贸易有限公司

主頁 > 知識庫 > 詳解linux下nohup日志輸出過大問題解決方案

詳解linux下nohup日志輸出過大問題解決方案

熱門標(biāo)簽:承德地圖標(biāo)注公司 地圖標(biāo)注如何改成微信號 400電話號碼辦理多少錢 濮陽好的聯(lián)通400電話申請 百度地圖標(biāo)注公司位置要多少錢 靈圖uu電子寵物店地圖標(biāo)注 山東企業(yè)外呼系統(tǒng)公司 地圖標(biāo)注黃河的位置 虛假地圖標(biāo)注

最近在一hadoop測試集群運(yùn)行一個(gè)spark streaming程序,然后使用nohup ./execute.sh & 執(zhí)行讓程序后臺運(yùn)行,才幾天日志就上G了,如果有問題想要查看日志,顯然打開文件是一件很麻煩的事,于是我想辦法通過減小文件大小:

1、nohup命令解釋:

  a、語法:nohup [command] [args] [&]

  b、說明:nohup 命令運(yùn)行由 Command 參數(shù)和任何相關(guān)的 Arg 參數(shù)指定的命令,忽略所有掛斷信號。在注銷后使用 nohup 命令運(yùn)行后臺中的程序。要運(yùn)行后臺中的 nohup 命令,添加 & ( 表示“and”的符號)到命令的尾部,如果不指定重定向,則日志默認(rèn)輸出到當(dāng)前目錄下nohup.out文件中,

  一般提交如 :nohup ./execute.sh &  這樣日志或輸出當(dāng)前運(yùn)行目下.nohup.out中

  重定向: nohup ./execute.sh >  /home/xxx/log.log 2>&1 & :這樣日志會重定向到指定目錄下

2 、切分nohup.out,同時(shí)不讓它無限增長

我這里用的一般提交命令:nohup ./execute.sh &,這樣在當(dāng)前目錄就有nohup.out文件了,這時(shí)候可以想辦法定時(shí)將nohup.out切分成,多個(gè)小文件,但同時(shí)又要使nohup.out不會無限增長下去(一般情況下是程序不能中斷的):

    a、每天(根據(jù)需要設(shè)置時(shí)間),定時(shí)切分前一天的日志,(比如每天大概1g,那么可以么次切分100m左右),

    b、切分完后將nohup.out文件情況,保證新的輸出日志會不停的繼續(xù)輸出到nohup.out

以上在shell中

current_date=`date -d "-1 day" "+%Y%m%d"`

split  -b 65535000 -d -a 4  nohup.out  ./log/log_${current_date}_   這里使用split命令,將nouhup文件按指定大小切分(65535000b 大概60多M吧,可以自定義大小 ),并分成指定格式(-d -a 4以4位數(shù)字形式為后綴以從0000開始,具體可以百度split命令用法),最終輸出格式為log_20160610_0001

  cat /dev/null > nohup.out  (該命令會瞬間清空nohup.out文件,后續(xù)會繼續(xù)寫該文件),將日志定向到/dev/null中

使用重定向輸出一樣可以這樣,只不過換成重定向的文件名即可

將這些命令定義在一個(gè)shell文件每天定時(shí)運(yùn)行即可,這樣每天日志會被分成若干份,排查也方便,而且如果日志積壓過大的話??梢远〞r(shí)刪除歷史的日志,保留近幾天即可

整體代碼如下:

this_path=$(cd `dirname $0`;pwd)
 
cd $this_path
echo $this_path
current_date=`date -d "-1 day" "+%Y%m%d"`
echo $current_date
split -b 65535000 -d -a 4 /home/.../nohup.out  /home/.../log/log_${current_date}_
 
cat /dev/null > nohup.out

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:安康 上海 樂山 福州 鷹潭 淮安 德宏 泰安

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解linux下nohup日志輸出過大問題解決方案》,本文關(guān)鍵詞  詳解,linux,下,nohup,日志,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳解linux下nohup日志輸出過大問題解決方案》相關(guān)的同類信息!
  • 本頁收集關(guān)于詳解linux下nohup日志輸出過大問題解決方案的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    都兰县| 肇东市| 海安县| 伽师县| 宜章县| 田东县| 大足县| 改则县| 凤庆县| 安庆市| 大港区| 台北市| 青海省| 河间市| 榕江县| 玉龙| 沙雅县| 渑池县| 安徽省| 文水县| 保康县| 贡嘎县| 峨边| 尚义县| 曲松县| 明星| 都兰县| 静宁县| 八宿县| 泗阳县| 湘阴县| 龙胜| 牙克石市| 玉山县| 比如县| 青川县| 普宁市| 酒泉市| 集安市| 库伦旗| 库尔勒市|