主頁 > 知識庫 > Linux使用crontab運行Java程序定時任務(wù)代碼解析

Linux使用crontab運行Java程序定時任務(wù)代碼解析

熱門標簽:哪種品牌的400電話申請 旅游路書地圖標注 適用的400電話辦理 iphone地圖標注我的店鋪 百度ai電銷機器人排名 ai智能外呼系統(tǒng)是什么 廣東電話機器人開戶 百度地圖地圖標注客服多少 成都米蘭申請

簡介 

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運行:

crontab crontab.txt

到這里設(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)專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!

標簽:陜西 玉林 紹興 大連 汕頭 泰安 遼陽 茂名

巨人網(wǎng)絡(luò)通訊聲明:本文標題《Linux使用crontab運行Java程序定時任務(wù)代碼解析》,本文關(guān)鍵詞  Linux,使用,crontab,運行,Java,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Linux使用crontab運行Java程序定時任務(wù)代碼解析》相關(guān)的同類信息!
  • 本頁收集關(guān)于Linux使用crontab運行Java程序定時任務(wù)代碼解析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章