前言
如果想要把命令的輸出保存到文件中,你會(huì)怎么做?
一個(gè)常用的方法就是使用IO重定向吧
ls >/tmp/ls.txt 2>&1
如果需要在將命令輸出保存到文件中的同時(shí)還需要將內(nèi)容也輸出到屏幕中的話,那么我們可以使用 tee 命令
ls |tee /tmp/ls.txt
不過(guò),我今天發(fā)現(xiàn)還有一個(gè) logsave 的命令,也可以做到將命令輸出保存到文件的同時(shí)將內(nèi)容頁(yè)輸出到屏幕中。
logsave 的語(yǔ)法非常簡(jiǎn)單:
logsave [ -asv ] logfile cmd_prog [args ... ]
選項(xiàng)
-a:追加信息到指定的日志文件中。
參數(shù)
logsave 會(huì)執(zhí)行 cmd_prog args... 并將命令輸出的副本保存到 logfile 中. 而它厲害的地方在于 即使logfile所在的目錄不存在,logsave也會(huì)將輸出保存到內(nèi)存中,等到logfile所在的目錄建立后再將內(nèi)容寫(xiě)入到日志文件中
logsave 的這個(gè)特性使得它很適合用于系統(tǒng)啟動(dòng)腳本中,將輸出的內(nèi)容保存到內(nèi)存中,直到 /var/ 目錄掛載后再將內(nèi)容寫(xiě)入 /var/log/ 中
比如下面這個(gè)例子
# 刪除存放logfile的目錄 rm -rf /tmp/logdir # 使用logsave保存logfile logsave /tmp/logdir/logfile bash -c "sleep 2;date" # 創(chuàng)建logdir mkdir /tmp/logdir echo 查看logfile是否生成: ls -l /tmp/logdir echo 等待2s后: sleep 2 echo 再次查看logfile是否生成: ls -l /tmp/logdir echo 查看logfile的內(nèi)容: cat /tmp/logdir/logfile
2018年 05月 14日 星期一 16:31:44 CST 查看logfile是否生成: 總用量 0 等待2s后: 再次查看logfile是否生成: 總用量 4 -rw-r--r-- 1 lujun9972 lujun9972 141 5月 14 16:31 logfile 查看logfile的內(nèi)容: Log of bash -c sleep 2;date Mon May 14 16:31:42 2018 2018年 05月 14日 星期一 16:31:44 CST Mon May 14 16:31:44 2018 ----------------
從中可以看到:
logsave 中的 cmd_prog 可以是一個(gè)特殊的 - ,這表示 logsave 從標(biāo)準(zhǔn)輸入中獲取要記錄日志的內(nèi)容,這使得 logsave 可以像 tee 一樣被使用
ls |wc -l |logsave /tmp/1.txt - >/dev/null cat /tmp/1.txt
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
標(biāo)簽:邵陽(yáng) 撫州 岳陽(yáng) 南陽(yáng) 白城 泉州 南陽(yáng) 葫蘆島
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《利用logsave如何將命令輸出保存起來(lái)》,本文關(guān)鍵詞 利用,logsave,如何,將,命令,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。