将Java jar stdout和stderr记录到Linux中的文件

lka*_*las 5 java bash jar

我找到了可以用于jar文件的脚本。我的问题是如何修改它以将stdout和stderr记录到文件中。

据我了解,这一行应该修改:

nohup java -jar $PATH_TO_JAR /tmp 2>> /dev/null >> /dev/null &
Run Code Online (Sandbox Code Playgroud)

什么是“/ tmp目录”说明什么?/ dev / null表示它没有将anuting定向到任何地方?

这是我正在使用的脚本:

#!/bin/sh
SERVICE_NAME=MyService
PATH_TO_JAR=/usr/local/MyProject/MyJar.jar
PID_PATH_NAME=/tmp/MyService-pid
case $1 in
    start)
        echo "Starting $SERVICE_NAME ..."
        if [ ! -f $PID_PATH_NAME ]; then
            nohup java -jar $PATH_TO_JAR /tmp 2>> /dev/null >> /dev/null &
                        echo $! > $PID_PATH_NAME
            echo "$SERVICE_NAME started ..."
        else
            echo "$SERVICE_NAME is already running ..."
        fi
    ;;
    stop)
        if [ -f $PID_PATH_NAME ]; then
            PID=$(cat $PID_PATH_NAME);
            echo "$SERVICE_NAME stoping ..."
            kill $PID;
            echo "$SERVICE_NAME stopped ..."
            rm $PID_PATH_NAME
        else
            echo "$SERVICE_NAME is not running ..."
        fi
    ;;
    restart)
        if [ -f $PID_PATH_NAME ]; then
            PID=$(cat $PID_PATH_NAME);
            echo "$SERVICE_NAME stopping ...";
            kill $PID;
            echo "$SERVICE_NAME stopped ...";
            rm $PID_PATH_NAME
            echo "$SERVICE_NAME starting ..."
            nohup java -jar $PATH_TO_JAR /tmp 2>> /dev/null >> /dev/null &
                        echo $! > $PID_PATH_NAME
            echo "$SERVICE_NAME started ..."
        else
            echo "$SERVICE_NAME is not running ..."
        fi
    ;;
esac
Run Code Online (Sandbox Code Playgroud)

我想将所有内容记录到/var/log/myservice.log文件中。任何帮助表示赞赏!

lka*_*las 5

我找到了这个解决方案:

nohup java -jar $PATH_TO_JAR > /var/log/myservice.log  2>&1 &
Run Code Online (Sandbox Code Playgroud)

当我在 servce 运行时删除日志文件时,它并没有创建一个新文件,尽管它正在流式传输到标准输出。

  • 一些评论:1) 2>&1 表示采用 stderr(这是第二个流)并将其重定向到 stdout(这是第一个流) 2)您可能想要做 >> 而不是 > 来重定向输出(> 将覆盖那里的任何日志文件;>> 将追加;不确定您的用例中哪个是合适的)。3)让您的系统删除旧日志文件并创建一个新文件绝对是一个单独的问题) (2认同)