#这个要有不能再多了

#!/bin/bash

#进入脚本所在的目录

cd `dirname $0`

#为BIN_DIR赋值为当前路径

BIN_DIR=`pwd`

#退到上一级目录

cd ..

#为DEPLOY_DIR赋值当前路径,也就是部署的包所在目录,官方建议的项目部署规范参照官网

DEPLOY_DIR=`pwd`

#为CONF_DIR赋值

CONF_DIR=$DEPLOY_DIR/conf

#取配置文件dubbo.properties中dubbo.application.name配置的值并赋值给SERVER_NAME

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

#取配置文件dubbo.properties中dubbo.protocol.name配置的值并赋给SERVER_PROTOCOL

SERVER_PROTOCOL=`sed '/dubbo.protocol.name/!d;s/.*=//' conf/dubbo.properties | tr -d '\r'`
#取配置文件dubbo.properties中dubbo.protocol.port配置的值并赋给SERVER_PORT

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'`

#检验SERVER_NAME是否有值,长度为0时为真

if [ -z "$SERVER_NAME" ]; then

  #如果SERVER_NAME长度为0,则重新设置为主机名

    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

#如果SERVER_PORT有值

if [ -n "$SERVER_PORT" ]; then

    #获取此端口号在运行的数量ps:这种说法挺扯淡,其实就是有没有

    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目录

LIB_DIR=$DEPLOY_DIR/lib

#部署项目的JARS

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

#运行jar所需的参数配置信息

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"

#后台运行JAR

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 &


#COUNTWhile确定项目是否启动成功

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"