Skip to content

2.9_插件开发指引

lulu2panpan edited this page Dec 28, 2019 · 1 revision

开始该章节前,请先了解一下Datalink的插件机制:1.5深入插件,插件开发基本流程如下:

添加项目

  • 如果是reader插件,项目名称以"dl-worker-reader-"开头
  • 如果是writer插件,项目名称以"dl-worker-writer-"开头

  • 保证新添加的项目在dl-worker的pom文件中已经配上,如下所示:

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <parent>

      <groupId>com.ucar.datalink</groupId>
      <artifactId>datalink</artifactId>
      <version>0.0.1</version>
      <relativePath>../pom.xml</relativePath>
    

    </parent>

    <artifactId>dl-worker</artifactId> <packaging>pom</packaging> <name>worker module for datalink</name>

    <modules>

      <!--保证自己的模块在此处有对应配置-->
      <module>dl-worker-core</module>
      <module>dl-worker-reader-mysql</module>
      <module>dl-worker-writer-dummy</module>
      <module>dl-worker-writer-rdbms</module>
      <module>dl-worker-reader-dummy</module>
      <module>dl-worker-api</module>
    

    </modules>

    </project>


配置pom文件

  • 在pom文件中增加对dl-worker-api模块的依赖(注:除了这个模块,不要再添加对其它datalink模块的依赖,否则将对打包产生影响,此模块已经间接把其它datalink模块引进来了

    <dependency>

    <groupId>com.ucar.datalink</groupId>
    <artifactId>dl-worker-api</artifactId>
    <version>0.0.1</version><!--版本视具体情况而定-->
    

    </dependency>


  • 在pom文件中增加build配置,如下所示

    <build>

    <plugins>
        <plugin>
            <artifactId>maven-assembly-plugin</artifactId>
            <configuration>
                <descriptors>
                    <descriptor>src/main/assembly/package.xml</descriptor>
                </descriptors>
                <finalName>reader-mysql</finalName><!--将finalName替换为自己的插件名称即可-->
                <appendAssemblyId>false</appendAssemblyId>
                <outputDirectory>${project.parent.parent.build.directory}/dl-worker/plugin/reader
                </outputDirectory><!--根据插件类型设置,reader或者writer-->
            </configuration>
            <executions>
                <execution>
                    <phase>package</phase>
                    <goals>
                        <goal>single</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>
    </plugins>
    

    </build>


添加package文件

定义插件参数类

  • 在dl-domain模块中进行参数定义
    Reader插件,放到com.ucar.datalink.domain.plugin.reader包下面
    Writer插件,放到com.ucar.datalink.domain.plugin.writer包下面
  • 参数类需要继承自相关父类
    Reader参数类需要继承自com.ucar.datalink.domain.plugin.PluginReaderParameter
    Writer参数类需要继承自com.ucar.datalink.domain.plugin.PluginWriterParameter
    Reader和Writer参数都需要实现方法:initPluginName()、initPluginClass()和initSupportedSourceTypes()
    注:对于插件名称,如果是reader,插件名称必须以"reader-"开头,如果是writer,插件名称必须以"writer-"开头
    如下所示:

    public class RdbmsWriterParameter extends PluginWriterParameter {
    
    @Override
    public String initPluginName() {
        //返回插件名称,前面pom中的finalName和package中的id必须和此处的pluginName保持一致,如:
    	//return "writer-rdbms";
    }
    
    @Override
    public String initPluginClass() {
        //返回该插件对应的TaskReader或TaskWriter的类名称(全限定名),如:
    	//return "com.ucar.datalink.writer.rdbms.RdbmsTaskWriter";
    }
    
    @Override
    public Set<MediaSourceType> initSupportedSourceTypes() {
    	//返回该插件支持的数据源源类型,如:
        //return Sets.newHashSet(MediaSourceType.MYSQL, MediaSourceType.SQLSERVER);
    }
    

    }

  • 如果是Reader插件,还需要定义自己的Position类,用于保存数据同步位点信息,自定义的Position类需要继承自com.ucar.datalink.domain.Position

开发自己的TaskReader或TaskWriter

  • go!go!go!