簡(jiǎn)介
Linux中,crontab的功能是十分強(qiáng)大的,能夠方便的調(diào)度程序的運(yùn)行,甚至在很多時(shí)候能夠替代程序中的定時(shí)任務(wù)。
分析
它的命令格式和主要參數(shù)如下:
命令格式
crontab [-u user] [ -e | -l | -r ]
命令參數(shù)
-u user:用來(lái)設(shè)定某個(gè)用戶(hù)的crontab服務(wù);
file:file是命令文件的名字,表示將file做為crontab的任務(wù)列表文件并載入crontab。如果在命令行中沒(méi)有指定這個(gè)文件,>crontab命令將接受標(biāo)準(zhǔn)輸入(鍵盤(pán))上鍵入的命令,并將它們載入crontab。
-e:編輯某個(gè)用戶(hù)的crontab文件內(nèi)容。如果不指定用戶(hù),則表示編輯當(dāng)前用戶(hù)的crontab文件。
-l:顯示某個(gè)用戶(hù)的crontab文件內(nèi)容,如果不指定用戶(hù),則表示顯示當(dāng)前用戶(hù)的crontab文件內(nèi)容。
-r:從/var/spool/cron目錄中刪除某個(gè)用戶(hù)的crontab文件,如果不指定用戶(hù),則默認(rèn)刪除當(dāng)前用戶(hù)的crontab文件。
-i:在刪除用戶(hù)的crontab文件時(shí)給確認(rèn)提示。
圖片化格式說(shuō)明:

本次因?yàn)樾枰扑鸵慌鷶?shù)據(jù),簡(jiǎn)單起見(jiàn)用Java寫(xiě)了個(gè)jar程序,用命令行java -jar push.jar調(diào)用完事,但是數(shù)據(jù)是每天都要推送的,難道每天都要手工去執(zhí)行一下命令行?這顯然不切實(shí)際。
為了這么個(gè)小程序開(kāi)發(fā)個(gè)定時(shí)任務(wù)也嫌麻煩,后來(lái)就想到了Linux系統(tǒng)的crontab,但是在使用過(guò)程中還是碰到了幾個(gè)問(wèn)題,在此記錄一下。
實(shí)現(xiàn)
第一步,編寫(xiě)start_pust.sh文件,內(nèi)容簡(jiǎn)單如下:
#!/bin/bash
java -jar /home/liyd/push.jar
為了避免路徑問(wèn)題引起的錯(cuò)誤,這里使用了絕對(duì)路徑來(lái)保證執(zhí)行正確。
第二步,編寫(xiě)crontab.txt文件,簡(jiǎn)單的一行指定執(zhí)行時(shí)間:
34 1 * * * /home/liyd/start_push.sh
每天的1點(diǎn)34分調(diào)用push.jar。
最后指定crontab運(yùn)行:
到這里設(shè)置就都完成了,按照我們的預(yù)想每天的1點(diǎn)34分就會(huì)執(zhí)行pust.jar推送數(shù)據(jù)。
再遇問(wèn)題
可是事情往往不會(huì)按我們預(yù)想的發(fā)展,我們發(fā)現(xiàn)程序根本就沒(méi)有執(zhí)行,這是為什么呢?因?yàn)樵谶@之前我用命令行直接./start_push.sh都是可以的呀。
只能查查資料了,發(fā)現(xiàn)網(wǎng)上也有很多人碰到這個(gè)問(wèn)題,總結(jié)起來(lái)兩點(diǎn):
一、路徑問(wèn)題
二、環(huán)境變量問(wèn)題
這里我為了避免出錯(cuò)已經(jīng)使用了絕對(duì)路徑,那看來(lái)就是環(huán)境變量的問(wèn)題了。
原來(lái)crontab并不會(huì)加載環(huán)境變量配置,需要我們?cè)谀_本中設(shè)置,Java程序沒(méi)有JDK等環(huán)境變量當(dāng)前不能運(yùn)行了。
修改前面的start_push.sh腳本,加入profile文件的讀取:
#!/bin/bash
. /etc/profile
. ~/.bash_profile
java -jar /home/liyd/push.jar
到這里,程序能夠正常運(yùn)行了,使用ps aux | grep java能夠看到執(zhí)行的進(jìn)程,但是我的Java程序死活沒(méi)有日志輸出啊,查看我的日志配置:
appender name="DEFAULT-APPENDER" class="org.apache.log4j.DailyRollingFileAppender">
param name="file" value="${user.dir}/logs/common-default.log"/>
param name="append" value="true"/>
param name="encoding" value="UTF-8"/>
layout class="org.apache.log4j.PatternLayout">
param name="ConversionPattern" value="[%x][%r][%p][%t] %d{HH:mm:ss,SSS} method:%l %m%n"/>
/layout>
/appender>
本來(lái)應(yīng)該是輸出到當(dāng)前項(xiàng)目的logs文件夾下的,這里初步估計(jì)應(yīng)該是${user.dir}這個(gè)變量又找不到了吧。
再次修改start_pust.sh文件,加入user.dir參數(shù):
#!/bin/bash
. /etc/profile
. ~/.bash_profile
java -Duser.dir="/home/liyd/" -jar /home/liyd/push.jar
到這里,終于一切正常!
以上就是腳本之家分享給大家的關(guān)于Linux使用crontab運(yùn)行Java程序定時(shí)任務(wù)代碼解析的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專(zhuān)題,如有不足之處,歡迎留言指出。感謝朋友們對(duì)本站的支持!