java启动脚本报错:nohup: redirecting stderr to stdout

以你之姓@ 2024-03-26 12:19 183阅读 0赞

一、问题现象

java项目启动脚本start.sh如下:

  1. nohup java -jar xxx.jar >xxx.txt &

执行报错:

nohup: redirecting stderr to stdout

二、解决方案

将命令改成:

  1. nohup java -jar xxx.jar >xxx.txt 2>&1 &

三、命令说明

一个命令的执行伴随着三种输入输出

标准输入(stdin):默认指向键盘的输入,可以通过标准输入重定向<,让标准输入指向文件输入

标准输出(stdout) :指命令产生的正常的输出,如echo aaa,标准输出默认指向终端显示器,可以通过输出重定向>,让标准输出重定向到文件

标准错误输出(stderr):指命令产生的错误信息的输出,如执行了不存在的命令,标准错误输出也默认指向终端显示器,同样可以通过输出重定向>,让标准错误输出重定向到文件。

所谓的输出重定向到文件,是指把默认输出到终端显示器的信息写入到指定文件

标准输入,标准输出,标准错误输出的文件描述符分别时0,1,2。

“>” 表示输出重定向

“2>&1”是指把标准错误输出重定向到标准输出的引用,即也重定向到file

例子:

  1. #标准错误输出重定向到log
  2. sh xxx.sh 2> log
  3. #标准输出重定向到log1,标准错误输出重定向到log2
  4. sh xxx.sh >log1 2>log2
  5. #标准输出重定向到文件log,标准错误输出重定向到标准输出的引用
  6. sh xxx.sh >log 2>&1
  7. #标准错误输出重定向到文件testlog,标准输出和重定向到标准错误输出的引用
  8. sh xxx.sh 2>log 1>&2
  9. #标准输出重定向到log文件,标准错误输出也重定向到log文件
  10. sh xxx.sh 1>log 2>log

四、补充说明:

command>a 2>a 与 command>a 2>&1的区别

command 1>a 2>&1 只打开一次文件a,IO效率更高。

command 1>a 2>a 打开文件两次,导致stdout被stderr覆盖,可能导致某些输出错误。IO效率较低。

&1的含义就可以理解为用标准输出的引用,引用的就是重定向标准输出产生打开的a。

发表评论

表情:
评论列表 (有 0 条评论,183人围观)

还没有评论,来说两句吧...

相关阅读

    相关 shell本报后退出执行

    在做devops或者持续集成、持续交付时,有时候会写shell脚本。 但是在shell脚本顺序执行过程中,可能会有中间环节会出错报错,此时仍然会继续往下执行。 那如何避免此