脚本部署java的class_java项目的部署脚本

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

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值