kettle源码分析之4 osgi与插件开发

2024-09-02 12:18

本文主要是介绍kettle源码分析之4 osgi与插件开发,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 简介
  • 使用
    • 注册
    • 查找服务
  • 插件
    • 数据库插件
    • step
    • job

https://wiki.pentaho.com/display/EAI/OSGI+in+Kettle

https://www.oreilly.com/library/view/building-modular-cloud/9781449345143/

简介

对于kettle的插件系统可以看一下上面连接的文档。大意是:kettle引入OSGI来消除xml配置的内置插件和基于注解/xml的jar插件,尽可能的减少制定代码。

OSGi并不是一个新技术,eclipse就是一个非常好的范例。不过kettle的OSGi实践中并没有完全使用现有的标准技术。

使用

注册

PluginTracker.getInstance().registerPluginClass(Class);
// 添加监听器
PluginTracker.getInstance().addPluginLifecycleListener(Class, PluginLifecycleListener)

通过插件类型能够找到Services和Bean

查找服务

需要注意的是服务应该是无状态的,避免共同引用一个服务造成属性混淆。

PluginTracker.getInstance().getServiceObject(Class serviceClassType, Map serviceProps, [optional] boolean doProxy);

默认情况下Services是被代理的,并有个动态生命周期。一个bundle服务可以被停止,重启或者被替换。

PluginTracker.getInstance().addServiceReferenceListener(Object serviceObject, ServiceReferenceListener listener);

从插件中获取bean实例有2种方式:

  • 提供可以定位BeanFactory的may如 pluginID
  • 通过来自这个bundle中的service实例获取
PluginTracker.getInstance().getBean(Class beanType, Map beanFactoryProps, String beanID);
PluginTracker.getInstance().getBean(Class beanType, Object serviceObject, String beanID);

知道了如何从kettle中获取bean,那么下面开始进入到最关心的问题如何进行插件开发:

插件

为了实现一个kettle插件,最起码需要实现4个接口:

StepMetaInterface: it defines the metadata and takes care of XML representation, saving loading from/to repository, checks, etc.
StepInterface: makes the step execute: inherit from BaseStep to make your life easier.
StepDataInterface: holds open cursors, resultsets, files, etc.
StepDialogInterface: GUI/dialog code to edit the meta-data

类名最好按照kettle的规范,元数据类Meta结束,对话框以Dialog结束,并且有相同的前缀。
创建插件:

  • 文件夹:plugins/transformations/steps/SomePlugin.
  • 创建文件:someplugin.jar, plugin.xml, someplugin.png
  • debug插件

启动Spoon,添加:-Xdebug -Xnoagent -Djava.compiler=NONE -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=1044
IDE创建一个remote configuration

在这里插入图片描述

数据库插件

作用:

  • 构建连接字符串
  • 将连接设置给JDBC
  • 创建SQL方言
  • 检测JDBC驱动的特殊能力和限制

在这里插入图片描述

step

job

这篇关于kettle源码分析之4 osgi与插件开发的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1129930

相关文章

Olingo分析和实践之EDM 辅助序列化器详解(最佳实践)

《Olingo分析和实践之EDM辅助序列化器详解(最佳实践)》EDM辅助序列化器是ApacheOlingoOData框架中无需完整EDM模型的智能序列化工具,通过运行时类型推断实现灵活数据转换,适用... 目录概念与定义什么是 EDM 辅助序列化器?核心概念设计目标核心特点1. EDM 信息可选2. 智能类

Olingo分析和实践之OData框架核心组件初始化(关键步骤)

《Olingo分析和实践之OData框架核心组件初始化(关键步骤)》ODataSpringBootService通过初始化OData实例和服务元数据,构建框架核心能力与数据模型结构,实现序列化、URI... 目录概述第一步:OData实例创建1.1 OData.newInstance() 详细分析1.1.1

Olingo分析和实践之ODataImpl详细分析(重要方法详解)

《Olingo分析和实践之ODataImpl详细分析(重要方法详解)》ODataImpl.java是ApacheOlingoOData框架的核心工厂类,负责创建序列化器、反序列化器和处理器等组件,... 目录概述主要职责类结构与继承关系核心功能分析1. 序列化器管理2. 反序列化器管理3. 处理器管理重要方

Spring Boot Maven 插件如何构建可执行 JAR 的核心配置

《SpringBootMaven插件如何构建可执行JAR的核心配置》SpringBoot核心Maven插件,用于生成可执行JAR/WAR,内置服务器简化部署,支持热部署、多环境配置及依赖管理... 目录前言一、插件的核心功能与目标1.1 插件的定位1.2 插件的 Goals(目标)1.3 插件定位1.4 核

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种

解决1093 - You can‘t specify target table报错问题及原因分析

《解决1093-Youcan‘tspecifytargettable报错问题及原因分析》MySQL1093错误因UPDATE/DELETE语句的FROM子句直接引用目标表或嵌套子查询导致,... 目录报js错原因分析具体原因解决办法方法一:使用临时表方法二:使用JOIN方法三:使用EXISTS示例总结报错原

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

java使用protobuf-maven-plugin的插件编译proto文件详解

《java使用protobuf-maven-plugin的插件编译proto文件详解》:本文主要介绍java使用protobuf-maven-plugin的插件编译proto文件,具有很好的参考价... 目录protobuf文件作为数据传输和存储的协议主要介绍在Java使用maven编译proto文件的插件