Linux标准输出重定向及标准错误重定向

你可能遇到了如下问题:

[root@localhost shell]# ls -l badfile > error.log
ls: 无法访问badfile: 没有那个文件或目录
[root@localhost shell]# cat error.log

当命令生成错误消息时,shell并未将错误消息重定向到输出重定向文件。shell创建了输出重
定向文件,但错误消息却显示在了显示器屏幕上。注意,在显示test3文件的内容时并没有任何错
误。test3文件创建成功了,只是里面是空的。

在项目中,我们经常需要查看日志文件的错误信息,来进行排查问题,也就是说,我们需要解决如何把错误信息保存到文件中,而不是默认显示在显示器上。

只重定向错误

STDERR文件描述符为2,我们可以在重定向符号前加上2,如下:
[root@localhost shell]# ls -l badfile 2> nginx.log
[root@localhost shell]# cat nginx.log 
ls: 无法访问badfile: 没有那个文件或目录

为什么说如上只是重定向错误呢,为了证明,我们列出一个已存在加不存在的文件

[root@localhost shell]# ls
error.log  hello.txt  nginx.log  test.sh
[root@localhost shell]# ls -l hello.txt badfile 2> apache.log
-rw-r--r-- 1 root root 36 1月  11 08:48 hello.txt
[root@localhost shell]# cat apache.log 
ls: 无法访问badfile: 没有那个文件或目录

可以看到,hello.txt信息并没有存储到apache.log文件中,而是显示到了显示器中,apache.log文件只是存

Rebuild started: Project: Project *** Using Compiler 'V6.22', folder: 'E:\Keil_v5\ARM\ARMCLANG\Bin' Rebuild target 'Target 1' assembling startup_stm32f10x_md.s... Start/core_cm3.c(445): error: non-ASM statement in naked function is not supported 445 | uint32_t result=0; | ^ Start/core_cm3.c(442): note: attribute is here 442 | uint32_t __get_PSP(void) __attribute__( ( naked ) ); | ^ Start/core_cm3.c(465): error: parameter references not allowed in naked functions 465 | "BX lr \n\t" : : "r" (topOfProcStack) ); | ^ Start/core_cm3.c(461): note: attribute is here 461 | void __set_PSP(uint32_t topOfProcStack) __attribute__( ( naked ) ); | ^ Start/core_cm3.c(479): error: non-ASM statement in naked function is not supported 479 | uint32_t result=0; | ^ Start/core_cm3.c(476): note: attribute is here 476 | uint32_t __get_MSP(void) __attribute__( ( naked ) ); | ^ Start/core_cm3.c(499): error: parameter references not allowed in naked functions 499 | "BX lr \n\t" : : "r" (topOfMainStack) ); | ^ Start/core_cm3.c(495): note: attribute is here 495 | void __set_MSP(uint32_t topOfMainStack) __attribute__( ( naked ) ); | ^ 4 errors generated. compiling core_cm3.c... compiling misc.c... compiling system_stm32f10x.c... compiling stm32f10x_adc.c... compiling stm32f10x_dac.c... compiling stm32f10x_exti.c... compiling stm32f10x_dbgmcu.c... compiling stm32f10x_dma.c... compiling stm32f10x_crc.c... compiling stm32f10x_cec.c... compiling stm32f10x_bkp.c... compiling stm32f10x_can.c... compiling stm32f10x_flash.c... compiling stm32f10x_pwr.c... compiling stm32f10x_fsmc.c... compiling stm32f10x_
03-31
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

黄宝康

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值