Linux中 nohup运行jar包出现nohup: redirecting stderr to stdout解决办法
Linux中各种命令对于小白来说实在是太多了 = =。
异常场景
学习过程中,准备将一个jar包部署在linux上面,直接使用了传统的java -jar xxxxx.jar
这种命令。刷刷刷日志出来,一切都没有什么问题。但是当我关闭Linux窗口之后或者按Ctrl C关闭应用应用就会被打断,这样肯定不是我们想要的。找到一些能让java程序后台运行的命令:
-
java -jar xxx.jar &
& 表示后台运行,ssh窗口不被锁定,但是关闭窗口时,程序还是会退出 -
nohup java -jar xxx.jar &
nohup 表示不挂断运行命令行,当账号退出或关闭终端时,程序仍然运行
当用 nohup 命令执行作业时,该作业的所有输出被重定向到nohup.out的文件中,除非另外指定了输出文件。 -
nohup java -jar xxx.jar >/usr/local/temp.txt &
> /usr/local/temp.txt 表示将所有启动的日志信息记录到temp.txt文件中
问题来了:当我使用第三种方法
nohup java -jar spring-chat-0.0.1-SNAPSHOT.jar >temp.text &
的时候就抛出了nohup: redirecting stderr to stdout
异常
网上搜了半天,据说好象可以把后面的 “&” 改成 “2>&1 &”,于是把启动命令改成如下:
nohup java -jar spring-chat-0.0.1-SNAPSHOT.jar >temp.text 2>&1 &
回车后,会自动输出这个jar包运行的pid,可以根据这个数据kill它
翻译一下:
- 2> 表示把标准错误重定向
- &1 表示标准输出
- &2 表示标准错误
附加几条Linux命令
- 可通过ps -ef |grep java命令查看包含“java”的所有进程
ps -ef |grep java
如图所示,可以根据pid杀死相关进程
2. 杀死进程命令 kill -9 xxx(pid)
kill -9 27351