linux部署dubbo服务可执行Jar和启动批处理命令编写

来源:互联网 发布:淘宝衣服搭配在哪里 编辑:程序博客网 时间:2024/06/06 16:27

开发项目采用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 envexport JAVA_HOME=/root/jdk1.7.0_79export JRE_HOME=$JAVA_HOME/jre## service nameAPP_NAME=userSERVICE_DIR=/root/edu/service/$APP_NAMESERVICE_NAME=edu-service-$APP_NAMEJAR_NAME=$SERVICE_NAME\.jarPID=$SERVICE_NAME\.pidcd $SERVICE_DIRcase "$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        ;;esacexit 0

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

0 0
原创粉丝点击