JSVC没有启动,我没有收到任何错误消息

时间:2016-03-02 07:46:55

标签: java linux jsvc

我正在尝试运行一个简单的JSVC程序。但是,当我运行脚本时它不会启动。 我也没有在日志文件,终端或我能找到的任何系统日志中收到任何错误。

JSVC似乎没有验证类路径,因为如果我故意使它们无效我 仍然没有得到关于它的错误。

如果安装了JSVC IS,它会验证它会报错的其他参数。

Java home也应该是正确的,因为它之前抱怨过。

脚本:

#!/bin/sh

# Setup variables
EXEC=/usr/bin/jsvc
JAVA_HOME=/usr/lib/jvm/default-java
CLASS_PATH="/usr/share/java/commons-daemon.jar":"/home/xxxuserxxx/Desktop/Tutorials/StackOverflow_version/EchoTest.jar"
CLASS=Main
USER=xxxuserxxx
PID=/tmp/example.pid
LOG_OUT=/tmp/example.out
LOG_ERR=/tmp/example.err

do_exec()
{
    $EXEC -home "$JAVA_HOME" -cp $CLASS_PATH -user $USER -outfile $LOG_OUT -errfile $LOG_ERR -pidfile $PID $1 -wait 20 $CLASS
}

case "$1" in
    start)
        do_exec
            ;;
    stop)
        do_exec "-stop"
            ;;
    restart)
        if [ -f "$PID" ]; then
            do_exec "-stop"
            do_exec
        else
            echo "service not running, will do nothing"
            exit 1
        fi
            ;;
    *)
            echo "usage: daemon {start|stop|restart}" >&2
            exit 3
            ;;
esac

代码:

import java.util.Timer;
import org.apache.commons.daemon.*;

public class Main implements Daemon {


private static Timer timer = null;

public static void main(String[] args) {
    System.out.println("Hello");
    timer = new Timer();
    timer.schedule(new EchoTask(), 0, 1000);
}

@Override
public void init(DaemonContext dc) throws DaemonInitException, Exception {
    System.out.println("initializing ...");
}

@Override
public void start() throws Exception {
    System.out.println("starting ...");
    main(null);
}

@Override
public void stop() throws Exception {
    System.out.println("stopping ...");
    if (timer != null) {
        timer.cancel();
    }
}

@Override
public void destroy() {
    System.out.println("done.");
}

}

import java.util.Date;
import java.util.TimerTask;

public class EchoTask extends TimerTask {
    @Override
    public void run() {
        System.out.println(new Date() + " running ...");
    }
}

1 个答案:

答案 0 :(得分:0)

好的,我认为设置所有常量时出错了。

代码基于此Q / A: How to convert a java program to daemon with jsvc?

我删除了wait参数并在class参数中扩展了完整的类/包路径后开始工作。

错误和输出文件正在运行,它们必须由我之前做过的事情修复过......我想。