關於jobjava的信息

本文目錄一覽:

怎麼實現java簡單調用kettle我自己做好的job

怎麼實現java簡單調用kettle我自己做好的job

/**

* 本測試類慎用!!!!!!!

*

* @param args

*/

public static void main(String[] args) {

String datetime = “2014-12-19 23:20:45”;

String[] params = {“707”, datetime}; // 傳遞參數

String path = “F:\\job7.kjb”;

// runTransfer(params, path);

runJob(params, path);

// runJob();

// jbResource();

}

/**

* 運行轉換文件方法

* @param params 多個參數變數值

* @param ktrPath 轉換文件的路徑,後綴ktr

*/

public static void runTransfer(String[] params, String ktrPath) {

Trans trans = null;

try {

// // 初始化

// 轉換元對象

KettleEnvironment.init();// 初始化

EnvUtil.environmentInit();

TransMeta transMeta = new TransMeta(ktrPath);

// 轉換

trans = new Trans(transMeta);

// 執行轉換

trans.execute(params);

// 等待轉換執行結束

trans.waitUntilFinished();

// 拋出異常

if (trans.getErrors() 0) {

throw new Exception(

“There are errors during transformation exception!(傳輸過程中發生異常)”);

}

} catch (Exception e) {

e.printStackTrace();

}

}

/**

* java 調用 kettle 的job

*

* @param jobname

* 如: String fName= “D:\\kettle\\informix_to_am_4.ktr”;

*/

public static void runJob(String[] params, String jobPath) {

try {

KettleEnvironment.init();

// jobname 是Job腳本的路徑及名稱

JobMeta jobMeta = new JobMeta(jobPath, null);

Job job = new Job(null, jobMeta);

// 向Job 腳本傳遞參數,腳本中獲取參數值:${參數名}

// job.setVariable(paraname, paravalue);

job.setVariable(“id”, params[0]);

job.setVariable(“dt”, params[1]);

job.start();

job.waitUntilFinished();

if (job.getErrors() 0) {

throw new Exception(

“There are errors during job exception!(執行job發生異常)”);

}

} catch (Exception e) {

e.printStackTrace();

}

}

用java代碼 道怎樣停止一個運行的job,我發現沒法停掉它.只能把整個進程退出才行.

把job放到一個線程中,用一個成員變數控制線程的運行

public class MyThead implements Runnable{

private boolean flag = false;

public void run() {

//while(){ 反覆執行的程序

if(flag) //flag是開關,更改flag狀態控制線程是否運行

return;

// }

}

java中如何實現Job Scheduing

例如:

/**

* @author kevin zhou

*

* 在Java中實現Job Scheduling

* 創建日期 2004-7-13

*/

import java.util.TimerTask;

import java.util.Calendar;

import java.util.Date;

import java.util.Timer;

public class ReportGenerator extends TimerTask{

   /* (非 Javadoc)

    * @see java.util.TimerTask#run()

    */

   public void run() {

       System.out.println(“Generating report”);

}

}

class MainApplication {

 public static void main(String[] args) {

   Timer timer=new Timer();

   Calendar date = Calendar.getInstance();

   date.set(

     Calendar.DAY_OF_WEEK,

     Calendar.SUNDAY

   );

   date.set(Calendar.HOUR, 0);

   date.set(Calendar.MINUTE, 0);

   date.set(Calendar.SECOND, 0);

   date.set(Calendar.MILLISECOND, 0);

   // Schedule to run every Sunday in midnight

   timer.schedule(

     new ReportGenerator(),

     date.getTime(),

     1000 * 60 * 60 * 24 * 7

   );

 }

}

此處簡單解釋一下,在此例子中ReportGenerator繼承java.util.TimerTask,它又繼承了java.lang.Runnable,我們需要覆蓋run()方法。

調用時用schedule()方法讓它每周日0點0分執行,避開伺服器高峰,實現Job Scheduling的目的。

補充:Java是一種可以撰寫跨平台應用軟體的面向對象的程序設計語言。Java 技術具有卓越的通用性、高效性、平台移植性和安全性,廣泛應用於PC、數據中心、遊戲控制台、科學超級計算機、行動電話和互聯網,同時擁有全球最大的開發者專業社群。

java quartz job 執行時間配置

第一步:引包

要使用Quartz,必須要引入以下這幾個包:

1、log4j-1.2.16

2、quartz-2.1.7

3、slf4j-api-1.6.1.jar

4、slf4j-log4j12-1.6.1.jar

這些包都在下載的Quartz包裡面包含著,因此沒有必要為尋找這幾個包而頭疼。

第二步:創建要被定執行的任務類

這一步也很簡單,只需要創建一個實現了org.quartz.Job介面的類,並實現這個介面的唯一一個方法execute(JobExecutionContext arg0) throws JobExecutionException即可。如:

import java.text.SimpleDateFormat;

import java.util.Date;

import org.quartz.Job;

import org.quartz.JobExecutionContext;

import org.quartz.JobExecutionException;

public class myJob implements Job {

@Override

public void execute(JobExecutionContext arg0) throws JobExecutionException {

SimpleDateFormat sdf = new SimpleDateFormat(“yyyy-MM-dd HH:mm:ss SSS”);

System.out.println(sdf.format(new Date()));

}

}

import java.text.SimpleDateFormat;

import java.util.Date;

import org.quartz.Job;

import org.quartz.JobExecutionContext;

import org.quartz.JobExecutionException;

public class myJob implements Job {

@Override

public void execute(JobExecutionContext arg0) throws JobExecutionException {

SimpleDateFormat sdf = new SimpleDateFormat(“yyyy-MM-dd HH:mm:ss SSS”);

System.out.println(sdf.format(new Date()));

}

}

這個例子很簡單,就不用解說了。

第三步:創建任務調度,並執行

這一步應該算是最難的一步的,但其實是非常簡單的,直接上代碼

import static org.quartz.CronScheduleBuilder.cronSchedule;

import static org.quartz.JobBuilder.newJob;

import static org.quartz.TriggerBuilder.newTrigger;

import java.text.SimpleDateFormat;

import java.util.Date;

import org.quartz.CronTrigger;

import org.quartz.JobDetail;

import org.quartz.Scheduler;

import org.quartz.SchedulerFactory;

import org.quartz.impl.StdSchedulerFactory;

public class Test {

public void go() throws Exception {

// 首先,必需要取得一個Scheduler的引用

SchedulerFactory sf = new StdSchedulerFactory();

Scheduler sched = sf.getScheduler();

//jobs可以在scheduled的sched.start()方法前被調用

//job 1將每隔20秒執行一次

JobDetail job = newJob(myJob.class).withIdentity(“job1”, “group1”).build();

CronTrigger trigger = newTrigger().withIdentity(“trigger1”, “group1”).withSchedule(cronSchedule(“0/20 * * * * ?”)).build();

Date ft = sched.scheduleJob(job, trigger);

SimpleDateFormat sdf = new SimpleDateFormat(“yyyy-MM-dd HH:mm:ss SSS”);

System.out.println(job.getKey() + ” 已被安排執行於: ” + sdf.format(ft) + “,並且以如下重複規則重複執行: ” + trigger.getCronExpression());

// job 2將每2分鐘執行一次(在該分鐘的第15秒)

job = newJob(myJob.class).withIdentity(“job2”, “group1”).build();

trigger = newTrigger().withIdentity(“trigger2”, “group1”).withSchedule(cronSchedule(“15 0/2 * * * ?”)).build();

ft = sched.scheduleJob(job, trigger);

System.out.println(job.getKey() + ” 已被安排執行於: ” + sdf.format(ft) + “,並且以如下重複規則重複執行: “+ trigger.getCronExpression());

// 開始執行,start()方法被調用後,計時器就開始工作,計時調度中允許放入N個Job

sched.start();

try {

//主線程等待一分鐘

Thread.sleep(60L * 1000L);

} catch (Exception e) {}

//關閉定時調度,定時器不再工作

sched.shutdown(true);

}

public static void main(String[] args) throws Exception {

Test test = new Test();

test.go();

}

}

import static org.quartz.CronScheduleBuilder.cronSchedule;

import static org.quartz.JobBuilder.newJob;

import static org.quartz.TriggerBuilder.newTrigger;

import java.text.SimpleDateFormat;

import java.util.Date;

import org.quartz.CronTrigger;

import org.quartz.JobDetail;

import org.quartz.Scheduler;

import org.quartz.SchedulerFactory;

import org.quartz.impl.StdSchedulerFactory;

public class Test {

public void go() throws Exception {

// 首先,必需要取得一個Scheduler的引用

SchedulerFactory sf = new StdSchedulerFactory();

Scheduler sched = sf.getScheduler();

//jobs可以在scheduled的sched.start()方法前被調用

//job 1將每隔20秒執行一次

JobDetail job = newJob(myJob.class).withIdentity(“job1”, “group1”).build();

CronTrigger trigger = newTrigger().withIdentity(“trigger1”, “group1”).withSchedule(cronSchedule(“0/20 * * * * ?”)).build();

Date ft = sched.scheduleJob(job, trigger);

SimpleDateFormat sdf = new SimpleDateFormat(“yyyy-MM-dd HH:mm:ss SSS”);

System.out.println(job.getKey() + ” 已被安排執行於: ” + sdf.format(ft) + “,並且以如下重複規則重複執行: ” + trigger.getCronExpression());

// job 2將每2分鐘執行一次(在該分鐘的第15秒)

job = newJob(myJob.class).withIdentity(“job2”, “group1”).build();

trigger = newTrigger().withIdentity(“trigger2”, “group1”).withSchedule(cronSchedule(“15 0/2 * * * ?”)).build();

ft = sched.scheduleJob(job, trigger);

System.out.println(job.getKey() + ” 已被安排執行於: ” + sdf.format(ft) + “,並且以如下重複規則重複執行: “+ trigger.getCronExpression());

// 開始執行,start()方法被調用後,計時器就開始工作,計時調度中允許放入N個Job

sched.start();

try {

//主線程等待一分鐘

Thread.sleep(60L * 1000L);

} catch (Exception e) {}

//關閉定時調度,定時器不再工作

sched.shutdown(true);

}

public static void main(String[] args) throws Exception {

Test test = new Test();

test.go();

}

}

OK了,Job1和Job2就會被安排為定時執行了。此時程序是可以執行的了,但是可能會輸出WARN級別日誌,這是因為沒有加log4j的配置文件,加上配置文件,就OK了。這裡需要說明的地方只有一個,其它的可以直接Copy到您的項目裡面。看代碼:

CronTrigger trigger = newTrigger().withIdentity(“trigger1”, “group1”).withSchedule(cronSchedule(“0/20 * * * * ?”)).build();

CronTrigger trigger = newTrigger().withIdentity(“trigger1”, “group1”).withSchedule(cronSchedule(“0/20 * * * * ?”)).build();

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/283611.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-22 08:08
下一篇 2024-12-22 08:08

相關推薦

  • Java 監控介面返回信息報錯信息怎麼處理

    本文將從多個方面對 Java 監控介面返回信息報錯信息的處理方法進行詳細的闡述,其中包括如何捕獲異常、如何使用日誌輸出錯誤信息、以及如何通過異常處理機制解決報錯問題等等。以下是詳細…

    編程 2025-04-29
  • 使用Python爬蟲獲取電影信息的實現方法

    本文將介紹如何使用Python編寫爬蟲程序,來獲取和處理電影數據。需要了解基本的Python編程語言知識,並使用BeautifulSoup庫和Requests庫進行爬取。 一、準備…

    編程 2025-04-28
  • Python爬取網頁信息

    本文將從多個方面對Python爬取網頁信息做詳細的闡述。 一、爬蟲介紹 爬蟲是一種自動化程序,可以模擬人對網頁進行訪問獲取信息的行為。通過編寫代碼,我們可以指定要獲取的信息,將其從…

    編程 2025-04-28
  • 如何使用Python執行Shell命令並獲取執行過程信息

    本文將介紹如何使用Python執行Shell命令並獲取執行過程信息。我們將從以下幾個方面進行闡述: 一、執行Shell命令 Python內置的subprocess模塊可以方便地執行…

    編程 2025-04-28
  • Python實現身份信息模擬生成與查驗

    本文將從以下幾個方面對Python實現身份信息模擬生成與查驗進行詳細闡述: 一、身份信息生成 身份信息生成是指通過代碼生成符合身份信息規範的虛假數據。Python中,我們可以使用f…

    編程 2025-04-27
  • Dapper使用getschema獲取表信息

    本文旨在介紹Dapper中使用getschema獲取表信息的方法和注意事項。 一、獲取某張表的所有列信息 使用Dapper獲取某張表信息,可以使用 `IDbConnection.G…

    編程 2025-04-27
  • 已裝備我軍的空中信息化作戰平台

    本文將會從多個方面詳細闡述已裝備我軍的空中信息化作戰平台。 一、平台概述 已裝備我軍的空中信息化作戰平台是一個全新的作戰系統,具備實時數據採集、處理、分析、共享的能力。它可以在不同…

    編程 2025-04-27
  • 通過提交信息搜索-使用git

    本篇文章重點講解如何使用git通過提交信息來搜索。我們將從多個方面介紹如何使用git來搜索提交信息,並提供相應的代碼示例以供參考。 一、搜索方式 Git提供了三種搜索方式,分別為:…

    編程 2025-04-27
  • Linux查看系統信息

    一、CPU信息 Linux系統下,查看CPU的信息最常用的命令是lscpu。該命令可以顯示CPU架構、核心數量、線程數、緩存大小、CPU頻率等信息。例如: lscpu 該命令會輸出…

    編程 2025-04-24
  • 軟考 信息安全工程師

    軟考 信息安全工程師是一項技能型國家級資格認證考試,主要測試考生在信息安全領域的理論知識和實踐技能,是證明個人信息安全能力的重要證書。本文將從多個方面對軟考 信息安全工程師做詳細的…

    編程 2025-04-23

發表回復

登錄後才能評論