开发项目采用Dubbo分布式开发基本上都是Linux服务器部署项目,多个项目模块部署需要按照规范进行部署,方便项目管理以及迁移。

项目模块部署规范:
i1. 建立项目部署目录文件夹。通常以项目名为根节点。
这里写图片描述

i2. 二级目录为项目类型名。例如:app、service、timer、web。
i3. 三级目录为子模块项目名。

自定义Dubbo服务维护的Shell脚本。

  • 脚本命名规范:
    /root/edu/service/xxx/service-xxx.sh
    例如:
    /root/edu/service/user/service-user.sh

  • 效果:

# cd /root/edu/service/user
# ./service-user.sh start
# ./service-user.sh stop
# ./service-user.sh restart

以下是自定脚本代码:

#!/bin/sh

## java env
export JAVA_HOME=/root/jdk1.7.0_79
export JRE_HOME=$JAVA_HOME/jre

## service name
APP_NAME=user

SERVICE_DIR=/root/edu/service/$APP_NAME
SERVICE_NAME=edu-service-$APP_NAME
JAR_NAME=$SERVICE_NAME\.jar
PID=$SERVICE_NAME\.pid

cd $SERVICE_DIR

case "$1" in

    start)
        nohup $JRE_HOME/bin/java -Xms256m -Xmx512m -jar $JAR_NAME >/dev/null 2>&1 &
        echo $! > $SERVICE_DIR/$PID
        echo "=== start $SERVICE_NAME"
        ;;

    stop)
        kill `cat $SERVICE_DIR/$PID`
        rm -rf $SERVICE_DIR/$PID
        echo "=== stop $SERVICE_NAME"

        sleep 5
        ##
        ## edu-service-aa.jar
        ## edu-service-aa-bb.jar
        P_ID=`ps -ef | grep -w "$SERVICE_NAME" | grep -v "grep" | awk '{print $2}'`
        if [ "$P_ID" == "" ]; then
            echo "=== $SERVICE_NAME process not exists or stop success"
        else
            echo "=== $SERVICE_NAME process pid is:$P_ID"
            echo "=== begin kill $SERVICE_NAME process, pid is:$P_ID"
            kill -9 $P_ID
        fi
        ;;

    restart)
        $0 stop
        sleep 2
        $0 start
        echo "=== restart $SERVICE_NAME"
        ;;

    *)
        ## restart
        $0 stop
        sleep 2
        $0 start
        ;;

esac
exit 0

注:使用这个批处理文件只需要将修改定义变量路径修改正确既可以使用。
点击下载批处理文件

Logo

更多推荐