java调用kettle_导入jar包(1)
版权声明:本文为博主原创文章,未经博主允许不得转载。
Java调用Kettle执行任务或转换,需要使用Kettle中的jar,可以先导入lib目录中的几个基本的jar,如:kettle-core.jar、kettle-db.jar、kettle-engine.jar ,其它jar根据情况进行添加,所需的jar在<kettle-home>\lib、<kettle-home>\libext下面都可以找到,本示例引用的jar如下图:


之后编写代码测试Java调用,调用前先使用Kettle的设计器设计了一个转换,取名为voucher.ktr。另外,本示例使用的是Kettle3.2的版本,据说4.1版本调用方法会有不同。
- import org.pentaho.di.core.database.DatabaseMeta;
- import org.pentaho.di.core.exception.KettleException;
- import org.pentaho.di.core.logging.LogWriter;
- import org.pentaho.di.core.util.EnvUtil;
- import org.pentaho.di.job.Job;
- import org.pentaho.di.job.JobEntryLoader;
- import org.pentaho.di.job.JobMeta;
- import org.pentaho.di.repository.Repository;
- import org.pentaho.di.repository.RepositoryDirectory;
- import org.pentaho.di.repository.RepositoryMeta;
- import org.pentaho.di.repository.UserInfo;
- import org.pentaho.di.trans.StepLoader;
- import org.pentaho.di.trans.Trans;
- import org.pentaho.di.trans.TransMeta;
- /**
- * Java调用Kettle示例代码
- *
- * @author 李文锴
- * @since 2012-8-14 下午03:50:00
- *
- */
- public class KettleTest {
- public static void main(String[] args) throws KettleException {
- String filename = "voucher.ktr";
- // callNativeTrans(filename);
- // executeTrans();
- // executeJobs();
- callNativeTransWithParam(filename);
- System.out.println("ok");
- }
- /**
- * 调用本地的转换文件
- *
- * @Description:
- * @param transFileName
- * @throws KettleException
- * @author 李文锴
- * @since:2012-8-15 下午02:58:41
- */
- public static void callNativeTrans(String transFileName) throws KettleException {
- // 初始化
- EnvUtil.environmentInit();
- StepLoader.init();
- // 转换元对象
- TransMeta transMeta = new TransMeta(transFileName);
- // 转换
- Trans trans = new Trans(transMeta);
- // 执行转换
- trans.execute(null);
- // 等待转换执行结束
- trans.waitUntilFinished();
- }
- /**
- * 调用本地的转换文件(带参数)
- *
- * @Description:
- * @param transFileName
- * @throws KettleException
- * @author 李文锴
- * @since:2012-8-15 下午02:58:54
- */
- public static void callNativeTransWithParam(String transFileName) throws KettleException {
- // 初始化
- EnvUtil.environmentInit();
- StepLoader.init();
- // 转换元对象
- TransMeta transMeta = new TransMeta(transFileName);
- // 转换
- Trans trans = new Trans(transMeta);
- String[] params = {};
- // 执行转换
- trans.execute(params);
- // 等待转换执行结束
- trans.waitUntilFinished();
- }
- /**
- * 执行存储在数据库资源库中的转换
- *
- * @Description:
- * @throws KettleException
- * @author 李文锴
- * @since:2012-8-15 下午02:59:14
- */
- public static void executeTrans() throws KettleException {
- // 初始化
- EnvUtil.environmentInit();
- StepLoader.init();
- // 日志
- LogWriter log = LogWriter.getInstance("TransTest.log", true, LogWriter.LOG_LEVEL_DEBUG);
- // 用户
- UserInfo userInfo = new UserInfo();
- userInfo.setLogin("admin");
- userInfo.setPassword("admin");
- // 数据库连接元对象(连接名称,不必与kettle中配置的保持一致:数据库类型:连接方式(kettle支持的连接方式):资源库IP:资源库实例名:资源库端口:资源库用户名:资源库用户密码)
- DatabaseMeta connection = new DatabaseMeta("", "Oracle", "Native", "192.168.3.232", "NSDEV", "1521", "nstcsa3441", "671468");
- // 资源库元对象
- RepositoryMeta repinfo = new RepositoryMeta();
- repinfo.setConnection(connection);
- // 资源库
- Repository rep = new Repository(log, repinfo, userInfo);
- // 连接资源库
- rep.connect("");
- // 资源库目录对象
- RepositoryDirectory dir = new RepositoryDirectory(rep);
- // 转换元对象
- TransMeta transMeta = new TransMeta(rep, "凭证(N9->EVC2)", dir);
- // 转换
- Trans trans = new Trans(transMeta);
- // 执行转换
- trans.execute(null);
- // 等待转换执行结束
- trans.waitUntilFinished();
- }
- /**
- * 执行本地的任务文件
- *
- * @Description:
- * @param jobFileName
- * @throws KettleException
- * @author 李文锴
- * @since:2012-8-15 下午02:59:34
- */
- public static void callNativeJob(String jobFileName) throws KettleException {
- // 初始化
- EnvUtil.environmentInit();
- JobEntryLoader.init();
- StepLoader.init();
- // 日志
- LogWriter log = LogWriter.getInstance("TransTest.log", true, LogWriter.LOG_LEVEL_DETAILED);
- // job元对象
- JobMeta jobMeta = new JobMeta(log, jobFileName, null);
- // job
- Job job = new Job(log, StepLoader.getInstance(), null, jobMeta);
- jobMeta.setInternalKettleVariables(job);
- // 执行job
- job.execute();
- // 等待job执行结束
- job.waitUntilFinished();
- }
- /**
- * 执行数据库资源库中的任务
- *
- * @Description:
- * @throws KettleException
- * @author 李文锴
- * @since:2012-8-15 下午02:59:45
- */
- public static void executeJobs() throws KettleException {
- // 初始化
- EnvUtil.environmentInit();
- JobEntryLoader.init();
- StepLoader.init();
- // 日志
- LogWriter log = LogWriter.getInstance("TransTest.log", true, LogWriter.LOG_LEVEL_DETAILED);
- // 用户
- UserInfo userInfo = new UserInfo();
- userInfo.setLogin("admin");
- userInfo.setPassword("admin");
- // 数据库连接元对象
- DatabaseMeta connection = new DatabaseMeta("", "Oracle", "Native", "192.168.3.232", "NSDEV", "1521", "nstcsa3441", "671468");
- // 资源库元对象
- RepositoryMeta repinfo = new RepositoryMeta();
- repinfo.setConnection(connection);
- // 资源库
- Repository rep = new Repository(log, repinfo, userInfo);
- // 连接资源库
- rep.connect("");
- // 资源库目录对象
- RepositoryDirectory dir = new RepositoryDirectory(rep);
- // 步骤加载对象
- StepLoader steploader = StepLoader.getInstance();
- // job元对象
- JobMeta jobmeta = new JobMeta(log, rep, "4.账户每日余额", dir);
- // job
- Job job = new Job(log, steploader, rep, jobmeta);
- // 执行job
- job.execute();
- // 等待job执行结束
- job.waitUntilFinished();
- }
- }
本示例只能实现一次调用,暂时不知道如何通过API设定运行时间,但可以结合spring和Quartz,设定定时调度,以便实现调度目标。
来源:http://blog.csdn.net/scorpio3k/article/details/7869196
java调用kettle_导入jar包(1)的更多相关文章
- 分享:根据webservice WSDL地址自动生成java调用代码及JAR包
分享:根据webservice WSDL地址自动生成java调用代码及JAR包使用步骤:一.安装java 并配置JAVA_HOME 及 path二.安装ANT 并配置ANT_HOME三.解压WsdlT ...
- 在java工程中导入jar包的注意事项
在java工程中导入jar包后一定要bulid path,不然jar包不可以用.而在java web工程中导入jar包后可以不builld path,但最好builld path.
- java项目(java project)如何导入jar包的解决方案列表
右键项目-properties-java build path(左侧菜单)-选择libraries 有两种方式,导入jar包实际上就是建立一种链接,并不是copy式的导入 一.导入外部包,add ex ...
- eclipse项目(java project)如何导入jar包的解决方案列表?
右键项目-properties-java build path(左侧菜单)-选择libraries 有两种方式,导入jar包实际上就是建立一种链接,并不是copy式的导入 一.导入外部包,add ex ...
- Idea JAVA項目的导入JAR包和导出jar包
一.IDea项目中导入jar包 打开菜单project structure,然后选择modules/dependencies下选择右侧的+,选择jar包目录中的jar文件,导入 二.导出jar包 菜单 ...
- java maven项目 导入jar包注意
1.将jar 包放到lib目录下 2.build path 3.点击maven主项目右键选择properties 4.选择myeclipse 下的第一个选项 5.点击add 选择archives ...
- java web工程导入jar包流程,容易犯错
1)首先把jar包拷贝到WEB-INF/lib下 2)在Eclipse中web/WEB-INF/lib路径下刷新.(省略此步骤就会找不到) 3)Java Build Path中Remove掉Web A ...
- java调用kettle_实现(2)
(1).参照“java调用kettle_导入jar包(1)”,应用etl工具下lib里的所有jar (2). 最近要对一个系统的数据同步到另一个系统中,要求新系统的数据结果完成之后,实时同步到另一个系 ...
- Android使用KSOAP2调用WebService及正确导入jar包的问题(转)
Android使用KSOAP2调用WebService及正确导入jar包的问题(转) 错误信息 最近在学Android使用KSOAP2调用现有的Webservice的方法,期间在网上找了很多代 ...
随机推荐
- 分享六个基于Bootstrap的实用开发教程和模板演示
关于Bootstrap,相信大家一定不陌生,它已经成为现在主流产业的一个重要工具,Bootstrap提供了优雅的HTML和CSS规范,它基于jQuery框架开发的,它在jQuery框架的基础上进行了更 ...
- java对象的强引用,软引用,弱引用和虚引用
1.强引用 以前我们使用的大部分引用实际上都是强引用,这是使用最普遍的引用.如果一个对象具有强引用,那就类似于必不可少的生活用品,垃圾回收器绝不会回收它.当内存空 间不足,Java虚拟机宁愿抛出Out ...
- 算法笔记_147:有向图欧拉回路判断应用(Java)
目录 1 问题描述 2 解决方案 1 问题描述 Description In order to make their sons brave, Jiajia and Wind take them t ...
- 算法笔记_023:拓扑排序(Java)
目录 1 问题描述 2 解决方案 2.1 基于减治法实现 2.2 基于深度优先查找实现 1 问题描述 给定一个有向图,求取此图的拓扑排序序列. 那么,何为拓扑排序? 定义:将有向图中的顶点以线性方式进 ...
- 43、Java动态代理一——动态类Proxy的使用
1.什么是动态代理? 答:动态代理可以提供对另一个对象的访问,同时隐藏实际对象的具体事实.代理一般会实现它所表示的实际对象的接口.代理可以访问实际对象,但是延迟实现实际对象的部分功能,实际对象实现系统 ...
- 基于olami开放语义平台的微信小程序遥知之源码实现
概述 实现一个智能生活信息查询的小秘书功能,支持查天气.新闻.日历.汇率.笑话.故事.百科.诗词.邮编.区号.菜谱.股票.节目预告,还支持闲聊.算24点.数学计算.单位换算.购物.搜索等功能. 使用方 ...
- jquery api 常见api 效果操作例子
addClass_removeClass_toggleClass_hasClass.html <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 ...
- 复制Map对象:Map.putAll方法
复制Map对象:Map.putAll方法 Map.putAll方法可以追加另一个Map对象到当前Map集合 package xmu.sxl; import java.util.HashMap; imp ...
- Spring boot 配置 swagger
1.maven配置包 <!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger2 --> <dep ...
- Tsung运行环境安装(转)
转自:http://www.cnblogs.com/tsbc/p/4272974.html#_Toc372013359 tsung Tsung运行环境安装 检查安装一下依赖包,以免在安装的时候报错.( ...