Shell-通过shell启动Java类中的main方法 + 通过Shell启动jar包
文章目錄
- 概述
- shell啟動Java類中的main方法
- 啟動腳本分析
- 啟動腳本
- shell啟動jar包
概述
Java程序 運行在linux主機上, 通過shell腳本啟動為進程。
Java程序中 通過定時任務,設置訪問Hbase的時間間隔,設置告警規則,比如三次獲取Hbase中的數據失敗,則調用存過,遍歷配置的告警號碼,插入短信中間表,實現短信的發送。
項目結構如下
shell啟動Java類中的main方法
啟動腳本分析
根據服務器上JDK 以及工程部署路徑
修改相應的#JDK所在路徑 APP_HOME 啟動入口類APP_MAINCLASS(需有main方法) 。注意CLASSPATH,務必正確export相應的jar包。
之前碰到了一個錯誤,應用啟動時,hadoop會加載native文件,有兩種解決方式:
我采用了第一種方式來加載對應的native。(找到主機native的安裝路徑指定即可)
應用中引用的hadoop相關的jar包(后面因報錯,增加了commons-codec-1.10.jar 和 netty-3.6.6.Final.jar)
btw: 應用中的hadoop相關jar盡量和大數據平臺的保持一致, 所以本應用的jar都是從大數據平臺主機上down下來的 (@ο@)。
如不清楚jar包具體位置,
. /home/aisc/app/env.sh
env.sh ,so 進去瞅瞅相應的路徑就ok了。
可以看到 $AISC_HOME/libjars/*.jar
腳本啟動方式 ./startup 【start | stop | info | status 】詳見腳本
#!/bin/sh #該腳本為Linux下啟動java程序的通用腳本。即可以作為開機自啟動service腳本被調用, #也可以作為啟動java程序的獨立腳本來使用。 # #Author: tudaxia.com, Date: 2011/6/7 # #警告!!!:該腳本stop部分使用系統kill命令來強制終止指定的java程序進程。 #在殺死進程前,未作任何條件檢查。在某些情況下,如程序正在進行文件或數據庫寫操作, #可能會造成數據丟失或數據不完整。如果必須要考慮到這類情況,則需要改寫此腳本, #增加在執行kill命令前的一系列檢查。 # # ################################### #環境變量及程序執行參數 #需要根據實際環境以及Java程序名稱來修改這些參數 ################################### #JDK所在路徑 JAVA_HOME="/usr/java/jdk1.7.0_60"#執行程序啟動所使用的系統用戶,考慮到安全,推薦不使用root帳號 (本次我在下面的start和stop方法中,屏蔽了校驗 忘記了xxx的密碼了.... ) RUNNING_USER=xxx#Java程序所在的目錄(classes的上一級目錄) APP_HOME=/home/xxx/HbaseMonitor#需要啟動的Java主程序(main方法類) APP_MAINCLASS=com.xxxxx.monitor.hbase.HbaseMonitor#拼湊完整的classpath參數,包括指定lib目錄下所有的jar CLASSPATH=$APP_HOME/bin for i in "$APP_HOME"/lib/*.jar; doCLASSPATH="$CLASSPATH":"$i" done#export LD_LIBRARY_PATH=/home/aaaa/app/hadoop-2.3.0-cdh5.1.2/lib/native #java虛擬機啟動參數 JAVA_OPTS="-ms512m -mx512m -Xmn256m -Djava.awt.headless=true -XX:MaxPermSize=128m -Djava.library.path=/home/aaaa/app/hadoop-2.3.0-cdh5.1.2/lib/native" ################################### #(函數)判斷程序是否已啟動 # #說明: #使用JDK自帶的JPS命令及grep命令組合,準確查找pid #jps 加 l 參數,表示顯示java的完整包路徑 #使用awk,分割出pid ($1部分),及Java程序名稱($2部分) ################################### #初始化psid變量(全局) psid=0checkpid() {javaps=`$JAVA_HOME/bin/jps -l | grep $APP_MAINCLASS`if [ -n "$javaps" ]; thenpsid=`echo $javaps | awk '{print $1}'`elsepsid=0fi }################################### #(函數)啟動程序 # #說明: #1. 首先調用checkpid函數,刷新$psid全局變量 #2. 如果程序已經啟動($psid不等于0),則提示程序已啟動 #3. 如果程序沒有被啟動,則執行啟動命令行 #4. 啟動命令執行后,再次調用checkpid函數 #5. 如果步驟4的結果能夠確認程序的pid,則打印[OK],否則打印[Failed] #注意:echo -n 表示打印字符后,不換行 #注意: "nohup 某命令 >/dev/null 2>&1 &" 的用法 ################################### start() {checkpidif [ $psid -ne 0 ]; thenecho "================================"echo "warn: $APP_MAINCLASS already started! (pid=$psid)"echo "================================"elseecho -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"nohup $JAVA_HOME/bin/java $JAVA_OPTS -classpath $CLASSPATH $APP_MAINCLASS >/dev/null 2>&1 &checkpidif [ $psid -ne 0 ]; thenecho "(pid=$psid) [OK]"elseecho "[Failed]"fifi }################################### #(函數)停止程序 # #說明: #1. 首先調用checkpid函數,刷新$psid全局變量 #2. 如果程序已經啟動($psid不等于0),則開始執行停止,否則,提示程序未運行 #3. 使用kill -9 pid命令進行強制殺死進程 #4. 執行kill命令行緊接其后,馬上查看上一句命令的返回值: $? #5. 如果步驟4的結果$?等于0,則打印[OK],否則打印[Failed] #6. 為了防止java程序被啟動多次,這里增加反復檢查進程,反復殺死的處理(遞歸調用stop)。 #注意:echo -n 表示打印字符后,不換行 #注意: 在shell編程中,"$?" 表示上一句命令或者一個函數的返回值 ################################### stop() {checkpidif [ $psid -ne 0 ]; thenecho -n "Stopping $APP_MAINCLASS ...(pid=$psid) "# 設置推薦用戶停止#su - $RUNNING_USER -c "kill -9 $psid"#不校驗用戶直接killkill -9 $psidif [ $? -eq 0 ]; thenecho "[OK]"elseecho "[Failed]"ficheckpidif [ $psid -ne 0 ]; thenstopfielseecho "================================"echo "warn: $APP_MAINCLASS is not running"echo "================================"fi }################################### #(函數)檢查程序運行狀態 # #說明: #1. 首先調用checkpid函數,刷新$psid全局變量 #2. 如果程序已經啟動($psid不等于0),則提示正在運行并表示出pid #3. 否則,提示程序未運行 ################################### status() {checkpidif [ $psid -ne 0 ]; thenecho "$APP_MAINCLASS is running! (pid=$psid)"elseecho "$APP_MAINCLASS is not running"fi }################################### #(函數)打印系統環境參數 ################################### info() {echo "System Information:"echo "****************************"echo `head -n 1 /etc/issue`echo `uname -a`echoecho "JAVA_HOME=$JAVA_HOME"echo `$JAVA_HOME/bin/java -version`echo "CLASSPATH=${CLASSPATH}"echoecho "APP_HOME=$APP_HOME"echo "APP_MAINCLASS=$APP_MAINCLASS"echo "****************************" }################################### #讀取腳本的第一個參數($1),進行判斷 #參數取值范圍:{start|stop|restart|status|info} #如參數不在指定范圍之內,則打印幫助信息 ################################### case "$1" in'start')start;;'stop')stop;;'restart')stopstart;;'status')status;;'info')info;;*)echo "Usage: $0 {start|stop|restart|status|info}"exit 1 esac exit 0本來的思路是 通過連接hbase 創建表然后put幾條數據進去的方式,如果成功,則說明連接OK。但是dont know why ,調整了很多次,已經是卡在 HBaseAdmin hBaseAdmin = new HBaseAdmin(configuration);
但是沒有報錯…
調整思路: 手工在hbase中建表,手工插入幾條數據,然后讓應用去獲取數據,果然可以獲取到,精神病人思路廣啊…
通過hbase shell命令 進入 hbase,然后逐一執行以下腳本
主要是 建個表,然后寫入幾條模擬數據,讓應用去獲取一下。
tableName : xxx_monitor
核心代碼如下:
通過靜態代碼塊 初始化Hbase連接信息,就不用加載hbase-site.xml等配置文件了。 通過連接zk,(三個節點),將hbase托管給zk去管理。
/*** 靜態代碼塊,類初始化的時候,僅加載一次*/static {logger.info("Hbase配置開始初始化........");configuration = HBaseConfiguration.create();configuration.set("hbase.zookeeper.quorum", "10.4.10.AAAA,10.4.10.BBBB,10.4.10.CCCCC");configuration.set("hbase.zookeeper.property.clientPort", "2181");logger.info("Hbase配置初始化成功........");}定時任務是通過ScheduledExecutorService 實現
public static void main(String[] args) {Runnable runnable = new Runnable() {public void run() {if (deadTimes < 3) {logger.info("開始檢測....");// 建表// creatTable(tablename);// 添加數據// insertData(tablename);// 查詢數據QueryAll(tablename);} else {// 發送短信 如果未恢復,肯定逼逼的又是一堆,如果恢復了,則正常。logger.info("超過三次-----" + deadTimes);WarnMessage.senMessage(errInfo);deadTimes = 0;}}};// 調度ScheduledExecutorService service = Executors.newSingleThreadScheduledExecutor();// 第二個參數為首次執行的延時時間,第三個參數為定時執行的間隔時間 ,第四個參數為單位service.scheduleAtFixedRate(runnable, 0, 1, TimeUnit.MINUTES);}啟動腳本
#!/bin/sh # #該腳本為Linux下啟動java程序的通用腳本。即可以作為開機自啟動service腳本被調用, #也可以作為啟動java程序的獨立腳本來使用。 # #Author: tudaxia.com, Date: 2011/6/7 # #警告!!!:該腳本stop部分使用系統kill命令來強制終止指定的java程序進程。 #在殺死進程前,未作任何條件檢查。在某些情況下,如程序正在進行文件或數據庫寫操作, #可能會造成數據丟失或數據不完整。如果必須要考慮到這類情況,則需要改寫此腳本, #增加在執行kill命令前的一系列檢查。 # ################################### # 以下這些注釋設置可以被chkconfig命令讀取 # chkconfig: - 99 50 # description: Java程序啟動腳本 # processname: test # config: 如果需要的話,可以配置 ################################### # ################################### #環境變量及程序執行參數 #需要根據實際環境以及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; doCLASSPATH="$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=0checkpid() {javaps=`$JAVA_HOME/bin/jps -l | grep $APP_MAINCLASS`if [ -n "$javaps" ]; thenpsid=`echo $javaps | awk '{print $1}'`elsepsid=0fi }################################### #(函數)啟動程序 # #說明: #1. 首先調用checkpid函數,刷新$psid全局變量 #2. 如果程序已經啟動($psid不等于0),則提示程序已啟動 #3. 如果程序沒有被啟動,則執行啟動命令行 #4. 啟動命令執行后,再次調用checkpid函數 #5. 如果步驟4的結果能夠確認程序的pid,則打印[OK],否則打印[Failed] #注意:echo -n 表示打印字符后,不換行 #注意: "nohup 某命令 >/dev/null 2>&1 &" 的用法 ################################### start() {checkpidif [ $psid -ne 0 ]; thenecho "================================"echo "warn: $APP_MAINCLASS already started! (pid=$psid)"echo "================================"elseecho -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"checkpidif [ $psid -ne 0 ]; thenecho "(pid=$psid) [OK]"elseecho "[Failed]"fifi }################################### #(函數)停止程序 # #說明: #1. 首先調用checkpid函數,刷新$psid全局變量 #2. 如果程序已經啟動($psid不等于0),則開始執行停止,否則,提示程序未運行 #3. 使用kill -9 pid命令進行強制殺死進程 #4. 執行kill命令行緊接其后,馬上查看上一句命令的返回值: $? #5. 如果步驟4的結果$?等于0,則打印[OK],否則打印[Failed] #6. 為了防止java程序被啟動多次,這里增加反復檢查進程,反復殺死的處理(遞歸調用stop)。 #注意:echo -n 表示打印字符后,不換行 #注意: 在shell編程中,"$?" 表示上一句命令或者一個函數的返回值 ################################### stop() {checkpidif [ $psid -ne 0 ]; thenecho -n "Stopping $APP_MAINCLASS ...(pid=$psid) "su - $RUNNING_USER -c "kill -9 $psid"if [ $? -eq 0 ]; thenecho "[OK]"elseecho "[Failed]"ficheckpidif [ $psid -ne 0 ]; thenstopfielseecho "================================"echo "warn: $APP_MAINCLASS is not running"echo "================================"fi }################################### #(函數)檢查程序運行狀態 # #說明: #1. 首先調用checkpid函數,刷新$psid全局變量 #2. 如果程序已經啟動($psid不等于0),則提示正在運行并表示出pid #3. 否則,提示程序未運行 ################################### status() {checkpidif [ $psid -ne 0 ]; thenecho "$APP_MAINCLASS is running! (pid=$psid)"elseecho "$APP_MAINCLASS is not running"fi }################################### #(函數)打印系統環境參數 ################################### info() {echo "System Information:"echo "****************************"echo `head -n 1 /etc/issue`echo `uname -a`echoecho "JAVA_HOME=$JAVA_HOME"echo `$JAVA_HOME/bin/java -version`echoecho "APP_HOME=$APP_HOME"echo "APP_MAINCLASS=$APP_MAINCLASS"echo "****************************" }################################### #讀取腳本的第一個參數($1),進行判斷 #參數取值范圍:{start|stop|restart|status|info} #如參數不在指定范圍之內,則打印幫助信息 ################################### case "$1" in'start')start;;'stop')stop;;'restart')stopstart;;'status')status;;'info')info;;*)echo "Usage: $0 {start|stop|restart|status|info}"exit 1 esac exit 0shell啟動jar包
2019-03更新
腳本如下,修改Java路徑和jar包路徑即可
如果是通過yum安裝的java,要找到具體的安裝路徑可以參考如下方式
[root@artisan ~]# whereis java java: /usr/bin/java /usr/lib/java /etc/java /usr/share/java /usr/share/man/man1/java.1.gz # 找到軟連接 [root@artisan ~]# ls -ltr /usr/bin/java lrwxrwxrwx. 1 root root 22 Apr 2 22:46 /usr/bin/java -> /etc/alternatives/java # 安裝路徑 [root@artisan ~]# ls -ltr /etc/alternatives/java lrwxrwxrwx. 1 root root 73 Apr 2 22:46 /etc/alternatives/java -> /usr/lib/jvm/java-1.8.0-openjdk-1.8.0.201.b09-2.el7_6.x86_64/jre/bin/java [root@artisan ~]#然后再/etc/profile 添加
export JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.201.b09-2.el7_6.x86_64/jre/bin/java export PATH=$JAVA_HOME/bin:$PATH export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar最后記得 source /etc/profile 或者 . /etc/profile 使其生效【. 后面有空格,注意下】
記得給腳本賦予可執行的權限 chmod +x startup.sh
使用
[root@artisan ~]# ./startup.sh usage Usage: sh startup.sh [start|stop|restart|status] [root@artisan ~]# ./startup.sh start /root/artisan4Nginx-0.0.1-SNAPSHOT.jar is started. [root@artisan ~]# ./startup.sh status /root/artisan4Nginx-0.0.1-SNAPSHOT.jar is running. Pid is 19180 [root@artisan ~]# ./startup.sh start /root/artisan4Nginx-0.0.1-SNAPSHOT.jar is already running. pid=19180 [root@artisan ~]# ./startup.sh restart /root/artisan4Nginx-0.0.1-SNAPSHOT.jar is started. [root@artisan ~]# ./startup.sh stop [root@artisan ~]# ./startup.sh status /root/artisan4Nginx-0.0.1-SNAPSHOT.jar is NOT running. [root@artisan ~]#《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀
總結
以上是生活随笔為你收集整理的Shell-通过shell启动Java类中的main方法 + 通过Shell启动jar包的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Imageloader5-ImageLo
- 下一篇: Imageloader6-mUIHand