记录javajar标准输出&;linux中文件的stderr

记录javajar标准输出&;linux中文件的stderr,java,bash,jar,Java,Bash,Jar,我找到了一个可以用于jar文件的脚本。 我的问题是如何修改它以将stdout和stderr记录到文件中 据我所知,这一行应该修改: nohup java -jar $PATH_TO_JAR /tmp 2>> /dev/null >> /dev/null & “/tmp”表示什么/dev/null表示它没有将任何东西定向到任何地方 以下是我正在使用的脚本: #!/bin/sh SERVICE_NAME=MyService PATH_TO_JAR=/usr/loca

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

据我所知,这一行应该修改:

nohup java -jar $PATH_TO_JAR /tmp 2>> /dev/null >> /dev/null &
“/tmp”表示什么/dev/null表示它没有将任何东西定向到任何地方

以下是我正在使用的脚本:

#!/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
我想将所有内容都记录到/var/log/myservice.log文件中。 感谢您的帮助

我找到了这个解决方案:

nohup java -jar $PATH_TO_JAR > /var/log/myservice.log  2>&1 &

当我在服务运行时删除日志文件时,它没有创建新的日志文件,尽管它正在流式传输到stdout。

有几个注释:1)2>&1意味着获取stderr(第二个流)并将其重定向到stdout(第一个流)2)您可能希望执行>>而不是>,以重定向输出(>将覆盖那里的任何日志文件;>>将附加;不确定您的用例是否合适)。3)让您的系统删除旧日志文件并创建新日志文件肯定是一个单独的问题)当您从目录中删除文件时,实际上并没有从磁盘中删除它。任何打开文件的程序都可以使用它。此外,如果文件存在于任何其他目录中,它将继续这样做。顺便说一句,您仍然可以通过查看
/proc/{pid}/fd/1
来访问该文件。我发现这对于运行jar和选择日志文件非常有用-