shell腳本運(yùn)行java程序jar的方法
在UBuntu上部署項(xiàng)目的時(shí)候,我們往往通過(guò)一段shell來(lái)啟動(dòng)程序,甚至是通過(guò)crontab定時(shí)任務(wù)來(lái)定時(shí)的調(diào)用java程序,但是很奇怪的一個(gè)問(wèn)題就是,比如我寫(xiě)了一個(gè)如下的shell腳本:
#!/bin/sh export mypath=/root/project/wishnomal java -Xmx3000m -Xms3000m -server -d64 -Dfile.encoding=UTF-8 -Dfetch.threads=300 -classpath $mypath/:$mypath/wish2-assembly-1.0.0.jar newstandard.CrawlerNewStandard $* echo "END"
手動(dòng)命令行運(yùn)行該腳本的時(shí)候,可以正常運(yùn)行java程序,但是使用crontab定時(shí)任務(wù),貌似就不起效果了
分析可能原因:
1)是否當(dāng)前用戶對(duì)此shell腳本沒(méi)有可執(zhí)行權(quán)限,通過(guò)ls -lrt /apps/service/mtk/checking/run.sh查看腳本是有可執(zhí)行,但是有執(zhí)行權(quán)限呀-rwxr-xr-x
2)既然單獨(dú)運(yùn)行腳本沒(méi)問(wèn)題,那會(huì)不會(huì)是定時(shí)的問(wèn)題呢?于是寫(xiě)了一個(gè)簡(jiǎn)單的輸出的shell腳本通過(guò)定時(shí)也是沒(méi)問(wèn)題的。說(shuō)明還是腳本的問(wèn)題。
后來(lái)上網(wǎng)查了下,想到可能是腳本中環(huán)境變量的原因,因?yàn)橥ㄟ^(guò)crontab運(yùn)行腳本,是以root用戶,而不是當(dāng)前用戶,于是cat /etc/profile查看環(huán)境變量,然后修改腳本如下:
分析可能原因:
1)是否當(dāng)前用戶對(duì)此shell腳本沒(méi)有可執(zhí)行權(quán)限,通過(guò)ls -lrt /apps/service/mtk/checking/run.sh查看腳本是有可執(zhí)行,但是有執(zhí)行權(quán)限呀-rwxr-xr-x
2)既然單獨(dú)運(yùn)行腳本沒(méi)問(wèn)題,那會(huì)不會(huì)是定時(shí)的問(wèn)題呢?于是寫(xiě)了一個(gè)簡(jiǎn)單的輸出的shell腳本通過(guò)定時(shí)也是沒(méi)問(wèn)題的。說(shuō)明還是腳本的問(wèn)題。
后來(lái)上網(wǎng)查了下,想到可能是腳本中環(huán)境變量的原因,因?yàn)橥ㄟ^(guò)crontab運(yùn)行腳本,是以root用戶,而不是當(dāng)前用戶,于是cat /etc/profile查看環(huán)境變量,然后修改腳本如下:
#!/bin/sh export mypath=/root/project/wishnomal export JAVA_HOME=/root/lib/jdk1.7.0_72 PATH=$PATH:$JAVA_HOME/bin java -Xmx3000m -Xms3000m -server -d64 -Dfile.encoding=UTF-8 -Dfetch.threads=300 -classpath $mypath/:$mypath/wish2-assembly-1.0.0.jar newstandard.CrawlerNewStandard $* echo "END"
export顯示導(dǎo)出為用戶環(huán)境變量的環(huán)境變量
這樣crontab計(jì)劃任務(wù)就正常了。
修改參考:
#!/bin/sh # ----------------------------------------------------------------------------- # Start script for the CMGP BOSSCONTROL # # $Id: run_bosscontrol.sh,v 1.0 2007/11/06 Exp $ # ----------------------------------------------------------------------------- #指定字符集 LANG=zh_CN.GBK export LANG RUN_HOME=. CLASSPATH=$CLASSPATH:$RUN_HOME/lib/checking.jar CLASSPATH=$CLASSPATH:$RUN_HOME/lib/ojdbc14.jar CLASSPATH=$CLASSPATH:$RUN_HOME/lib/commons-dbutils-1.1.jar CLASSPATH=$CLASSPATH:$RUN_HOME/lib/log4j-1.2.14.jar CLASSPATH=$CLASSPATH:$RUN_HOME/lib/dom4j-1.6.jar export CLASSPATH java com.**.checking.Checking_Start >> log.out &
手動(dòng)命令行運(yùn)行該腳本的時(shí)候,可以正常運(yùn)行java程序,但是使用crontab定時(shí)任務(wù),貌似就不起效果了,很是郁悶?zāi)模樵蚰?,分析可能原因?/p>
1)是否當(dāng)前用戶對(duì)此shell腳本沒(méi)有可執(zhí)行權(quán)限,通過(guò)ls -lrt /apps/service/mtk/checking/run.sh查看腳本是有可執(zhí)行,但是有執(zhí)行權(quán)限呀-rwxr-xr-x
2)既然單獨(dú)運(yùn)行腳本沒(méi)問(wèn)題,那會(huì)不會(huì)是定時(shí)的問(wèn)題呢?于是寫(xiě)了一個(gè)簡(jiǎn)單的輸出的shell腳本通過(guò)定時(shí)也是沒(méi)問(wèn)題的。說(shuō)明還是腳本的問(wèn)題。
后來(lái)上網(wǎng)查了下,想到可能是腳本中環(huán)境變量的原因,因?yàn)橥ㄟ^(guò)crontab運(yùn)行腳本,是以root用戶,而不是當(dāng)前用戶,于是cat /etc/profile查看環(huán)境變量,然后修改腳本如下:
#!/bin/sh # ----------------------------------------------------------------------------- # Start script for the CMGP BOSSCONTROL # # $Id: run_bosscontrol.sh,v 1.0 2007/11/06 Exp $ # ----------------------------------------------------------------------------- export PATH=/apps/usr/java/jdk1.5/bin:$PATH export JAVA_HOME=/apps/usr/java/jdk1.5 export JRE_HOME=/apps/usr/java/jdk1.5/jre export CLASSPATH=/apps/usr/java/jdk1.5/lib:/apps/usr/java/jdk1.5/jre/lib:$CLASSPATH RUN_HOME=/apps/service/checking CLASSPATH=$CLASSPATH$RUN_HOME/lib/checking.jar CLASSPATH=$CLASSPATH:$RUN_HOME/lib/ojdbc14.jar CLASSPATH=$CLASSPATH:$RUN_HOME/lib/commons-dbutils-1.1.jar CLASSPATH=$CLASSPATH:$RUN_HOME/lib/log4j-1.2.14.jar CLASSPATH=$CLASSPATH:$RUN_HOME/lib/dom4j-1.6.jar export CLASSPATH=$CLASSPATH java com.**.checking.Checking_Start >> log.out &
export顯示導(dǎo)出為用戶環(huán)境變量的環(huán)境變量
以上這種jar包是通過(guò)eclipse工具export導(dǎo)出,不包含MANIFEST.MF文件,如果使用打包工具Ant,我們可以在打包默認(rèn)的build.xml文件中設(shè)置Class-Path
將第三方j(luò)ar包加入manifest.mf文件中,且指定程序主類(lèi)
在build.xml中添加如下內(nèi)容:
<!-- create a property containing all .jar files, prefix lib/, and seperated with a space -->
<pathconvert property="libs.project" pathsep=" ">
<mapper>
<chainedmapper>
<!-- remove absolute path -->
<flattenmapper />
<!-- add lib/ prefix -->
<globmapper from="*" to="lib/*" />
</chainedmapper>
</mapper>
<path>
<!-- lib.home contains all jar files, in several subdirectories -->
<fileset dir="${lib.dir}">
<include name="**/*.jar" />
</fileset>
</path>
</pathconvert>
另外,在create manifest文件時(shí),加上:
<!-- 這樣就可以將第三方j(luò)ar包加入 -->
<attribute name="Class-Path" value="${libs.project}" />
<!-- 程序運(yùn)行的主類(lèi) -->
<attribute name="Main-Class" value="com.**.checking.Checking_Start " />
這樣運(yùn)行ant,打成的jar包中MANIFEST.MF中內(nèi)容如下:
Manifest-Version: 1.0 Ant-Version: Apache Ant 1.7.0 Created-By: 1.5.0_09-b01 (Sun Microsystems Inc.) Implementation-Title: fee task Implementation-Version: 1.0 Implementation-Vendor: Aspire Main-Class: com.aspire.cmgp.flowcontrol.server.FlowControlServer Class-Path: lib/cmgp-util-1.0.1.jar lib/commons-codec-1.3.jar lib/comm ons-collections.jar lib/commons-dbcp-1.2.1.jar lib/commons-httpclient .jar lib/commons-logging.jar lib/commons-pool-1.2.jar lib/dom4j.jar l ib/log4j.jar lib/ojdbc14.jar
這樣在shell腳本中就不需要指定程序所需要的jar包了,也就不存在環(huán)境變量設(shè)置的惱人問(wèn)題。比較正規(guī)的也是這么操作的。
這樣在shell中就直接運(yùn)行jar包就行了:java -jar 主程序.jar -Xmx1024m -Xms1024m -Xmn512m,
#!/bin/bash后追加
source /etc/profile
source ~/.bash_profile
測(cè)試下。。
#! /bin/sh
export JAVA_HOME=/usr/java/jdk1.6.0_18
export CLASSPATH=.:${JAVA_HOME}/lib/dt.jar:${JAVA_HOME}/lib/tools.jar
for i in lib/*.jar;
do CLASSPATH=$i:${CLASSPATH}
done
export CLASSPATH=.:${CLASSPATH}
java -cp ${CLASSPATH} main方法所在包名.main方法所在的類(lèi)名
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 基于Java的打包jar、war、ear包的作用與區(qū)別詳解
- mysql-connector-java.jar包的下載過(guò)程詳解
- IntelliJ IDEA引入第三方j(luò)ar包或查看Java源碼的時(shí)候報(bào)decompiled.class file bytecode version:52.0(java 8)錯(cuò)誤的解決辦法
- java命令執(zhí)行jar包的多種方法(四種方法)
- java打包成可執(zhí)行的jar或者exe的詳細(xì)步驟
- idea中將單個(gè)java類(lèi)導(dǎo)出為jar包文件的方法
- 在eclipse導(dǎo)入Java的jar包的方法JDBC(圖文說(shuō)明)
- 將java程序打成jar包在cmd命令行下執(zhí)行的方法
- java使用命令行打包JAR
- 一鍵打包壓縮,Java項(xiàng)目變身JAR
相關(guān)文章
解決SpringBoot在IDEA中熱部署失效問(wèn)題
熱部署是指程序運(yùn)行過(guò)程中實(shí)時(shí)更新或替換其組件的技術(shù),即項(xiàng)目正在啟動(dòng)中,修改了配置文件中某個(gè)值或者添加了某個(gè)方法或者修改了某個(gè)方法參數(shù),本文給大家介紹了解決SpringBoot在IDEA中熱部署失效問(wèn)題,需要的朋友可以參考下2024-01-01
Java設(shè)計(jì)模式之策略模式詳細(xì)解析
這篇文章主要介紹了Java設(shè)計(jì)模式之策略模式詳細(xì)解析,策略模式中,定義算法族,分別封裝起來(lái),讓他們之間可以相互轉(zhuǎn)化,此模式讓算法的變化獨(dú)立于使用算法的客戶,需要的朋友可以參考下2023-11-11
ArrayList在for循環(huán)中使用remove方法移除元素方法介紹
這篇文章主要介紹了ArrayList在for循環(huán)中使用remove方法移除元素的內(nèi)容,介紹了具體代碼實(shí)現(xiàn),需要的朋友可以參考下。2017-09-09
JavaEE7+Websockets+GlassFish4打造聊天室
Java EE 7已經(jīng)發(fā)布很久了,新增加了很多新的功能和特性,如新增或更新了不少的JSR標(biāo)準(zhǔn)。其中特別受到關(guān)注的是Websockets。它的一個(gè)好處之一是減少了不必要的網(wǎng)絡(luò)流量。它主要是用于在客戶機(jī)和服務(wù)器之間建立單一的雙向連接。2015-09-09
SpringBoot使用itext填充pdf表單及導(dǎo)出pdf的流程
由于最近開(kāi)發(fā)的項(xiàng)目需要用到打印單據(jù),就在網(wǎng)上找了一下方案,反反復(fù)復(fù),都沒(méi)有找到合適的,借鑒了網(wǎng)上資源,使用itext5、itext7的工具包,所以本文介紹了SpringBoot使用itext填充pdf表單及導(dǎo)出pdf的流程,需要的朋友可以參考下2024-09-09
Jmeter使用接口傳遞數(shù)據(jù)過(guò)程圖解
這篇文章主要介紹了Jmeter使用接口傳遞數(shù)據(jù)過(guò)程圖解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05

