nohup的用法
2015-07-29 12:01
260 查看
linux重定向及nohup不输出的方法
先说一下linux重定向:0、1和2分别表示标准输入、标准输出和标准错误信息输出,可以用来指定需要重定向的标准输入或输出。
在一般使用时,默认的是标准输出,既1.当我们需要特殊用途时,可以使用其他标号。例如,将某个程序的错误信息输出到log文件中:./program 2>log。这样标准输出还是在屏幕上,但是错误信息会输出到log文件中。
另外,也可以实现0,1,2之间的重定向。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,于是一切静悄悄:-)
由于使用nohup时,会自动将输出写入nohup.out文件中,如果文件很大的话,nohup.out就会不停的增大,这是我们不希望看到的,因此,可以利用/dev/null来解决这个问题。
nohup ./program >/dev/null 2>log.txt &
如果错误信息也不想要的话:
nohup ./program >/dev/null 2>&1 &
那如果想要输出信息到指定的文件中呢:
比如有future这个可执行文件,我想在后台一直运行并且将标准输出写到out.log这个文件中,将错误信息写到error.log中:
nohup ./future 1>out.log 2>error.log &
也可以写作:nohup ./future >out.log 2>error.log & 这个1是默认值,因此可以省略
如果想将错误信息和标准输出都写到out.log这个文件中,可以这样写:
nohup ./future 1>out.log 2>&1 & 最后这个&是说在后台运行的意思 2>&1 是说将错误输出重定向到标准输出中,而标准输出已经指定输出到out.log中了,因此他们都将会写到out.log中
另外一种酷的写法是 nohup ./future &>out.log & 这里的&>out.log就等于 1>out.log 2>&1
那是否可以写成这样呢:
nohup ./future 1>out.log 2>out.log
虽然最终也会生成out.log这个文件,但是由于两条数据(即标准输出与错误输出)可能同时写入交叉写入这个文件,所以里面的数据会错乱掉,无法达到追踪日志的目的了
相关文章推荐
- 动态清空 nohup 输出文件
- php守护进程 加linux命令nohup实现任务每秒执行一次
- Linux后台执行命令
- Shell后台运行
- linux下程序的前、后台切换及让进程不受终端的影响
- python操作mysq-redis脚本及使用nohup或crontab任务后台执行
- 让进程在linux后台可靠运行的几种方法
- Tomcat 开启后会自动退出 nohup实现守护进程
- linux命令后台运行
- linux总结(1)——crontab、nohup、chage
- 脱离终端后台运行 nohup xxx &
- [Linux] Job管理
- weblogic启动报错
- linux命令nohup使用
- Linux命令之后台运行-nohup &
- 使用nohup让程序在远程主机后台运行
- linux下nohup调用函数
- [转]nohup 让程序永远后台执行
- Linux 技巧:让进程在后台可靠运行的几种方法
- linux 的nohup & 和daemon 总结