X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fdistribution%2Fopendaylight%2Fsrc%2Fmain%2Fresources%2Frun.sh;h=6caf3e3f57c55aa0f3c2d88f70e43dde7de355b8;hb=b45957ba3b729ca2c406c893d3db24f5f6363df1;hp=74cadaed38fecdf81a82581e7a4589e7361f7a33;hpb=42210c03b0a4c54706320ba9f55794c0abd4d201;p=controller.git diff --git a/opendaylight/distribution/opendaylight/src/main/resources/run.sh b/opendaylight/distribution/opendaylight/src/main/resources/run.sh index 74cadaed38..6caf3e3f57 100755 --- a/opendaylight/distribution/opendaylight/src/main/resources/run.sh +++ b/opendaylight/distribution/opendaylight/src/main/resources/run.sh @@ -1,9 +1,5 @@ #!/bin/bash -[[ -z ${JAVA_HOME} ]] && echo "Need to set JAVA_HOME environment variable" && exit -1; -[[ ! -x ${JAVA_HOME}/bin/java ]] && echo "Cannot find an executable \ -JVM at path ${JAVA_HOME}/bin/java check your JAVA_HOME" && exit -1; - platform='unknown' unamestr=`uname` if [[ "$unamestr" == 'Linux' ]]; then @@ -32,10 +28,101 @@ elif [[ $platform == 'osx' ]]; then PHYS_DIR=`pwd -P` RESULT=$PHYS_DIR/$TARGET_FILE fullpath=$RESULT + + [[ -z ${JAVA_HOME} ]] && [[ -x "/usr/libexec/java_home" ]] && export JAVA_HOME=`/usr/libexec/java_home -v 1.7`; + fi +[[ -z ${JAVA_HOME} ]] && echo "Need to set JAVA_HOME environment variable" && exit -1; +[[ ! -x ${JAVA_HOME}/bin/java ]] && echo "Cannot find an executable \ +JVM at path ${JAVA_HOME}/bin/java check your JAVA_HOME" && exit -1; + basedir=`dirname ${fullpath}` +function usage { + echo "Usage: $0 [-jmx] [-jmxport ] [-debug] [-debugsuspend] [-debugport ] [-start []] [-stop] [-status] [-console] [-help] []" + exit 1 +} + +if [ -z ${TMP} ]; then + pidfile="/tmp/opendaylight.PID" +else + pidfile="${TMP}/opendaylight.PID" +fi +debug=0 +debugsuspend=0 +debugport=8000 +debugportread="" +startdaemon=0 +daemonport=2400 +daemonportread="" +jmxport=1088 +jmxportread="" +startjmx=0 +stopdaemon=0 +statusdaemon=0 +consolestart=1 +dohelp=0 +extraJVMOpts="" +unknown_option=0 +while true ; do + case "$1" in + -debug) debug=1; shift ;; + -jmx) startjmx=1; shift ;; + -debugsuspend) debugsuspend=1; shift ;; + -debugport) shift; debugportread="$1"; if [[ "${debugportread}" =~ ^[0-9]+$ ]] ; then debugport=${debugportread}; shift; else echo "-debugport expects a number but was not found"; exit -1; fi;; + -jmxport) shift; jmxportread="$1"; if [[ "${jmxportread}" =~ ^[0-9]+$ ]] ; then jmxport=${jmxportread}; shift; else echo "-jmxport expects a number but was not found"; exit -1; fi;; + -start) startdaemon=1; shift; daemonportread="$1"; if [[ "${daemonportread}" =~ ^[0-9]+$ ]] ; then daemonport=${daemonportread}; shift; fi;; + -stop) stopdaemon=1; shift ;; + -status) statusdaemon=1; shift ;; + -console) shift ;; + -help) dohelp=1; shift;; + -D*) extraJVMOpts="${extraJVMOpts} $1"; shift;; + -X*) extraJVMOpts="${extraJVMOpts} $1"; shift;; + "") break ;; + *) echo "Unknown option $1"; unknown_option=1; shift ;; + esac +done + +# Unknown Options and help +if [ "${unknown_option}" -eq 1 ]; then + usage +fi + +if [ "${dohelp}" -eq 1 ]; then + usage +fi + +# Validate debug port +if [[ "${debugport}" -lt 1024 ]] || [[ "${debugport}" -gt 65535 ]]; then + echo "Debug Port not in the range [1024,65535] ${debugport}" + exit -1 +fi + +# Validate daemon console port +if [[ "${daemonport}" -lt 1024 ]] || [[ "${daemonport}" -gt 65535 ]]; then + echo "Daemon console Port not in the range [1024,65535] value is ${daemonport}" + exit -1 +fi + +# Validate jmx port +if [[ "${jmxport}" -lt 1024 ]] || [[ "${jmxport}" -gt 65535 ]]; then + echo "JMX Port not in the range [1024,65535] value is ${jmxport}" + exit -1 +fi + +# Debug options +if [ "${debugsuspend}" -eq 1 ]; then + extraJVMOpts="${extraJVMOpts} -Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=${debugport}" +elif [ "${debug}" -eq 1 ]; then + extraJVMOpts="${extraJVMOpts} -Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=${debugport}" +fi + +# Add JMX support +if [ "${startjmx}" -eq 1 ]; then + extraJVMOpts="${extraJVMOpts} -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.port=${jmxport} -Dcom.sun.management.jmxremote" +fi + ######################################## # Now add to classpath the OSGi JAR ######################################## @@ -58,13 +145,68 @@ FWCLASSPATH=${FWCLASSPATH},file:${basedir}/lib/org.eclipse.virgo.kernel.equinox. CLASSPATH=${CLASSPATH}:${basedir}/lib/org.eclipse.equinox.launcher-1.3.0.v20120522-1813.jar FWCLASSPATH=${FWCLASSPATH},file:${basedir}/lib/org.eclipse.equinox.launcher-1.3.0.v20120522-1813.jar -$JAVA_HOME/bin/java $@ \ - -Djava.io.tmpdir=${basedir}/work/tmp \ - -Dosgi.install.area=${basedir} \ - -Dosgi.configuration.area=${basedir}/configuration \ - -Dosgi.frameworkClassPath=${FWCLASSPATH} \ - -Dosgi.framework=file:${basedir}/lib/org.eclipse.osgi-3.8.1.v20120830-144521.jar \ - -classpath ${CLASSPATH} \ - org.eclipse.equinox.launcher.Main \ - -console \ - -consoleLog +if [ "${stopdaemon}" -eq 1 ]; then + if [ -e "${pidfile}" ]; then + daemonpid=`cat "${pidfile}"` + kill "${daemonpid}" + rm -f "${pidfile}" + echo "Controller with PID: ${daemonpid} -- Stopped!" + exit 0 + else + echo "Doesn't seem any Controller daemon is currently running" + exit -1 + fi +fi + +if [ "${statusdaemon}" -eq 1 ]; then + if [ -e "${pidfile}" ]; then + daemonpid=`cat "${pidfile}"` + ps -p ${daemonpid} > /dev/null + daemonexists=$? + if [ "${daemonexists}" -eq 0 ]; then + echo "Controller with PID: ${daemonpid} -- Running!" + exit 0 + else + echo "Controller with PID: ${daemonpid} -- Doesn't seem to exist" + rm -f "${pidfile}" + exit 0 + fi + else + echo "Doesn't seem any Controller daemon is currently running, at least no PID file has been found" + exit -1 + fi +fi + +if [ "${startdaemon}" -eq 1 ]; then + if [ -e "${pidfile}" ]; then + echo "Another instance of controller running, check with $0 -status" + exit -1 + fi + $JAVA_HOME/bin/java ${extraJVMOpts} \ + -Djava.io.tmpdir=${basedir}/work/tmp \ + -Dosgi.install.area=${basedir} \ + -Dosgi.configuration.area=${basedir}/configuration \ + -Dosgi.frameworkClassPath=${FWCLASSPATH} \ + -Dosgi.framework=file:${basedir}/lib/org.eclipse.osgi-3.8.1.v20120830-144521.jar \ + -classpath ${CLASSPATH} \ + org.eclipse.equinox.launcher.Main \ + -console ${daemonport} \ + -consoleLog & + daemonpid=$! + echo ${daemonpid} > ${pidfile} +elif [ "${consolestart}" -eq 1 ]; then + if [ -e "${pidfile}" ]; then + echo "Another instance of controller running, check with $0 -status" + exit -1 + fi + $JAVA_HOME/bin/java ${extraJVMOpts} \ + -Djava.io.tmpdir=${basedir}/work/tmp \ + -Dosgi.install.area=${basedir} \ + -Dosgi.configuration.area=${basedir}/configuration \ + -Dosgi.frameworkClassPath=${FWCLASSPATH} \ + -Dosgi.framework=file:${basedir}/lib/org.eclipse.osgi-3.8.1.v20120830-144521.jar \ + -classpath ${CLASSPATH} \ + org.eclipse.equinox.launcher.Main \ + -console \ + -consoleLog +fi