簡介
Linux中,crontab的功能是十分強大的,能夠方便的調(diào)度程序的運行,甚至在很多時候能夠替代程序中的定時任務(wù)。
分析
它的命令格式和主要參數(shù)如下:
命令格式
crontab [-u user] [ -e | -l | -r ]
命令參數(shù)
-u user:用來設(shè)定某個用戶的crontab服務(wù);
file:file是命令文件的名字,表示將file做為crontab的任務(wù)列表文件并載入crontab。如果在命令行中沒有指定這個文件,>crontab命令將接受標準輸入(鍵盤)上鍵入的命令,并將它們載入crontab。
-e:編輯某個用戶的crontab文件內(nèi)容。如果不指定用戶,則表示編輯當(dāng)前用戶的crontab文件。
-l:顯示某個用戶的crontab文件內(nèi)容,如果不指定用戶,則表示顯示當(dāng)前用戶的crontab文件內(nèi)容。
-r:從/var/spool/cron目錄中刪除某個用戶的crontab文件,如果不指定用戶,則默認刪除當(dāng)前用戶的crontab文件。
-i:在刪除用戶的crontab文件時給確認提示。
圖片化格式說明:
本次因為需要推送一批數(shù)據(jù),簡單起見用Java寫了個jar程序,用命令行java -jar push.jar調(diào)用完事,但是數(shù)據(jù)是每天都要推送的,難道每天都要手工去執(zhí)行一下命令行?這顯然不切實際。
為了這么個小程序開發(fā)個定時任務(wù)也嫌麻煩,后來就想到了Linux系統(tǒng)的crontab,但是在使用過程中還是碰到了幾個問題,在此記錄一下。
實現(xiàn)
第一步,編寫start_pust.sh文件,內(nèi)容簡單如下:
#!/bin/bash
java -jar /home/liyd/push.jar
為了避免路徑問題引起的錯誤,這里使用了絕對路徑來保證執(zhí)行正確。
第二步,編寫crontab.txt文件,簡單的一行指定執(zhí)行時間:
34 1 * * * /home/liyd/start_push.sh
每天的1點34分調(diào)用push.jar。
最后指定crontab運行:
到這里設(shè)置就都完成了,按照我們的預(yù)想每天的1點34分就會執(zhí)行pust.jar推送數(shù)據(jù)。
再遇問題
可是事情往往不會按我們預(yù)想的發(fā)展,我們發(fā)現(xiàn)程序根本就沒有執(zhí)行,這是為什么呢?因為在這之前我用命令行直接./start_push.sh都是可以的呀。
只能查查資料了,發(fā)現(xiàn)網(wǎng)上也有很多人碰到這個問題,總結(jié)起來兩點:
一、路徑問題
二、環(huán)境變量問題
這里我為了避免出錯已經(jīng)使用了絕對路徑,那看來就是環(huán)境變量的問題了。
原來crontab并不會加載環(huán)境變量配置,需要我們在腳本中設(shè)置,Java程序沒有JDK等環(huán)境變量當(dāng)前不能運行了。
修改前面的start_push.sh腳本,加入profile文件的讀?。?/p>
#!/bin/bash
. /etc/profile
. ~/.bash_profile
java -jar /home/liyd/push.jar
到這里,程序能夠正常運行了,使用ps aux | grep java能夠看到執(zhí)行的進程,但是我的Java程序死活沒有日志輸出啊,查看我的日志配置:
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>
本來應(yīng)該是輸出到當(dāng)前項目的logs文件夾下的,這里初步估計應(yīng)該是${user.dir}這個變量又找不到了吧。
再次修改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運行Java程序定時任務(wù)代碼解析的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!