雖然寫起動shell的頻率很是不高。。。可是每次要寫都要對付一大堆的jar文件路徑,新加jar包也必需要修改起動shell。java
在網上找到一個挺好的通用shell腳本。linux
只須要修改一些配置變量,就能夠用來作起動腳本了。shell
而且除了能起動、還支持關閉、重啓、查看是否正在運行的功能。數據庫
原文地址:http://www.tudaxia.com/archives/10編程
start函數中,nohup部分其實也能夠提出來放入一個配置變量中。這裏沒有修改直接貼上做者的原文安全
#!/bin/sh #該腳本爲Linux下啓動java程序的通用腳本。便可以做爲開機自啓動service腳本被調用, #也能夠做爲啓動java程序的獨立腳原本使用。 # #Author: tudaxia.com, Date: 2011/6/7 # #警告!!!:該腳本stop部分使用系統kill命令來強制終止指定的java程序進程。 #在殺死進程前,未做任何條件檢查。在某些狀況下,如程序正在進行文件或數據庫寫操做, #可能會形成數據丟失或數據不完整。若是必需要考慮到這類狀況,則須要改寫此腳本, #增長在執行kill命令前的一系列檢查。 # # ################################### #環境變量及程序執行參數 #須要根據實際環境以及Java程序名稱來修改這些參數 ################################### #JDK所在路徑 JAVA_HOME="/usr/java/jdk" #執行程序啓動所使用的系統用戶,考慮到安全,推薦不使用root賬號 RUNNING_USER=root #Java程序所在的目錄(classes的上一級目錄) APP_HOME=/opt/tudaxia/test/WEB-INF #須要啓動的Java主程序(main方法類) APP_MAINCLASS=com.tudaxia.test.TestMain #拼湊完整的classpath參數,包括指定lib目錄下全部的jar CLASSPATH=$APP_HOME/classes for i in "$APP_HOME"/lib/*.jar; do CLASSPATH="$CLASSPATH":"$i" done #java虛擬機啓動參數 JAVA_OPTS="-ms512m -mx512m -Xmn256m -Djava.awt.headless=true -XX:MaxPermSize=128m" ################################### #(函數)判斷程序是否已啓動 # #說明: #使用JDK自帶的JPS命令及grep命令組合,準確查找pid #jps 加 l 參數,表示顯示java的完整包路徑 #使用awk,分割出pid ($1部分),及Java程序名稱($2部分) ################################### #初始化psid變量(全局) psid=0 checkpid() { javaps=`$JAVA_HOME/bin/jps -l | grep $APP_MAINCLASS` if [ -n "$javaps" ]; then psid=`echo $javaps | awk '{print $1}'` else psid=0 fi } ################################### #(函數)啓動程序 # #說明: #1. 首先調用checkpid函數,刷新$psid全局變量 #2. 若是程序已經啓動($psid不等於0),則提示程序已啓動 #3. 若是程序沒有被啓動,則執行啓動命令行 #4. 啓動命令執行後,再次調用checkpid函數 #5. 若是步驟4的結果可以確認程序的pid,則打印[OK],不然打印[Failed] #注意:echo -n 表示打印字符後,不換行 #注意: "nohup 某命令 >/dev/null 2>&1 &" 的用法 ################################### start() { checkpid if [ $psid -ne 0 ]; then echo "================================" echo "warn: $APP_MAINCLASS already started! (pid=$psid)" echo "================================" else echo -n "Starting $APP_MAINCLASS ..." JAVA_CMD="nohup $JAVA_HOME/bin/java $JAVA_OPTS -classpath $CLASSPATH $APP_MAINCLASS >/dev/null 2>&1 &" su - $RUNNING_USER -c "$JAVA_CMD" checkpid if [ $psid -ne 0 ]; then echo "(pid=$psid) [OK]" else echo "[Failed]" fi fi } ################################### #(函數)中止程序 # #說明: #1. 首先調用checkpid函數,刷新$psid全局變量 #2. 若是程序已經啓動($psid不等於0),則開始執行中止,不然,提示程序未運行 #3. 使用kill -9 pid命令進行強制殺死進程 #4. 執行kill命令行緊接其後,立刻查看上一句命令的返回值: $? #5. 若是步驟4的結果$?等於0,則打印[OK],不然打印[Failed] #6. 爲了防止java程序被啓動屢次,這裏增長反覆檢查進程,反覆殺死的處理(遞歸調用stop)。 #注意:echo -n 表示打印字符後,不換行 #注意: 在shell編程中,"$?" 表示上一句命令或者一個函數的返回值 ################################### stop() { checkpid if [ $psid -ne 0 ]; then echo -n "Stopping $APP_MAINCLASS ...(pid=$psid) " su - $RUNNING_USER -c "kill -9 $psid" if [ $? -eq 0 ]; then echo "[OK]" else echo "[Failed]" fi checkpid if [ $psid -ne 0 ]; then stop fi else echo "================================" echo "warn: $APP_MAINCLASS is not running" echo "================================" fi } ################################### #(函數)檢查程序運行狀態 # #說明: #1. 首先調用checkpid函數,刷新$psid全局變量 #2. 若是程序已經啓動($psid不等於0),則提示正在運行並表示出pid #3. 不然,提示程序未運行 ################################### status() { checkpid if [ $psid -ne 0 ]; then echo "$APP_MAINCLASS is running! (pid=$psid)" else echo "$APP_MAINCLASS is not running" fi } ################################### #(函數)打印系統環境參數 ################################### info() { echo "System Information:" echo "****************************" echo `head -n 1 /etc/issue` echo `uname -a` echo echo "JAVA_HOME=$JAVA_HOME" echo `$JAVA_HOME/bin/java -version` echo echo "APP_HOME=$APP_HOME" echo "APP_MAINCLASS=$APP_MAINCLASS" echo "****************************" } ################################### #讀取腳本的第一個參數($1),進行判斷 #參數取值範圍:{start|stop|restart|status|info} #如參數不在指定範圍以內,則打印幫助信息 ################################### case "$1" in 'start') start ;; 'stop') stop ;; 'restart') stop start ;; 'status') status ;; 'info') info ;; *) echo "Usage: $0 {start|stop|restart|status|info}" exit 1