日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

Shell-通过shell启动Java类中的main方法 + 通过Shell启动jar包

發布時間:2025/3/21 java 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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文件,有兩種解決方式:

  • 第一種 在java虛擬機啟動參數加入: -Djava.library.path=/home/aaaa/app/hadoop-2.3.0-cdh5.1.2/lib/native
  • 第二種 export LD_LIBRARY_PATH=/home/aaaa/app/hadoop-2.3.0-cdh5.1.2/lib/native
  • 我采用了第一種方式來加載對應的native。(找到主機native的安裝路徑指定即可)

    應用中引用的hadoop相關的jar包(后面因報錯,增加了commons-codec-1.10.jar 和 netty-3.6.6.Final.jar)

    btw: 應用中的hadoop相關jar盡量和大數據平臺的保持一致, 所以本應用的jar都是從大數據平臺主機上down下來的 (@ο@)。

    如不清楚jar包具體位置,

  • 第一種方式 可以查看環境變量 通過env命令,查看 HADOOP_CLASSPATH 相關信息
  • 第二種方式 cat /etc/profile 查看環境變量。 可以看到引入了
    . /home/aisc/app/env.sh
  • env.sh ,so 進去瞅瞅相應的路徑就ok了。
    可以看到 $AISC_HOME/libjars/*.jar

    for f in $AISC_HOME/libjars/*.jar; do CLASSPATH=${CLASSPATH}:$f; done export HADOOP_CLASSPATH=$HADOOP_CLASSPATH:$CLASSPATH

    腳本啟動方式 ./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,然后逐一執行以下腳本
    主要是 建個表,然后寫入幾條模擬數據,讓應用去獲取一下。

    create 'xxx_monitor','m_id','address','info'put'xxx_monitor','monitor','info:age','24'put'xxx_monitor','monitor','info:birthday','2015-12-09'put'xxx_monitor','monitor','info:company','ccccc'put'xxx_monitor','monitor','address:contry','china' put'xxx_monitor','monitor','address:province','aaaaaa' put'xxx_monitor','monitor','address:city','bbbbb'

    tableName : xxx_monitor
    核心代碼如下:

    /*** 顯示所有數據*/public static void QueryAll(String tableName) {logger.info( "開始顯示所有數據");HTablePool pool = new HTablePool(configuration, 100);HTableInterface table = (HTableInterface) pool.getTable(tableName);try {ResultScanner rs = table.getScanner(new Scan());for (Result r : rs) {logger.info("獲得到rowkey:" + new String(r.getRow()));for (KeyValue keyValue : r.raw()) {logger.info("列族:" + new String(keyValue.getFamily()) + " 列:" + new String(keyValue.getQualifier())+ "====值:" + new String(keyValue.getValue()));}}} catch (IOException e) {deadTimes++;errInfo = e.getMessage();logger.info(e.getMessage(), e);}logger.info("**************************顯示所有數據結束*******************************************");}

    通過靜態代碼塊 初始化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 0

    shell啟動jar包

    2019-03更新

    腳本如下,修改Java路徑和jar包路徑即可

    #!/bin/bash# 修改1:設置自己的Java路徑 或者 source某個外部文件 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#修改2: 自己Jar包的路徑 APP_NAME=/root/artisan4Nginx-0.0.1-SNAPSHOT.jar# 其余無需修改,直接用即可 #使用說明,用來提示輸入參數usage() {echo "Usage: sh startup.sh [start|stop|restart|status]"exit 1}#檢查程序是否在運行is_exist(){pid=`ps -ef|grep $APP_NAME|grep -v grep|awk '{print $2}'`#如果不存在返回1,存在返回0if [ -z "${pid}" ]; thenreturn 1elsereturn 0fi}#啟動方法start(){is_existif [ $? -eq 0 ]; thenecho "${APP_NAME} is already running. pid=${pid}"elsenohup java -jar ${APP_NAME} >startup.out 2>&1 &echo "${APP_NAME} is started."fi}#停止方法stop(){is_existif [ $? -eq "0" ]; thenkill -9 $pidelseecho "${APP_NAME} is not running"fi}#輸出運行狀態status(){is_existif [ $? -eq "0" ]; thenecho "${APP_NAME} is running. Pid is ${pid}"elseecho "${APP_NAME} is NOT running."fi}#重啟restart(){stopsleep 5start}#根據輸入參數,選擇執行對應方法,不輸入則執行使用說明case "$1" in"start")start;;"stop")stop;;"status")status;;"restart")restart;;*)usage;;esac

    如果是通過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包的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。