記得兩年前實習的時候,繼哥說,一個程式員如果把一些範疇內的事情做得完美,其他人會少很多事情,包括測試,運維,方便自己,方便大家。。這次有機會將一個項目進行重構,併進行前後端分離,分析了一些需求和後期的規劃後,決定放棄以前“肥大”的springMVC那一套東西,採用近兩年越來越火的微服務架構試一試,當 ...
記得兩年前實習的時候,繼哥說,一個程式員如果把一些範疇內的事情做得完美,其他人會少很多事情,包括測試,運維,方便自己,方便大家。。這次有機會將一個項目進行重構,併進行前後端分離,分析了一些需求和後期的規劃後,決定放棄以前“肥大”的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