课程咨询 :186 8716 1620      qq:2066486918

昆明Java培训 > 达内新闻 > java项目的部署脚本
  • java项目的部署脚本

    发布:昆明Java培训      来源:达内新闻      时间:2016-10-21

  • 昆明Java培训机构的老师知道,一个程序员如果把一些范畴内的事情做得完美,其他人会少很多事情,包括测试,运维,方便自己,方便大家。这次有机会将一个项目进行重构,并进行前后端分离,分析了一些需求和后期的规划 ,决定放弃以前“肥大”的springMVC那一套东西,采用近两年越来越火的微服务架构试一试,当然,首当其冲的就是采用spring-boot来担当重任了。

    前期的需求都已经完成,本次测试通过(强烈建议java程序员们自己写好单元测试,这将使我们后面的开发和维护变得简单,虽然前期可能要花点功夫,但是值得),准备放到生产环境,这时才发现,各种不便,因为一些设置参 ,启动,停止都不方便,所以就决定写好脚本,方便使用,基于这个愿意,有了昆明Java培训机构的老师的篇文章,这里分享一个可以通用的shell脚本(PS:我也是通过别人的版本修改过来的),考虑一些对于shell脚本不熟悉的人 这里我将选取一些做出详细解释。

    好,话不多少,昆明Java培训机构的老师先直接上启动脚本。

    1、项目目录结构

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

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

    根目录

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

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

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

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

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

    2、启动脚本

    1 #!/bin/bash

    2 # version: 1.0.0

    3 # modify: 2016/07/13

    4  

    5 cd `dirname $0`          #这个命令写在脚本文件里才有作用,他返回这个脚本文件放置的目录,并可以根据这个目录来定位所要运行程序的相对位置(绝对位置除外)。

    6 BIN_DIR=`pwd`       #得到当前的路径,即:项目根路径下的bin目录

    7 cd ..                    #返回到项目的根目录

    8 DEPLOY_DIR=`pwd`    #将根目录保存下来

    9 CONF_DIR=$DEPLOY_DIR/conf             #将配置文件的目录保存下来

    10 SERVER_NAME=`basename $DEPLOY_DIR`     #获取到当前目录的名称,basename命令会将路径截取根路径,比如:basename /data/had/hadoop得到的结果是:hadoop,由此作为项目的名称

    11 PIDS=`ps -ef | grep java | grep "$CONF_DIR" |awk '{print $2}'`    #查找项目是否已经启动,得到PID,先打印出所有的进程,然互过滤出java的进程,再找是否有带有本项目路径的进程,如果有,则截取出PID

    12 if [ -n "$PIDS" ]; then                                        #判断字符串PIDS是否为空,如果不 空,则说明进程已经存在                     

    13    echo "ERROR: The $SERVER_NAME already started!"           #弹出进程存在的提示信息

    14    echo "PID: $PIDS"                                         #打印出 PID的值

    15    exit 1                                            &nb sp;        #脚本执行结束

    16 fi

    17  

    18 LOGS_DIR=$DEPLOY_DIR/logs                                #设置日志文件的输出目录

    19  

    20 if [ ! -d $LOGS_DIR ]; then                              #如果目录不存在,就创建目录

    21    mkdir $LOGS_DIR

    22 fi

    23 STDOUT_FILE=$LOGS_DIR/stdout.log                       #创建标准日志的输出文件

    24  

    25 LIB_DIR=$DEPLOY_DIR/lib                               #得到java项目依赖jar包的存放目录

    26 LIB_JARS=`ls $LIB_DIR|grep .jar|awk '{print "'$LIB_DIR'/"$0}'|tr "\n" ":"`  #遍历整个目录的jar包,将其添加进来

    27 MAIN_CLASS_JAR=`ls $DEPLOY_DIR|grep .jar|awk '{print "'$DEPLOY_DIR'/"$0}'|tr "\n" ":"`    #得到要部署的jar包

    28 JAVA_OPTS=" -Djava.net.preferIPv4Stack=true -Dlog.home=$LOGS_DIR"     #设置java的启动参数

    29 JAVA_MEM_OPTS=""                #设置java的JVM参数

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

    31 if [ -n "$BITS" ]; then

    32    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 "

    33 else

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

    35 fi

    36  

    37 echo -e "Starting the $SERVER_NAME ...\c"  #打印启动日志

    38 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,并将输出重定向

    39  

    40 COUNT=0

    41 while [ $COUNT -lt 1 ]; do                #定时检测是否成功

    42    echo -e ".\c"                          #打点

    43    sleep 1                                 #等待一秒

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

    45    if [ $COUNT -gt 0 ]; then

    46        break

    47    fi

    48 done

    49  

    50 echo "OK!"                                     

    51 PIDS=`ps -f | grep java | grep "$DEPLOY_DIR" | awk '{print $2}'`  #获取启动后的PID

    52 echo "PID: $PIDS"

    53 echo "STDOUT: $STDOUT_FILE"

    3、停止脚本

    1 #!/bin/bash

    2 # version: 1.0.0

    3 # modify: 2016/07/13

    4

    5 cd `dirname $0`

    6 BIN_DIR=`pwd`

    7 cd ..

    8 DEPLOY_DIR=`pwd`

    9 CONF_DIR=$DEPLOY_DIR/conf

    10

    11 SERVER_NAME=`basename $DEPLOY_DIR`

    12

    13 PIDS=`ps -ef | grep java | grep "$CONF_DIR" |awk '{print $2}'`

    14 if [ -z "$PIDS" ]; then

    15    echo "ERROR: The $SERVER_NAME does ot started!"

    16    exit 1

    17 fi

    18

    19 if [ "$1" == "dump" ]; then

    20    $BIN_DIR/dump.sh

    21 fi

    22

    23 echo -e "Stopping the $SERVER_NAME ...\c"

    24 for PID in $PIDS ; do

    25    kill $PID > /dev/null 2>&1

    26 done

    27

    28 COUNT=0

    29 while [ $COUNT -lt 1 ]; do

    30    echo -e ".\c"

    31    sleep 1

    32    COUNT=1

    33    for PID in $PIDS ; do

    34        PID_EXIST=`ps -f -p $PID | grep java`

    35        if [ -n "$PID_EXIST" ]; then

    36            COUNT=0

    37            break

    38        fi

    39    done

    40 done

    41

    42 echo "OK!"

    43 echo "PID: $PIDS"

    4、dump脚本

    1 #!/bin/bash

    2 # version: 1.0.0

    3 # modify: 2016/07/13

    4

    5 cd `dirname $0`

    6 BIN_DIR=`pwd`

    7 cd ..

    8 DEPLOY_DIR=`pwd`

    9 CONF_DIR=$DEPLOY_DIR/conf

    10

    11 SERVER_NAME=`basename $DEPLOY_DIR`

    12

    13 PIDS=`ps -ef | grep java | grep "$CONF_DIR" |awk '{print $2}'`

    14 if [ -z "$PIDS" ]; then

    15    echo "ERROR: The $SERVER_NAME does ot started!"

    16    exit 1

    17 fi

    18

    19 LOGS_DIR=$DEPLOY_DIR/logs

    20 if [ ! -d $LOGS_DIR ]; then

    21    mkdir $LOGS_DIR

    22 fi

    23 DUMP_DIR=$LOGS_DIR/dump

    24 if [ ! -d $DUMP_DIR ]; then

    25    mkdir $DUMP_DIR

    26 fi

    27 DUMP_DATE=`date +%Y%m%d%H%M%S`

    28 DATE_DIR=$DUMP_DIR/$DUMP_DATE

    29 if [ ! -d $DATE_DIR ]; then

    30    mkdir $DATE_DIR

    31 fi

    32

    33 echo -e "Dumping the $SERVER_NAME ...\c"

    34 for PID in $PIDS ; do

    35    jstack $PID > $DATE_DIR/jstack-$PID.dump 2>&1

    36    echo -e ".\c"

    37    jinfo $PID > $DATE_DIR/jinfo-$PID.dump 2>&1

    38    echo -e ".\c"

    39    jstat -gcutil $PID > $DATE_DIR/jstat-gcutil-$PID.dump 2>&1

    40    echo -e ".\c"

    41    jstat -gccapacity $PID > $DATE_DIR/jstat-gccapacity-$PID.dump 2>&1

    42    echo -e ".\c"

    43    jmap $PID > $DATE_DIR/jmap-$PID.dump 2>&1

    44    echo -e ".\c"

    45    jmap -heap $PID > $DATE_DIR/jmap-heap-$PID.dump 2>&1

    46    echo -e ".\c"

    47    jmap -histo $PID > $DATE_DIR/jmap-histo-$PID.dump 2>&1

    48    echo -e ".\c"

    49    if [ -r /usr/sbin/lsof ]; then

    50    /usr/sbin/lsof -p $PID > $DATE_DIR/lsof-$PID.dump

    51    echo -e ".\c"

    52    fi

    53 done

    54

    55 if [ -r /bin/netstat ]; then

    56 /bin/netstat -an > $DATE_DIR/netstat.dump 2>&1

    57 echo -e ".\c"

    58 fi

    59 if [ -r /usr/bin/iostat ]; then

    60 /usr/bin/iostat > $DATE_DIR/iostat.dump 2>&1

    61 echo -e ".\c"

    62 fi

    63 if [ -r /usr/bin/mpstat ]; then

    64 /usr/bin/mpstat > $DATE_DIR/mpstat.dump 2>&1

    65 echo -e ".\c"

    66 fi

    67 if [ -r /usr/bin/vmstat ]; then

    68 /usr/bin/vmstat > $DATE_DIR/vmstat.dump 2>&1

    69 echo -e ".\c"

    70 fi

    71 if [ -r /usr/bin/free ]; then

    72 /usr/bin/free -t > $DATE_DIR/free.dump 2>&1

    73 echo -e ".\c"

    74 fi

    75 if [ -r /usr/bin/sar ]; then

    76 /usr/bin/sar > $DATE_DIR/sar.dump 2>&1

    77 echo -e ".\c"

    78 fi

    79 if [ -r /usr/bin/uptime ]; then

    80 /usr/bin/uptime > $DATE_DIR/uptime.dump 2>&1

    81 echo -e ".\c"

    82 fi

    83

    84 echo "OK!"

    85 echo "DUMP: $DATE_DIR"

    推荐文章

上一篇:JAVA注释的另一种用法

下一篇:java swing去掉按钮文字周围的焦点框

最新开班日期  |  更多

Java--零基础全日制班

Java--零基础全日制班

开班日期:11/30

Java--零基础业余班

Java--零基础业余班

开班日期:11/30

Java--周末提升班

Java--周末提升班

开班日期:11/30

Java--零基础周末班

Java--零基础周末班

开班日期:11/30

  • 网址:http://km .java.tedu.cn      地址:昆明市官渡区春城路62号证券大厦附楼6楼
  • 课程培训电话:186 8716 1620      qq:2066486918    全国服务监督电话:400-827-0010
  • 服务邮箱 ts@tedu.cn
  • 2001-2016 达内国际公司(TARENA INTERNATIONAL,INC.) 版权所有 京ICP证08000853号-56