linux Shell 脚本 输出日志文件 log /dev/null

linux Shell 脚本 输出日志文件 log

shell 错误输出重定向到标准输出
https://www.jb51.net/article/264888.htm

shell 错误输出重定向到标准输出

和<是文件重定向符。那么1和2是什么?

shell中每个进程都和三个系统文件相关联

标准输入stdin

标准输出stdout

标准错误stderr

三个系统文件的文件描述符分别为0,1和2。

所以这里2>&1的意思就是将标准错误也输出到标准输出当中。

下面通过一个例子来展示2>&1有什么作用:

创建一个 test.sh

内容如下:

c 复制代码
#!/bin/sh
t
date

执行

chmod 777 test.sh

./test.sh

c 复制代码
./test.sh: line 2: t: command not found
Mon Aug 19 10:56:50 CST 2024

test.sh中包含两个命令,其中t是一个不存在的命令,执行会报错,默认情况下,错误会输出到stderr。

date则能正确执行,并且输出时间信息,默认输出到stdout。

标准输出重定向到log文件中,标准错误打印在屏幕上

c 复制代码
 ./test.sh > test1.log

输出结果为

c 复制代码
./test.sh: line 2: t: command not found

文件中的内容为

cat test1.log

c 复制代码
Mon Aug 19 10:58:47 CST 2024

可以看到,date的执行结果被重定向到log文件中了,而t无法执行的错误则只打印在屏幕上。

标准输处和标准错误重定向到同一log文件中

c 复制代码
./test.sh > test2.log 2>&1

cat test2.log

c 复制代码
./test.sh: line 2: t: command not found
Mon Aug 19 11:05:03 CST 2024

这次,stderr和stdout的内容都被重定向到log文件中了。

实际上, >就相当于1>也就是重定向标准输出,不包括标准错误。

通过2>&1,就将标准错误重定向到标准输出了(stderr已作为stdout的副本),

那么再使用>重定向就会将标准输出和标准错误信息一同重定向了。

标准输处和标准错误重定向到不同log文件中

如果只想重定向标准错误到文件中,则可以使用2> file。

c 复制代码
sh test.sh 1>log.log 2>log_err.log

如何将shell脚本的全部执行结果记入一个log文件

c 复制代码
./test.sh >>logfile 2>&1

执行脚本test.sh时将错误输出2以及标准输出1都一起以附加写方式导入logfile文件。

即使多次执行脚本,之前的log也仍然存在。

/dev/null

如果希望执行某个命令,但又不希望在屏幕上显示出输出的结果,那么可以将输出重定向到/dev/null:

c 复制代码
$ command > /dev/null

/dev/null是一个特殊的文件,写入到它的内容都会被丢弃;如果尝试从该文件读取内容,那么什么也读取不到。

但是/dev/null文件非常的有用,将命令的输出重定向到它,会起到"静止输出"的效果。

如果希望屏蔽stdout和stderr,则可以这样写:

c 复制代码
$ command > /dev/null 2>&1

注意:0是标准输入(STDIN),1是标准输出(STDOUT),2是标准错误输出(STDERR)

相关推荐
面向对象World7 分钟前
正点原子Mini Linux 4.3寸800x480触摸屏gt115x驱动
linux·服务器·数据库
chilavert31813 分钟前
技术演进中的开发沉思-368:锁机制(中)
java·开发语言·jvm
~央千澈~26 分钟前
抖音弹幕游戏开发之第12集:添加冷却时间机制·优雅草云桧·卓伊凡
java·服务器·前端
17(无规则自律)27 分钟前
LubanCat 2烧录一个新镜像后开发环境搭建
linux·嵌入式硬件·考研·软件工程
HAPPY酷39 分钟前
C++ 多线程实战三板斧
java·开发语言·c++·技术美术
独自破碎E44 分钟前
BISHI54货物堆放
android·java·开发语言
json{shen:"jing"}1 小时前
分割回文串
java
workflower1 小时前
易用性和人性化需求
java·python·测试用例·需求分析·big data·软件需求
无心水1 小时前
5、微服务快速启航:基于Pig与BladeX构建高可用分布式系统实战
服务器·分布式·后端·spring·微服务·云原生·架构
『往事』&白驹过隙;2 小时前
浅谈PC开发中的设计模式搬迁到ARM开发
linux·c语言·arm开发·设计模式·iot