码迷,mamicode.com
首页 > 编程语言 > 详细

java项目的部署脚本

时间:2016-10-14 00:06:31      阅读:285      评论:0      收藏:0      [点我收藏+]

标签:

  记得两年前实习的时候,继哥说,一个程序员如果把一些范畴内的事情做得完美,其他人会少很多事情,包括测试,运维,方便自己,方便大家。。这次有机会将一个项目进行重构,并进行前后端分离,分析了一些需求和后期的规划后,决定放弃以前“肥大”的springMVC那一套东西,采用近两年越来越火的微服务架构试一试,当然,首当其冲的就是采用spring-boot来担当重任了。前期的需求都已经完成,本次测试通过(强烈建议java程序员们自己写好单元测试,这将使我们后面的开发和维护变得简单,虽然前期可能要花点功夫,但是值得),准备放到生产环境,这时才发现,各种不便,因为一些设置参数,启动,停止都不方便,所以就决定写好脚本,方便使用,基于这个愿意,有了本篇文章,这里分享一个可以通用的shell脚本(PS:我也是通过别人的版本修改过来的),考虑一些对于shell脚本不熟悉的人,这里我将选取一些做出详细解释。好,话不多少,先直接上启动脚本。

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                                                      #脚本执行结束
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"
View Code

 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 not 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"
View Code 

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 not 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"
View Code

 注:文中所有的脚本已近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

 

java项目的部署脚本

标签:

原文地址:http://www.cnblogs.com/yanyamin/p/5957629.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!