【问题标题】:Logging java jar stdout & stderr to a file in linux将java jar stdout和stderr记录到linux中的文件
【发布时间】:2015-12-15 22:44:49
【问题描述】:

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

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

nohup java -jar $PATH_TO_JAR /tmp 2>> /dev/null >> /dev/null &

"/tmp" 表示什么? /dev/null 表示它没有将anuthing定向到任何地方?

这是我正在使用的脚本:

#!/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 文件中。 任何帮助表示赞赏!

【问题讨论】:

标签: java bash jar


【解决方案1】:

我找到了这个解决方案:

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

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

【讨论】:

  • 几个 cmets: 1) 2>&1 表示采用 stderr (这是第二个流)并将其重定向到 stdout (这是第一个) 2)您可能想要做 >> 而不是> 用于重定向输出(> 将覆盖那里的任何日志文件;>> 将追加;不确定您的用例是否合适)。 3)让您的系统删除旧的日志文件并创建一个新的绝对是一个单独的问题)
  • 从目录中删除文件时,实际上并没有从磁盘中删除它。任何打开文件的程序仍然可以使用它。此外,如果该文件存在于任何其他目录中,它将继续这样做。顺便说一句,您仍然可以通过查看/proc/{pid}/fd/1 来访问该文件吗
猜你喜欢
  • 2013-06-09
  • 1970-01-01
  • 2014-07-14
  • 2014-07-22
  • 1970-01-01
  • 1970-01-01
  • 2011-08-10
  • 1970-01-01
  • 2016-02-19
相关资源
最近更新 更多