Ошибка при запуске класса Daemon в Java? - PullRequest
1 голос
/ 10 октября 2011

Я пытаюсь создать класс Daemon в Java, поэтому я реализовал класс, который реализует Daemon, но когда я его запускаю, я всегда получаю ошибки.

Класс, который я использую для этого;

public class RemoteAgentDaemon implements Daemon {
    private Logger logger;
    public LocalAgent frame;

    public void destroy() {
        logger.info("Server was destroyed ....");
    }

    public void init(DaemonContext arg0) throws Exception {
        frame = new LocalAgent();
        logger = Logger.getLogger("daemon");
        logger.addAppender(new ConsoleAppender(new PatternLayout("%d{DATE} [%t] %5p - %m%n")));
        logger.setLevel(Level.ALL);
    }

    public void start() throws Exception {
        logger.info("Server was started ....");
        frame.listenSocket();
    }

    public void stop() throws Exception {
        logger.info("Server was stoped ....");
    }
}

И сценарий, который я использую для запуска демона:

#!/bin/sh

# Setup variables
EXEC=/usr/bin/jsvc
JAVA_HOME=/usr/lib/jvm/java-6-sun
CLASS_PATH="/usr/share/java/commons-daemon.jar":"/home/mehmet/Desktop/remoteAgent.jar"
CLASS=example.Main
USER=foo
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 $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

Когда я запускаю скрипт, я получаю эту ошибку;

java.lang.NoClassDefFoundError: org/apache/log4j/Layout
at java.lang.Class.getDeclaredMethods0(Native Method)
at java.lang.Class.privateGetDeclaredMethods(Class.java:2444)
at java.lang.Class.getMethod0(Class.java:2687)
at java.lang.Class.getMethod(Class.java:1620)
at org.apache.commons.daemon.support.DaemonLoader.load(DaemonLoader.java:129)
    Caused by: java.lang.ClassNotFoundException: org.apache.log4j.Layout
at java.net.URLClassLoader$1.run(URLClassLoader.java:217)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:205)
at java.lang.ClassLoader.loadClass(ClassLoader.java:321)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:294)
at java.lang.ClassLoader.loadClass(ClassLoader.java:266)
... 5 more
    Cannot load daemon
    Service exit with a return value of 3

Не могли бы вы помочь мне решить эту проблему?

Спасибо всем

РЕДАКТИРОВАТЬ:

теперь я изменил свой путь к классу;

CLASS_PATH = "/ главная / Mehmet / Desktop / апач-log4j-1.2.16": "/ главная / Mehmet / Desktop / remoteAgent.jar"

но теперь я получил ошибку;

Не удалось найти загрузчик демона org / apache / commons / daemon / support / DaemonLoader Service выход со значением возврата 1

Ответы [ 2 ]

2 голосов
/ 10 октября 2011
java.lang.NoClassDefFoundError: org/apache/log4j/Layout

Вышеприведенное указывает на то, что вы должны добавить log4j к вашему classpath (отредактируйте CLASS_PATH в сценарии с расположением вашего jar log4j)

0 голосов
/ 10 октября 2011

ты скучаешь по log4j.jar.У commons.daemon есть зависимость.

...