kettle怎么复制资源库的job_Kettle:java调用资源库中job停止问题。

运行代码,job名为“Job测试01”可以跑起来。但是当我调用job.stop()或job.stopAll()无法停止该job,原因是代码里job重新new了一个,不再是原来的job,现在请教下,kettle是如何保存原先的job的,该怎么去停止该job。

public static void main(String[] args) {

try {

//初始化kettle环境

KettleEnvironment.init();

//创建资源库对象,此时的对象还是一个空对象

KettleDatabaseRepository repository = new KettleDatabaseRepository();

//创建资源库数据库对象,类似我们在spoon里面创建资源库

DatabaseMeta dataMeta = new DatabaseMeta("1111", "Oracle", "Native", "172.16.7.12", "datacache", "1521", "654321", "123456");

//资源库元对象,名称参数,id参数,描述等可以随便定义

KettleDatabaseRepositoryMeta kettleDatabaseMeta =   new KettleDatabaseRepositoryMeta("111", "111", "111",dataMeta);

//给资源库赋值

repository.init(kettleDatabaseMeta);

//连接资源库

repository.connect("admin","admin");

//根据变量查找到模型所在的目录对象,此步骤很重要。

RepositoryDirectoryInterface directory = repository.findDirectory("/");

//创建ktr元对象

JobMeta jobMeta = repository.loadJob("Job测试01", directory, null, null);

//创建ktr

Job job = new Job(repository, jobMeta);

System.out.println(job.getJobname()+job.getStatus());

//执行ktr

job.start();

//job.stop();

//等待执行完毕

//trans.waitUntilFinished();

job.waitUntilFinished();

if(job.getErrors()>0)

{

System.err.println("job run Failure!");

}

else

{

System.out.println("job run successfully!");

}

} catch (KettleException e) {

e.printStackTrace();

}

}

运行代码,job名为“Job测试01”可以跑起来。但是当我调用job.stop()或job.stopAll()无法停止该job,原因是代码里job重新new了一个,不再是原来的job,现在请教下,kettle是如何保存原先的job的,该怎么去停止该job。

2013年6月27日 11:05

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值