记得两年前实习的时候,继哥说,一个程序员如果把一些范畴内的事情做得完美,其他人会少很多事情,包括测试,运维,方便自己,方便大家。。这次有机会将一个项目进行重构,并进行前后端分离,分析了一些需求和后期的规划后,决定放弃以前“肥大”的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、启动脚本

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 #!/bin/bash2 # 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的进程,再找是否有带有本项目路径的进程,如果有,则截取出PID12 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_DIR22 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 break47 fi

48 done

49

50 echo "OK!"

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

53 echo "STDOUT: $STDOUT_FILE"

View Code

3、停止脚本

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 #!/bin/bash2 # 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/conf10

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 | grepjava`35 if [ -n "$PID_EXIST" ]; then

36 COUNT=0

37 break38 fi

39 done

40 done

41

42 echo "OK!"

43 echo "PID: $PIDS"

View Code

4、dump脚本

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 #!/bin/bash2 # 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/conf10

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/logs20 if [ ! -d $LOGS_DIR ]; then

21 mkdir$LOGS_DIR22 fi

23 DUMP_DIR=$LOGS_DIR/dump24 if [ ! -d $DUMP_DIR ]; then

25 mkdir$DUMP_DIR26 fi

27 DUMP_DATE=`date +%Y%m%d%H%M%S`28 DATE_DIR=$DUMP_DIR/$DUMP_DATE29 if [ ! -d $DATE_DIR ]; then

30 mkdir$DATE_DIR31 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.dump51 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

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐