MetaQ 简单使用(数据同步框架)

数据同步通用框架说明

框架说明


数据同步工具用来对两个系统或者多个系统的数据进行同步处理,框架能够实现项目开发人员只需配置两边系统需的业务数据,不需要关系数据是如何实现同步的,框架底层数据传输技术使用淘宝的开源框架metamorphosis简称metaQ,该框架是使用观察者的设计模式来处理数据的中间介,发送端只需将数据发送到服务器,接收端进行监听,一旦有新数据,就立刻可以接收到。

框架结构

 

 

系统常量中设置一些公用的常量,例如文件每次传输的大小,文件存放的路径,项目的路径等。

数据库工具类主要封装了一些基本的数据库操作。

业务枚举,主要包括数据传输方式,错误标记,业务类型,所属系统等等。

框架接口主要定义了一些针对框架配置进行处理的操作,例如获得标记池数据,打包数据等等。

MetaQ处理类,主要包含metaQ的实现方式-消息生产者、消息消费者。

定时服务程序,用来定时执行框架需要执行的操作。主要包括扫描标记池、监听服务端数据。
         业务线程,分为普通数据发送线程,文件发送线程,普通数据接收线程,文件接收线程

工具类,主要封装了一些常用的操作类,例如,文件处理类、json处理类,zip压缩解压处理类等。

 

详细说明

定时服务

 

用于定时执行需要实现的业务

 

分为数据发送线程、数据接收线程、文件发送线程、文件接收线程

 

数据发送线程

 

定时的从标记池中获取相应业务需要处理的数据,通过数据同步业务配置表中根据sql查出需要打包的数据,并根据规定打包格式进行打包发送数据,如果数据发送成功,更新标记池数据,该条记录设为已同步,否则,下次继续执行

 

数据接收线程


定时的从服务器中获取业务端发送成功的数据,进行解包处理,这里的接收线程属于监听线程,其中messge.getPartition().setAutoAck(false) 用来设置接收数据是否自动提交,如果自动提交,不论后面处理成功或者失败,都获取不到此条数据,如果为不自动提交,用户可以根据自己的需求来确定下次是否获取此条数据,这里准备设置为自动条件,错误数据进行日志记录。

 

文件发送线程

 

定时的从标记池中获取相应业务需要处理的数据,通过数据同步业务配置表中根据sql和模版配置查出需要传输的文件位置进行统一打包,并根据规定打包格式进行打包发送数据,数据发送采用已字节流的方式进行分块传输,如果数据发送成功,更新标记池数据,该条记录设为已同步,否则,下次继续执行

 

 

文件接收线程

 

定时的从服务器中获取业务端发送成功的数据,进行解包处理,这里的接收线程属于监听线程,其中messge.getPartition().setAutoAck(false) 用来设置接收数据是否自动提交,如果自动提交,不论后面处理成功或者失败,都获取不到此条数据,如果为不自动提交,用户可以根据自己的需求来确定下次是否获取此条数据,这里准备设置为自动条件,错误数据进行日志记录,文件接收采用追加写文件的方式,直至文件接收完毕再进行处理。

 

MetaQ 处理

普通生产者(Producer)

 

生产者可以向服务器中存在的任意topic中发送消息,供生产者使用,这里的sessionFactory和Producer建议使用单例,不然会出现问题

普通消费者(Consumer)

消费者可以从服务器上存在的topic中获取信息,这里使用的是异步获取,即获取完一条数据之后,如果客户端Consumer设置自动提交,下次获取,此条记录将获取不到,这里的sessionFactory和Consumer建议使用单例,不然会出现问题

文件生产者(FileProducer)

文件消费者(FileAsyncConsumer)

 

所需数据结构

标记池

存放业务端需同步的数据

日志表

记录接收错误数据

系统参数配置

用来通过业务端发送的业务ID来对业务端系统进行传输数据传输和处理,此表需对业务端数据库进行操作

业务参数配置

用来设置相应的系统业务是否需进行同步,并关联到metaQ相关配置

底层参数配置

用来配置metaQ相关配置,包括主题和分组

打包格式

1、普通同步数据

{sys:XXXX, type:XXXX, signId:XXXX,data[{XXX},{}…..]}

2、文件同步数据

{sys:XXXX, type:XXXX,signId:XXXX,data[{XXX},{}…..]}

错误数据处理

消费端接收的数据处理失败时,错误数据需进行日志记录,需要求发送端进行数据重传,具体操作为单独创建错误数据处理通道,进行错误信息的传输,实施类似普通消息的发送,接收。

1、  现在主要为通过SQL执行错误来判断数据的正确性

2、  后期可以考虑通过验证数据格式的正确性来判断


使用说明

MetaQ服务器部署

MetaQ是建立在zookeeper之上的中间介,所以要使用MetaQ,必须搭建zookeeper服务环境,从官网上下载安装程序包


直接解压文件到指定目录,执行bin目录下的zkServer.cmd,启动服务



MetaQ也一样,从官网上下载安装包


解压文件,执行bin目录下的metaServer.bat启动服务


MetaQ和zookeeper都包含windows和Linux的两个版本,目前最新版本必须使用JDK1.6版本。

 

具体的MetaQ 和zookeeper的相关配置需要参照官方文档

定时服务部署

系统完成后,将系统工程打包成相应的jar 文件,并使用bat文件进行项目的自动启用


定时服务使用

如果需要使用同步框架,用户需要将框架相关数据表导入系统(当然也可以采用其他方案),主要包含,业务参数配置表、数据同步配置表、数据标记池表和数据接收日志表

用户需配置业务参数配置表和数据同步配置表,并将需要传输的数据安装格式存入数据同步标记池中。业务参数配置中消息主题需要在服务端有相应的配置。

另外要根据MetaQ服务器存放的位置,相应的修改客户端的IP和端口

 


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

工作印记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值