当前位置: 技术问答>linux和unix
?linux输出重定位
来源: 互联网 发布时间:2016-05-16
本文导语: 现有linux环境下可执行程序exeDSP, 该程序中有大量printf输出。 要求:(1) 不更改exeDSP源程序(没有源代码) (2) 把标准输出重定位到文件 (3) 由于输出量比较大,只在文件中保存最近10分钟的输出 跪...
现有linux环境下可执行程序exeDSP, 该程序中有大量printf输出。
要求:(1) 不更改exeDSP源程序(没有源代码)
(2) 把标准输出重定位到文件
(3) 由于输出量比较大,只在文件中保存最近10分钟的输出
跪求高手赐教,通过什么方式实现?
要求:(1) 不更改exeDSP源程序(没有源代码)
(2) 把标准输出重定位到文件
(3) 由于输出量比较大,只在文件中保存最近10分钟的输出
跪求高手赐教,通过什么方式实现?
|
1、要求不严格的话,可以在crontab 中增加一个命令 > log.txt,每隔10分钟执行一次。执行exeDSP程序时,使用exeDSP >> 2>&1 log.txt方式。这样每隔10分钟将文件清空一次。
2、如果必须保存不少于10分钟的内容,可以在crontab中增加cp log.txt log.txt.tmp 和 > log.txt两个命令,最好将这两个命令写成一个批处理程序,以确保顺序执行,再执行exeDSP >> 2>&1 log.txt,这样,可以备份不小于10分钟的日志内容。
2、如果必须保存不少于10分钟的内容,可以在crontab中增加cp log.txt log.txt.tmp 和 > log.txt两个命令,最好将这两个命令写成一个批处理程序,以确保顺序执行,再执行exeDSP >> 2>&1 log.txt,这样,可以备份不小于10分钟的日志内容。
|
Linux Shell 环境中支持输入输出重定向,用符号""来表示。0、1和2分别表示标准输入、标准输出和标准错误信息输出,可以用来指定需要重定向的标准输入或输出,比如 2>a.txt 表示将错误信息输出到文件a.txt中。
同时,还可以在这三个标准输入输出之间实现重定向,比如将错误信息重定向到标准输出,可以用 2>&1来实现。
Linux下还有一个特殊的文件/dev/null,它就像一个无底洞,所有重定向到它的信息都会消失得无影无踪。这一点非常有用,当我们不需要回显程序的所有信息时,就可以将输出重定向到/dev/null。
如果想要正常输出和错误信息都不显示,则要把标准输出和标准错误都重定向到/dev/null, 例如:
# ls 1>/dev/null 2>/dev/null
还有一种做法是将错误重定向到标准输出,然后再重定向到 /dev/null,例如:
# ls >/dev/null 2>&1
注意:此处的顺序不能更改,否则达不到想要的效果,此时先将标准输出重定向到 /dev/null,然后将标准错误重定向到标准输出,由于标准输出已经重定向到了/dev/null,因此标准错误也会重定向到/dev/null,于是一切静悄悄:-)
另外+:
make >& make_log
意思是把标准输出和错误输出都重定向, make>out 只重定向标准输出!!!!!
>log 表示把标准输出重新定向到文件log中
>& log 表示把标准输出和错误输出都定向到文件log中,相当于 >log 2>&1
======================================
exeDSP 1>log.txt
只保存最近10分钟的,就唔知了。
同时,还可以在这三个标准输入输出之间实现重定向,比如将错误信息重定向到标准输出,可以用 2>&1来实现。
Linux下还有一个特殊的文件/dev/null,它就像一个无底洞,所有重定向到它的信息都会消失得无影无踪。这一点非常有用,当我们不需要回显程序的所有信息时,就可以将输出重定向到/dev/null。
如果想要正常输出和错误信息都不显示,则要把标准输出和标准错误都重定向到/dev/null, 例如:
# ls 1>/dev/null 2>/dev/null
还有一种做法是将错误重定向到标准输出,然后再重定向到 /dev/null,例如:
# ls >/dev/null 2>&1
注意:此处的顺序不能更改,否则达不到想要的效果,此时先将标准输出重定向到 /dev/null,然后将标准错误重定向到标准输出,由于标准输出已经重定向到了/dev/null,因此标准错误也会重定向到/dev/null,于是一切静悄悄:-)
另外+:
make >& make_log
意思是把标准输出和错误输出都重定向, make>out 只重定向标准输出!!!!!
>log 表示把标准输出重新定向到文件log中
>& log 表示把标准输出和错误输出都定向到文件log中,相当于 >log 2>&1
======================================
exeDSP 1>log.txt
只保存最近10分钟的,就唔知了。