2016-03-02 69 views
0

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

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

它确认其他参数,如果错误或遗漏,JSVC IS会安装。

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

脚本:

#!/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 ..."); 
    } 
} 

回答

0

好吧,我想我犯了一个错误设置了所有的常量。

的代码是在此基础上Q/A: How to convert a java program to daemon with jsvc?

它开始工作之后,我删除了等待参数和扩大在类参数满级/包路径。

错误和输出文件正在工作,它们必须已被我之前做的事情修复..我想。

相关问题