数据采集 ETL 工具 Elasticsearch-datatran v6.3.7 发布

数据采集ETL工具 Elasticsearch-datatran v6.3.7 发布

Elasticsearch-datatran 由 bboss 开源的数据采集同步ETL工具,提供数据采集、数据处理和数据入库功能。支持在Elasticsearch、关系数据库(mysql,oracle,db2,sqlserver、达梦等)、Mongodb、HBase、Hive、Kafka、文本文件、SFTP/FTP多种数据源之间进行海量数据采集同步;支持本地/ftp日志文件实时增量采集到kafka/elasticsearch/database;支持根据字段进行数据记录切割;支持根据文件路径信息将不同文件数据写入不同的数据库表

提供自定义处理采集数据功能,可以按照自己的要求将采集的数据处理到目的地,支持数据来源包括:database,elasticsearch,kafka,mongodb,hbase,file,ftp等,想把采集的数据保存到什么地方,由自己实现CustomOutPut接口处理即可。

Elasticsearch版本兼容性:支持各种Elasticsearch版本(1.x,2.x,5.x,6.x,7.x,+)之间相互数据迁移

v6.3.7 变更记录

  1. elasticsearch客户端改进:多数据源支持数据源引用功能,如果两个数据源都指向同一个数据源,则可以将第二个数据源指向第一个数据源,配置示例:

普通项目

elasticsearch.referExternal=default

spring boot项目

spring.elasticsearch.bboss.elasticsearch.referExternal=default
  1. 数据源同步改进:增加自定义定时同步调度机制,可以指定作业执行的时间段(支持指定多个时间段)和忽略执行时间段(支持指定多个时间段),使用案例:
        //定时任务配置,
        importBuilder.setScheduleSelf()//使用bboss自带的定时器,bboss timer
                .setDeyLay(1000L) // 任务延迟执行deylay毫秒后执行
                .setPeriod(1*60*1000l)//每隔period毫秒执行,如果不设置,只执行一次
                .addScanNewFileTimeRange("12:37-23:59");//添加每天调度执行的时间段,可以调用多次addScanNewFileTimeRange方法添加多个时间段
                //添加每天排除的时间段(不调度执行作业),可以调用多次addSkipScanNewFileTimeRange方法添加多个时间段,设置addScanNewFileTimeRange,则SkipScanNewFileTimeRange不起作用
//                .addSkipScanNewFileTimeRange("11:30-13:00");
        //定时任务配置结束

如果是Filelog插件,还需要额外指定:

        FileImportConfig config = new FileImportConfig();
        /**
        * 设置是否采用外部新文件扫描调度机制:bboss timer,jdk timer,quartz,xxl-job
        * true 采用,false 不采用,默认false
        */
        config.setUseETLScheduleForScanNewFile(true);        
  1. 在任务CallInterceptor.preCall中,可以根据taskContext中对应的不同的文件指定不同数据库添加、修改、删除sql,使用参考案例:

    //导出到数据源配置
         DBConfigBuilder dbConfigBuilder = new DBConfigBuilder();
         dbConfigBuilder
                 .setSqlFilepath("sql-dbtran.xml")//指定sql配置文件地址
                 .setTargetDbName("test");//指定目标数据库,在application.properties文件中配置
    
         importBuilder.setOutputDBConfig(dbConfigBuilder.buildDBImportConfig());
         importBuilder.addCallInterceptor(new CallInterceptor() {
             @Override
             public void preCall(TaskContext taskContext) {
                 FileTaskContext fileTaskContext = (FileTaskContext)taskContext;
                 String filePath = fileTaskContext.getFileInfo().getOriginFilePath();
                 /**
                  * 根据文件名称指定插入数据库的sql语句
                  */
                 if(filePath.endsWith("metrics-report.log")) {
                     DBConfigBuilder dbConfigBuilder = new DBConfigBuilder();
                     dbConfigBuilder.setInsertSqlName("insertSql");//指定新增的sql语句名称,在配置文件中配置:sql-dbtran.xml
    
                     taskContext.setDbmportConfig(dbConfigBuilder.buildDBImportConfig());
                 }
             }
    
             @Override
             public void afterCall(TaskContext taskContext) {
    
             }
    
             @Override
             public void throwException(TaskContext taskContext, Exception e) {
    
             }
         });

采集日志文件自定义处理案例

bboss数据采集ETL案例大全

https://esdoc.bbossgroups.com/#/bboss-datasyn-demo

优秀的个人博客,低调大师

微信关注我们

原文链接:https://www.oschina.net/news/167208/elasticsearch-datatran-6-3-7-released

转载内容版权归作者及来源网站所有!

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

相关文章

发表评论

资源下载

更多资源
优质分享Android(本站安卓app)

优质分享Android(本站安卓app)

近一个月的开发和优化,本站点的第一个app全新上线。该app采用极致压缩,本体才4.36MB。系统里面做了大量数据访问、缓存优化。方便用户在手机上查看文章。后续会推出HarmonyOS的适配版本。

Mario,低调大师唯一一个Java游戏作品

Mario,低调大师唯一一个Java游戏作品

马里奥是站在游戏界顶峰的超人气多面角色。马里奥靠吃蘑菇成长,特征是大鼻子、头戴帽子、身穿背带裤,还留着胡子。与他的双胞胎兄弟路易基一起,长年担任任天堂的招牌角色。

Oracle Database,又名Oracle RDBMS

Oracle Database,又名Oracle RDBMS

Oracle Database,又名Oracle RDBMS,或简称Oracle。是甲骨文公司的一款关系数据库管理系统。它是在数据库领域一直处于领先地位的产品。可以说Oracle数据库系统是目前世界上流行的关系数据库管理系统,系统可移植性好、使用方便、功能强,适用于各类大、中、小、微机环境。它是一种高效率、可靠性好的、适应高吞吐量的数据库方案。

Sublime Text 一个代码编辑器

Sublime Text 一个代码编辑器

Sublime Text具有漂亮的用户界面和强大的功能,例如代码缩略图,Python的插件,代码段等。还可自定义键绑定,菜单和工具栏。Sublime Text 的主要功能包括:拼写检查,书签,完整的 Python API , Goto 功能,即时项目切换,多选择,多窗口等等。Sublime Text 是一个跨平台的编辑器,同时支持Windows、Linux、Mac OS X等操作系统。