• 技术文章 >类库下载 >java类库

    java项目的部署脚本

    高洛峰高洛峰2016-10-14 13:40:40原创1422

    1、项目目录结构

      按照maven的规范,一般java的脚本会放在:src-->main-->scripts目录下面。

      maven插件打包完的目录通常是这样:

    根目录

      |----bin //放置shell脚本

      |----lib //放置java项目的依赖jar包

      |----*****-***.jar //本次项目要发布的核心jar包

      |----conf //放置项目的配置文件

      一般java的项目会把依赖的jar包,和要执行的jar包,以及配置文件都放到classpath路径下面。

    2、启动脚本

    #!/bin/bash
    # version: 1.0.0
    # modify: 2016/07/13
      
    cd `dirname $0`             #这个命令写在脚本文件里才有作用,他返回这个脚本文件放置的目录,并可以根据这个目录来定位所要运行程序的相对位置(绝对位置除外)。
    BIN_DIR=`pwd`             #得到当前的路径,即:项目根路径下的bin目录
    cd ..                          #返回到项目的根目录
    DEPLOY_DIR=`pwd`                #将根目录保存下来
    CONF_DIR=$DEPLOY_DIR/conf              #将配置文件的目录保存下来
    SERVER_NAME=`basename $DEPLOY_DIR`      #获取到当前目录的名称,basename 命令会将路径截取根路径,比如:basename /data/had/hadoop 得到的结果是:hadoop,由此作为项目的名称
    PIDS=`ps -ef | grep java | grep "$CONF_DIR" |awk '{print $2}'`     #查找项目是否已经启动,得到PID,先打印出所有的进程,然互过滤出java的进程,再找是否有带有本项目路径的进程,如果有,则截取出PID
    if [ -n "$PIDS" ]; then                                         #判断字符串PIDS是否为空,如果不为空,则说明进程已经存在                      
        echo "ERROR: The $SERVER_NAME already started!"            #弹出进程存在的提示信息
        echo "PID: $PIDS"                                          #打印出PID的值
        exit 1                                                      #脚本执行结束
    fi
      
    LOGS_DIR=$DEPLOY_DIR/logs                                 #设置日志文件的输出目录
      
    if [ ! -d $LOGS_DIR ]; then                               #如果目录不存在,就创建目录 
        mkdir $LOGS_DIR
    fi
    STDOUT_FILE=$LOGS_DIR/stdout.log                        #创建标准日志的输出文件
      
    LIB_DIR=$DEPLOY_DIR/lib                                #得到java项目依赖jar包的存放目录
    LIB_JARS=`ls $LIB_DIR|grep .jar|awk '{print "'$LIB_DIR'/"$0}'|tr "\n" ":"`   #遍历整个目录的jar包,将其添加进来
    MAIN_CLASS_JAR=`ls $DEPLOY_DIR|grep .jar|awk '{print "'$DEPLOY_DIR'/"$0}'|tr "\n" ":"`     #得到要部署的jar包
    JAVA_OPTS=" -Djava.net.preferIPv4Stack=true -Dlog.home=$LOGS_DIR"      #设置java的启动参数
    JAVA_MEM_OPTS=""                 #设置java的JVM参数
    BITS=`java -version 2>&1 | grep -i 64-bit`
    if [ -n "$BITS" ]; then
        JAVA_MEM_OPTS=" -server -Xms2g -Xmx2g -XX:PermSize=128m -XX:MaxPermSize=128m -XX:SurvivorRatio=6 -XX:+UseConcMarkSweepGC -XX:+CMSParallelRemarkEnabled -XX:+UseCMSInitiatingOccupancyOnly -XX:CMSInitiatingOccupancyFraction=80 -XX:+ScavengeBeforeFullGC -XX:+CMSScavengeBeforeRemark -XX:+PrintGCDateStamps -verbose:gc -XX:+PrintGCDetails -Xloggc:gc.log -XX:+UseGCLogFileRotation -XX:NumberOfGCLogFiles=10 -XX:GCLogFileSize=100M -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=dump.hprof "
    else
        JAVA_MEM_OPTS=" -server -Xms1g -Xmx1g -XX:PermSize=128m -XX:MaxPermSize=128m -XX:SurvivorRatio=2 -XX:+UseParallelGC "
    fi
      
    echo -e "Starting the $SERVER_NAME ...\c"   #打印启动日志
    nohup java $JAVA_OPTS $JAVA_MEM_OPTS -classpath $CONF_DIR:$LIB_JARS:$MAIN_CLASS_JAR  com.juanpi.lux.trace.ws.LuxTraceWsApplication > $STDOUT_FILE 2>&1 &   #启动java项目,注意要设置classpath,并且给出项目的main class ,并将输出重定向
      
    COUNT=0
    while [ $COUNT -lt 1 ]; do                 #定时检测是否成功
        echo -e ".\c"                           #打点
        sleep 1                                  #等待一秒
        COUNT=`ps -f | grep java | grep "$DEPLOY_DIR" | awk '{print $2}' | wc -l`
        if [ $COUNT -gt 0 ]; then
            break
        fi
    done
      
    echo "OK!"                                      
    PIDS=`ps -f | grep java | grep "$DEPLOY_DIR" | awk '{print $2}'`   #获取启动后的PID
    echo "PID: $PIDS"
    echo "STDOUT: $STDOUT_FILE"

    3、停止脚本

    #!/bin/bash
    # version: 1.0.0
    # modify: 2016/07/13
    
    cd `dirname $0`
    BIN_DIR=`pwd`
    cd ..
    DEPLOY_DIR=`pwd`
    CONF_DIR=$DEPLOY_DIR/conf
    
    SERVER_NAME=`basename $DEPLOY_DIR`
    
    PIDS=`ps -ef | grep java | grep "$CONF_DIR" |awk '{print $2}'`
    if [ -z "$PIDS" ]; then
        echo "ERROR: The $SERVER_NAME does not started!"
        exit 1
    fi
    
    if [ "$1" == "dump" ]; then
        $BIN_DIR/dump.sh
    fi
    
    echo -e "Stopping the $SERVER_NAME ...\c"
    for PID in $PIDS ; do
        kill $PID > /dev/null 2>&1
    done
    
    COUNT=0
    while [ $COUNT -lt 1 ]; do
        echo -e ".\c"
        sleep 1
        COUNT=1
        for PID in $PIDS ; do
            PID_EXIST=`ps -f -p $PID | grep java`
            if [ -n "$PID_EXIST" ]; then
                COUNT=0
                break
            fi
        done
    done
    
    echo "OK!"
    echo "PID: $PIDS"

    4、dump脚本

    #!/bin/bash
    # version: 1.0.0
    # modify: 2016/07/13
    
    cd `dirname $0`
    BIN_DIR=`pwd`
    cd ..
    DEPLOY_DIR=`pwd`
    CONF_DIR=$DEPLOY_DIR/conf
    
    SERVER_NAME=`basename $DEPLOY_DIR`
    
    PIDS=`ps -ef | grep java | grep "$CONF_DIR" |awk '{print $2}'`
    if [ -z "$PIDS" ]; then
        echo "ERROR: The $SERVER_NAME does not started!"
        exit 1
    fi
    
    LOGS_DIR=$DEPLOY_DIR/logs
    if [ ! -d $LOGS_DIR ]; then
        mkdir $LOGS_DIR
    fi
    DUMP_DIR=$LOGS_DIR/dump
    if [ ! -d $DUMP_DIR ]; then
        mkdir $DUMP_DIR
    fi
    DUMP_DATE=`date +%Y%m%d%H%M%S`
    DATE_DIR=$DUMP_DIR/$DUMP_DATE
    if [ ! -d $DATE_DIR ]; then
        mkdir $DATE_DIR
    fi
    
    echo -e "Dumping the $SERVER_NAME ...\c"
    for PID in $PIDS ; do
        jstack $PID > $DATE_DIR/jstack-$PID.dump 2>&1
        echo -e ".\c"
        jinfo $PID > $DATE_DIR/jinfo-$PID.dump 2>&1
        echo -e ".\c"
        jstat -gcutil $PID > $DATE_DIR/jstat-gcutil-$PID.dump 2>&1
        echo -e ".\c"
        jstat -gccapacity $PID > $DATE_DIR/jstat-gccapacity-$PID.dump 2>&1
        echo -e ".\c"
        jmap $PID > $DATE_DIR/jmap-$PID.dump 2>&1
        echo -e ".\c"
        jmap -heap $PID > $DATE_DIR/jmap-heap-$PID.dump 2>&1
        echo -e ".\c"
        jmap -histo $PID > $DATE_DIR/jmap-histo-$PID.dump 2>&1
        echo -e ".\c"
        if [ -r /usr/sbin/lsof ]; then
        /usr/sbin/lsof -p $PID > $DATE_DIR/lsof-$PID.dump
        echo -e ".\c"
        fi
    done
    
    if [ -r /bin/netstat ]; then
    /bin/netstat -an > $DATE_DIR/netstat.dump 2>&1
    echo -e ".\c"
    fi
    if [ -r /usr/bin/iostat ]; then
    /usr/bin/iostat > $DATE_DIR/iostat.dump 2>&1
    echo -e ".\c"
    fi
    if [ -r /usr/bin/mpstat ]; then
    /usr/bin/mpstat > $DATE_DIR/mpstat.dump 2>&1
    echo -e ".\c"
    fi
    if [ -r /usr/bin/vmstat ]; then
    /usr/bin/vmstat > $DATE_DIR/vmstat.dump 2>&1
    echo -e ".\c"
    fi
    if [ -r /usr/bin/free ]; then
    /usr/bin/free -t > $DATE_DIR/free.dump 2>&1
    echo -e ".\c"
    fi
    if [ -r /usr/bin/sar ]; then
    /usr/bin/sar > $DATE_DIR/sar.dump 2>&1
    echo -e ".\c"
    fi
    if [ -r /usr/bin/uptime ]; then
    /usr/bin/uptime > $DATE_DIR/uptime.dump 2>&1
    echo -e ".\c"
    fi
    
    echo "OK!"
    echo "DUMP: $DATE_DIR"

    注:文中所有的脚本已近maven插件的配置已经打包放在附件中,可以直接下载。http://files.cnblogs.com/files/yanyamin/%E8%84%9A%E6%9C%AC%E5%92%8C%E6%8F%92%E4%BB%B6%E9%85%8D%E7%BD%AE.zip

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    上一篇:java swing 去掉按钮文字周围的焦点框 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • Java性能调优工程的几点建议• Java 8 Streams中的数据库CRUD操作• spring 注解• Java中hashcode()方法的前生与今世• Java内存以及GC
    1/1

    PHP中文网