22.dubbo脚本之start.sh

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了22.dubbo脚本之start.sh相关的知识,希望对你有一定的参考价值。

#!/bin/bash

cd `dirname $0`

BIN_DIR=`pwd`

cd ..

DEPLOY_DIR=`pwd`

CONF_DIR=$DEPLOY_DIR/conf


SERVER_NAME=`sed ‘/dubbo.application.name/!d;s/.*=//‘ conf/dubbo.properties | tr -d ‘\r‘`

SERVER_PROTOCOL=`sed ‘/dubbo.protocol.name/!d;s/.*=//‘ conf/dubbo.properties | tr -d ‘\r‘`

SERVER_PORT=`sed ‘/dubbo.protocol.port/!d;s/.*=//‘ conf/dubbo.properties | tr -d ‘\r‘`

LOGS_FILE=`sed ‘/dubbo.log4j.file/!d;s/.*=//‘ conf/dubbo.properties | tr -d ‘\r‘`


if [ -z "$SERVER_NAME" ]; then

    SERVER_NAME=`hostname`

fi


PIDS=`ps -f | grep java | grep "$CONF_DIR" |awk ‘{print $2}‘`

if [ -n "$PIDS" ]; then

    echo "ERROR: The $SERVER_NAME already started!"

    echo "PID: $PIDS"

    exit 1

fi


if [ -n "$SERVER_PORT" ]; then

    SERVER_PORT_COUNT=`netstat -tln | grep $SERVER_PORT | wc -l`

    if [ $SERVER_PORT_COUNT -gt 0 ]; then

        echo "ERROR: The $SERVER_NAME port $SERVER_PORT already used!"

        exit 1

    fi

fi


LOGS_DIR=""

if [ -n "$LOGS_FILE" ]; then

    LOGS_DIR=`dirname $LOGS_FILE`

else

    LOGS_DIR=$DEPLOY_DIR/logs

fi

if [ ! -d $LOGS_DIR ]; then

    mkdir $LOGS_DIR

fi

STDOUT_FILE=$LOGS_DIR/stdout.log


LIB_DIR=$DEPLOY_DIR/lib

LIB_JARS=`ls $LIB_DIR|grep .jar|awk ‘{print "‘$LIB_DIR‘/"$0}‘|tr "\n" ":"`


JAVA_OPTS=" -Djava.awt.headless=true -Djava.net.preferIPv4Stack=true "

JAVA_DEBUG_OPTS=""

if [ "$1" = "debug" ]; then

    JAVA_DEBUG_OPTS=" -Xdebug -Xnoagent -Djava.compiler=NONE -Xrunjdwp:transport=dt_socket,address=8000,server=y,suspend=n "

fi

JAVA_JMX_OPTS=""

if [ "$1" = "jmx" ]; then

    JAVA_JMX_OPTS=" -Dcom.sun.management.jmxremote.port=1099 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false "

fi

JAVA_MEM_OPTS=""

BITS=`java -version 2>&1 | grep -i 64-bit`

if [ -n "$BITS" ]; then

    JAVA_MEM_OPTS=" -server -Xmx2g -Xms2g -Xmn256m -XX:PermSize=128m -Xss256k -XX:+DisableExplicitGC -XX:+UseConcMarkSweepGC -XX:+CMSParallelRemarkEnabled -XX:+UseCMSCompactAtFullCollection -XX:LargePageSizeInBytes=128m -XX:+UseFastAccessorMethods -XX:+UseCMSInitiatingOccupancyOnly -XX:CMSInitiatingOccupancyFraction=70 "

else

    JAVA_MEM_OPTS=" -server -Xms1g -Xmx1g -XX:PermSize=128m -XX:SurvivorRatio=2 -XX:+UseParallelGC "

fi


echo -e "Starting the $SERVER_NAME ...\c"

nohup java $JAVA_OPTS $JAVA_MEM_OPTS $JAVA_DEBUG_OPTS $JAVA_JMX_OPTS -classpath $CONF_DIR:$LIB_JARS com.alibaba.dubbo.container.Main > $STDOUT_FILE 2>&1 &


COUNT=0

while [ $COUNT -lt 1 ]; do    

    echo -e ".\c"

    sleep 1 

    if [ -n "$SERVER_PORT" ]; then

        if [ "$SERVER_PROTOCOL" == "dubbo" ]; then

       COUNT=`echo status | nc -i 1 127.0.0.1 $SERVER_PORT | grep -c OK`

        else

            COUNT=`netstat -an | grep $SERVER_PORT | wc -l`

        fi

    else

    COUNT=`ps -f | grep java | grep "$DEPLOY_DIR" | awk ‘{print $2}‘ | wc -l`

    fi

    if [ $COUNT -gt 0 ]; then

        break

    fi

done


echo "OK!"

PIDS=`ps -f | grep java | grep "$DEPLOY_DIR" | awk ‘{print $2}‘`

echo "PID: $PIDS"

echo "STDOUT: $STDOUT_FILE"


本文出自 “8159085” 博客,请务必保留此出处http://8169085.blog.51cto.com/8159085/1794997

以上是关于22.dubbo脚本之start.sh的主要内容,如果未能解决你的问题,请参考以下文章

Flink1.15源码解析--启动脚本----start-cluster.sh

sos-ci start-ci.sh脚本分析

java程序启停脚本run.sh

crontab中执行java程序的脚本

linux下java程序的start.sh启动脚本中classpath中载入了好多jar包,脚本启动后进程名特别长,不方便查看

hadoop启动脚本分析及常见命令