Linux Mandrivaで自動的にTomcatを実行する - java.io.IOException:無効なパラメータ

Linux Mandrivaで自動的にTomcatを実行する - java.io.IOException:無効なパラメータ

私が使用する自動実行スクリプトは次のとおりです。

#!/bin/sh

    # description: Tomcat start/stop script
    # chkconfig:

    TOMCAT_PATH=/java/apache-tomcat-7.0.32/bin
    TOMCAT_START=$TOMCAT_PATH/startup.sh
    TOMCAT_STOP=$TOMCAT_PATH/shutdown.sh

    start()
    {
    if [ -x ${TOMCAT_START} ]; then
    echo "Starting tomcat server..."
    ${TOMCAT_START} &
    else
    echo "Cannot start tomcat server"
    fi
    }

    stop()
    {
    if [ -x ${TOMCAT_STOP} ]; then
    echo "Stopping tomcat server"
    ${TOMCAT_STOP} &
    else
    echo "Cannot stop tomcat server..."
    fi
    }

    restart()
    {
    stop
    sleep 10
    start
    }

    case "$1" in
    'start')
    start
    ;;
    'stop')
    stop
    ;;
    'restart')
    restart
    ;;
    *)
    echo "Please supply an argument [start|stop|restart]"
    esac

入れました--

/etc/rc.d/init.d/

私はこれを開始に追加しました:

/sbin/chkconfig --add --level 345 tomcat

しかし、システムを再起動したときにログを見てみると、次のようになります。

カトリナアウト:

...
INFO: Stopping service Catalina
jan 03, 2013 6:09:04 PM hudson.util.CharacterEncodingFilter destroy
INFO: CharacterEncodingFilter destroyed.
jan 03, 2013 6:09:04 PM javax.jmdns.impl.tasks.state.DNSStateTask run
WARNING: Canceler(www-...-ru.local.).run() exception 
java.io.IOException: Invalid argument
    at java.net.PlainDatagramSocketImpl.send(Native Method)
    at java.net.DatagramSocket.send(DatagramSocket.java:676)
    at javax.jmdns.impl.JmDNSImpl.send(JmDNSImpl.java:1537)
    at javax.jmdns.impl.tasks.state.DNSStateTask.run(DNSStateTask.java:131)
    at java.util.TimerThread.mainLoop(Timer.java:555)
    at java.util.TimerThread.run(Timer.java:505)

プロセスは開始されません。

しかし、コマンドを実行すると -

/etc/rc.d/init.d/tomcat start

プロセスは順調に始まりました。

なぜ自動的に起動しないのですか?

ありがとうございます!

答え1

一部のシェルスクリプトを変更しました。

#!/bin/sh
#
# Startup script for Tomcat
#

JAVA_HOME="/usr/java/jdk1.7.0_09" ;
JRE_HOME=/usr/java/jdk1.7.0_09/jre;
CATALINA_HOME=/java/tomcat-7.0.27;
export JAVA_HOME && export JRE_HOME &&$CATALINA_HOME/bin/startup.sh &&$CATALINA_HOME/bin/shutdown.sh

case "$1" in
start)
echo -n "Starting Tomcat"
su - tomcat -c $CATALINA_HOME/bin/startup.sh
;;
stop)
echo -n "Stopping Tomcat"
su - tomcat -c $CATALINA_HOME/bin/shutdown.sh
;;
restart)
$0 stop
$0 start
;;
*)
echo "Usage: $0 {start|stop|restart}"
exit 1
esac

exit 0

それから入れて

/etc/rc.d/init.d

実行権限を追加:

# chmod +x /etc/init.d/ tomcat

追加されたシンボリックリンク:

ln -s /etc/init.d/tomcat /etc/rc0.d/K91tomcat
ln -s /etc/init.d/tomcat /etc/rc1.d/K91tomcat
ln -s /etc/init.d/tomcat /etc/rc2.d/S91tomcat
ln -s /etc/init.d/tomcat /etc/rc3.d/S91tomcat
ln -s /etc/init.d/tomcat /etc/rc4.d/S91tomcat
ln -s /etc/init.d/tomcat /etc/rc5.d/S91tomcat
ln -s /etc/init.d/tomcat /etc/rc6.d/K91tomcat

今、すべてが大丈夫です。

reboot;

カトリナアウト:

...
INFO: Server startup in 113947 ms

ありがとうございます!

関連情報