CN111737355A - 基于MongoDB元数据管理的异构数据源同步的方法及*** - Google Patents
基于MongoDB元数据管理的异构数据源同步的方法及*** Download PDFInfo
- Publication number
- CN111737355A CN111737355A CN202010616235.9A CN202010616235A CN111737355A CN 111737355 A CN111737355 A CN 111737355A CN 202010616235 A CN202010616235 A CN 202010616235A CN 111737355 A CN111737355 A CN 111737355A
- Authority
- CN
- China
- Prior art keywords
- data
- metadata
- mongodb
- information
- kudu
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/27—Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor
- G06F16/275—Synchronous replication
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/21—Design, administration or maintenance of databases
- G06F16/219—Managing data history or versioning
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/22—Indexing; Data structures therefor; Storage structures
- G06F16/2282—Tablespace storage structures; Management thereof
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/23—Updating
- G06F16/2365—Ensuring data consistency and integrity
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/54—Interprogram communication
- G06F9/546—Message passing systems or structures, e.g. queues
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2209/00—Indexing scheme relating to G06F9/00
- G06F2209/54—Indexing scheme relating to G06F9/54
- G06F2209/548—Queue
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Databases & Information Systems (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Data Mining & Analysis (AREA)
- Software Systems (AREA)
- Computer Security & Cryptography (AREA)
- Computing Systems (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本发明公开了一种基于MongoDB元数据管理的异构数据源同步的方法,包括:S1、扫描MySQL源数据端待同步表结构,初始化源端数据表的元数据信息;S2、基于扫描结果,在MongoDB数据库中构建一个通用的数据库元数据模型;S3、对MySQL数据库的binlog操作日志进行监听,解析操作日志后对数据操作行为进行区分,并进行后续处理;S4、获取分布式消息队列中待消费的数据变更信息;S5、根据数据变更信息,获取其涉及在MongoDB的元数据最新版本信息:S6、根据MongoDB元数据信息和消息队列数据,实时转换构造Kudu的DML变更数据,并执行Kudu数据更新。本发明实现了关系型数据库MySQL与分布式列式数据库Kudu之间的数据实时同步问题,支持DML和DDL的数据操作变更,可维护不同历史版本的元数据结构信息。
Description
技术领域
本发明涉及信息技术领域,更具体地说,它涉及一种基于MongoDB元数据管理的异构数据源同步的方法及***。
背景技术
当前各个金融业务***生产数据库均为MySQL,为了应对大规模数据分析查询工作,需要将业务数据实时同步至查询性能更强,支持水平扩展、高可用、分布式的列式存储数据库Kudu上。但是目前比较成熟的数据同步方案,均是基于传统关系型数据库之间进行数据同步,如MySQL数据库的Canal框架和Oracle数据库的OGG组件。而传统关系型数据库与Hadoop平台分布式数据库这两类异构数据库之间的数据同步只支持增量数据同步,源端和目标端元数据必须完全一致时才可以进行,不支持DDL数据操作变更的同步,不支持DML数据操作的更新和删除同步,同步限制条件较高,不能涵盖业务***数据库的所有数据变更操作。
基于上述原因,亟需设计一种可以实现关系型数据库MySQL与分布式列式数据库Kudu之间的数据实时同步的方法。
发明内容
针对现有技术存在的不足,本发明的目的在于提供一种基于MongoDB元数据管理的异构数据源同步的方法及***,可以实现关系型数据库MySQL与分布式列式数据库Kudu之间的数据实时同步,并且可以管理维护不同历史版本的元数据结构信息。
为实现上述目的,本发明提供了如下技术方案:
基于MongoDB元数据管理的异构数据源同步的方法,其特征是,包括以下步骤:
S1、启动“元数据变更监听”服务,通过扫描MySQL源数据端待同步表结构,初始化源端数据表的元数据信息;
S2、基于步骤S1的扫描结果,“元数据变更监听”服务在MongoDB数据库中构建一个通用的数据库元数据模型;
S3、通过“变动数据捕获”服务,对MySQL数据库的binlog操作日志进行监听,解析操作日志后对数据操作行为进行区分为数据变更操作和数据结构变更操作,并根据不同的数据操作行为进行相应的处理;
S4、通过“数据处理单元”获取分布式消息队列中待消费的数据变更信息;
S5、根据步骤S4所获取的数据变更信息,“数据处理单元”获取其涉及在MongoDB的元数据最新版本信息:
S6、“数据处理单元”根据MongoDB元数据信息和消息队列数据,实时转换构造Kudu的DML变更数据,并执行Kudu数据更新。
作为优选方案:在S3步骤中,针对数据变更操作,将变更数据按照MongoDB存储元数据结构存序列化写入分布式消息队列中;针对元数据变更操作,只保留通用元数据变更操作,将元数据变更操作信息更新为MongoDB元数据模型最新版本。
作为优选方案:S5步骤中若该元数据信息不存在,则根据MongoDB最新版本创建Kudu元数据结构;若Kudu中存在该元数据信息,数据处理单元比对MongoDB和Kudu之间的元数据版本信息,如果Kudu元数据版本小于MongoDB所保留的最新版本,数据处理单元将更新Kudu元数据结构信息,以保持与MongoDB中元数据最新版本一致。
一种基于MongoDB元数据管理的异构数据源同步的***,其特征是,包括:
MySQL数据库;
Kudu数据库;
MongoDB数据库;
元数据变更监听模块,用于通过扫描MySQL源数据端待同步表结构,初始化源端数据表的元数据信息,并基于扫描结果在MongoDB数据库中构建一个通用的数据库元数据模型;
变动数据捕获模块,用于对MySQL数据库的binlog操作日志进行监听,解析操作日志后将数据操作行为区分数据变更操作(DML)和数据结构变更操作(DDL),并根据不同的数据操作行为进行相应的处理;
分布式消息队列,用于数据变更信息的写入;
数据处理模块,用过获取分布式消息队列中待消费的数据变更信息,并根据获得的数据变更信息获取其涉及在MongoDB的元数据最新版本信息。
作为优选方案:针对数据变更操作,变动数据捕获模块将变更数据按照MongoDB存储元数据结构存序列化写入分布式消息队列中;针对元数据变更操作,只保留通用元数据变更操作,将元数据变更操作信息更新为MongoDB元数据模型最新版本。
作为优选方案:数据处理模块在获取MongoDB的元数据最新版本信息时,若该元数据信息不存在,则根据MongoDB最新版本创建Kudu元数据结构,若Kudu中存在该元数据信息,数据处理单元比对MongoDB和Kudu之间的元数据版本信息,如果Kudu元数据版本小于MongoDB所保留的最新版本,数据处理单元将更新Kudu元数据结构信息,以保持与MongoDB中元数据最新版本一致;数据处理模块还用于根据MongoDB元数据信息和消息队列数据,实时转换构造Kudu的DML变更数据,并执行Kudu数据更新。
与现有技术相比,本发明的优点是:本发明提出的方法主要解决关系型数据库MySQL与分布式列式数据库Kudu之间的数据实时同步问题,包括支持DML和DDL的数据操作变更,并且可以管理维护不同历史版本的元数据结构信息。
附图说明
图1为实施例一中的方法的流程框图;
图2为实施例二中的***的示意图。
具体实施方式
实施例一:
参照图1,一种基于MongoDB元数据管理的异构数据源同步的方法,包括以下步骤:
S1、启动“元数据变更监听”服务,通过扫描MySQL源数据端待同步表结构,初始化源端数据表的元数据信息。
S2、基于步骤S1的扫描结果,“元数据变更监听”服务在MongoDB数据库中构建一个通用的数据库元数据模型(Metadata)。
S3、通过“变动数据捕获”服务,对MySQL数据库的binlog操作日志进行监听。解析操作日志后将数据操作行为区分数据变更操作(DML)和数据结构变更操作(DDL)。
a、针对数据变更操作,将变更数据按照MongoDB存储元数据结构存序列化写入分布式消息队列中。
b、针对元数据变更操作,只保留通用元数据变更操作,将元数据变更操作信息更新为MongoDB元数据模型最新版本。
S4、通过“数据处理单元”获取分布式消息队列中待消费的数据变更信息。
S5、根据步骤S4所获取的数据变更信息,“数据处理单元”获取其涉及在MongoDB的元数据最新版本信息:
Ⅰ、若该元数据信息不存在,则根据MongoDB最新版本创建Kudu元数据结构;
Ⅱ、若Kudu中存在该元数据信息,数据处理单元比对MongoDB和Kudu之间的元数据版本信息。如果Kudu元数据版本小于MongoDB所保留的最新版本,数据处理单元将更新Kudu元数据结构信息,以保持与MongoDB中元数据最新版本一致。
S6、“数据处理单元”根据MongoDB元数据信息和消息队列数据,实时转换构造Kudu的DML变更数据,并执行Kudu数据更新。
实施例二:
参照图2,一种基于MongoDB元数据管理的异构数据源同步的***,包括:
MySQL数据库;
Kudu数据库;
MongoDB数据库;
元数据变更监听模块,用于通过扫描MySQL源数据端待同步表结构,初始化源端数据表的元数据信息,并基于扫描结果在MongoDB数据库中构建一个通用的数据库元数据模型。
变动数据捕获模块,用于对MySQL数据库的binlog操作日志进行监听,解析操作日志后将数据操作行为区分数据变更操作(DML)和数据结构变更操作(DDL);针对数据变更操作,将变更数据按照MongoDB存储元数据结构存序列化写入分布式消息队列中;针对元数据变更操作,只保留通用元数据变更操作,将元数据变更操作信息更新为MongoDB元数据模型最新版本。
分布式消息队列,用于数据变更信息的写入;
数据处理模块,用过获取分布式消息队列中待消费的数据变更信息,并根据获得的数据变更信息获取其涉及在MongoDB的元数据最新版本信息,若该元数据信息不存在,则根据MongoDB最新版本创建Kudu元数据结构,若Kudu中存在该元数据信息,数据处理单元比对MongoDB和Kudu之间的元数据版本信息,如果Kudu元数据版本小于MongoDB所保留的最新版本,数据处理单元将更新Kudu元数据结构信息,以保持与MongoDB中元数据最新版本一致;数据处理模块还用于根据MongoDB元数据信息和消息队列数据,实时转换构造Kudu的DML变更数据,并执行Kudu数据更新。
以上所述仅是本发明的优选实施方式,本发明的保护范围并不仅局限于上述实施例,凡属于本发明思路下的技术方案均属于本发明的保护范围。应当指出,对于本技术领域的普通技术人员来说,在不脱离本发明原理前提下的若干改进和润饰,这些改进和润饰也应视为本发明的保护范围。
Claims (6)
1.基于MongoDB元数据管理的异构数据源同步的方法,其特征是,包括以下步骤:
S1、启动“元数据变更监听”服务,通过扫描MySQL源数据端待同步表结构,初始化源端数据表的元数据信息;
S2、基于步骤S1的扫描结果,“元数据变更监听”服务在MongoDB数据库中构建一个通用的数据库元数据模型;
S3、通过“变动数据捕获”服务,对MySQL数据库的binlog操作日志进行监听,解析操作日志后对数据操作行为进行区分为数据变更操作和数据结构变更操作,并根据不同的数据操作行为进行相应的处理;
S4、通过“数据处理单元”获取分布式消息队列中待消费的数据变更信息;
S5、根据步骤S4所获取的数据变更信息,“数据处理单元”获取其涉及在MongoDB的元数据最新版本信息:
S6、“数据处理单元”根据MongoDB元数据信息和消息队列数据,实时转换构造Kudu的DML变更数据,并执行Kudu数据更新。
2.根据权利要求1所述的基于MongoDB元数据管理的异构数据源同步的方法,其特征是:在S3步骤中,针对数据变更操作,将变更数据按照MongoDB存储元数据结构存序列化写入分布式消息队列中;针对元数据变更操作,只保留通用元数据变更操作,将元数据变更操作信息更新为MongoDB元数据模型最新版本。
3.根据权利要求1所述的基于MongoDB元数据管理的异构数据源同步的方法,其特征是:S5步骤中若该元数据信息不存在,则根据MongoDB最新版本创建Kudu元数据结构;若Kudu中存在该元数据信息,数据处理单元比对MongoDB和Kudu之间的元数据版本信息,如果Kudu元数据版本小于MongoDB所保留的最新版本,数据处理单元将更新Kudu元数据结构信息,以保持与MongoDB中元数据最新版本一致。
4.一种基于MongoDB元数据管理的异构数据源同步的***,其特征是,包括:
MySQL数据库;
Kudu数据库;
MongoDB数据库;
元数据变更监听模块,用于通过扫描MySQL源数据端待同步表结构,初始化源端数据表的元数据信息,并基于扫描结果在MongoDB数据库中构建一个通用的数据库元数据模型;
变动数据捕获模块,用于对MySQL数据库的binlog操作日志进行监听,解析操作日志后将数据操作行为区分数据变更操作(DML)和数据结构变更操作(DDL),并根据不同的数据操作行为进行相应的处理;
分布式消息队列,用于数据变更信息的写入;
数据处理模块,用过获取分布式消息队列中待消费的数据变更信息,并根据获得的数据变更信息获取其涉及在MongoDB的元数据最新版本信息。
5.根据权利要求4所述的基于MongoDB元数据管理的异构数据源同步的***,其特征是:针对数据变更操作,变动数据捕获模块将变更数据按照MongoDB存储元数据结构存序列化写入分布式消息队列中;针对元数据变更操作,只保留通用元数据变更操作,将元数据变更操作信息更新为MongoDB元数据模型最新版本。
6.根据权利要求4所述的基于MongoDB元数据管理的异构数据源同步的***,其特征是:数据处理模块在获取MongoDB的元数据最新版本信息时,若该元数据信息不存在,则根据MongoDB最新版本创建Kudu元数据结构,若Kudu中存在该元数据信息,数据处理单元比对MongoDB和Kudu之间的元数据版本信息,如果Kudu元数据版本小于MongoDB所保留的最新版本,数据处理单元将更新Kudu元数据结构信息,以保持与MongoDB中元数据最新版本一致;数据处理模块还用于根据MongoDB元数据信息和消息队列数据,实时转换构造Kudu的DML变更数据,并执行Kudu数据更新。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010616235.9A CN111737355B (zh) | 2020-06-29 | 2020-06-29 | 基于MongoDB元数据管理的异构数据源同步的方法及*** |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010616235.9A CN111737355B (zh) | 2020-06-29 | 2020-06-29 | 基于MongoDB元数据管理的异构数据源同步的方法及*** |
Publications (2)
Publication Number | Publication Date |
---|---|
CN111737355A true CN111737355A (zh) | 2020-10-02 |
CN111737355B CN111737355B (zh) | 2023-06-23 |
Family
ID=72653889
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010616235.9A Active CN111737355B (zh) | 2020-06-29 | 2020-06-29 | 基于MongoDB元数据管理的异构数据源同步的方法及*** |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN111737355B (zh) |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112559475A (zh) * | 2020-12-11 | 2021-03-26 | 上海哔哩哔哩科技有限公司 | 数据实时捕获和传输方法及*** |
CN113051347A (zh) * | 2021-03-25 | 2021-06-29 | 未鲲(上海)科技服务有限公司 | 异构数据库之间数据同步方法、***、设备及存储介质 |
CN113342578A (zh) * | 2021-06-28 | 2021-09-03 | 上海万向区块链股份公司 | 一种实现MySQL数据自由恢复的方法及*** |
CN114048193A (zh) * | 2022-01-12 | 2022-02-15 | 树根互联股份有限公司 | 一种数据管控方法、装置及计算机可读存储介质 |
CN115794827A (zh) * | 2022-11-29 | 2023-03-14 | 广发银行股份有限公司 | 一种数据表结构管理***和方法 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN105701181A (zh) * | 2016-01-06 | 2016-06-22 | 中电科华云信息技术有限公司 | 一种动态异构元数据获取方法及*** |
US20160306867A1 (en) * | 2015-04-16 | 2016-10-20 | Alibaba Group Holding Limited | System, method, and apparatus for synchronization among heterogeneous data sources |
CN107783975A (zh) * | 2016-08-24 | 2018-03-09 | 北京京东尚科信息技术有限公司 | 分布式数据库同步处理的方法和装置 |
US10459647B1 (en) * | 2017-03-02 | 2019-10-29 | Amazon Technologies, Inc. | Multiple storage class representation in versioned storage |
-
2020
- 2020-06-29 CN CN202010616235.9A patent/CN111737355B/zh active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20160306867A1 (en) * | 2015-04-16 | 2016-10-20 | Alibaba Group Holding Limited | System, method, and apparatus for synchronization among heterogeneous data sources |
CN105701181A (zh) * | 2016-01-06 | 2016-06-22 | 中电科华云信息技术有限公司 | 一种动态异构元数据获取方法及*** |
CN107783975A (zh) * | 2016-08-24 | 2018-03-09 | 北京京东尚科信息技术有限公司 | 分布式数据库同步处理的方法和装置 |
US10459647B1 (en) * | 2017-03-02 | 2019-10-29 | Amazon Technologies, Inc. | Multiple storage class representation in versioned storage |
Non-Patent Citations (1)
Title |
---|
王玉标;饶锡如;何盼;: "异构环境下数据库增量同步更新机制", 计算机工程与设计, no. 03 * |
Cited By (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112559475A (zh) * | 2020-12-11 | 2021-03-26 | 上海哔哩哔哩科技有限公司 | 数据实时捕获和传输方法及*** |
CN113051347A (zh) * | 2021-03-25 | 2021-06-29 | 未鲲(上海)科技服务有限公司 | 异构数据库之间数据同步方法、***、设备及存储介质 |
CN113051347B (zh) * | 2021-03-25 | 2024-03-29 | 未鲲(上海)科技服务有限公司 | 异构数据库之间数据同步方法、***、设备及存储介质 |
CN113342578A (zh) * | 2021-06-28 | 2021-09-03 | 上海万向区块链股份公司 | 一种实现MySQL数据自由恢复的方法及*** |
CN114048193A (zh) * | 2022-01-12 | 2022-02-15 | 树根互联股份有限公司 | 一种数据管控方法、装置及计算机可读存储介质 |
CN115794827A (zh) * | 2022-11-29 | 2023-03-14 | 广发银行股份有限公司 | 一种数据表结构管理***和方法 |
Also Published As
Publication number | Publication date |
---|---|
CN111737355B (zh) | 2023-06-23 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN111737355B (zh) | 基于MongoDB元数据管理的异构数据源同步的方法及*** | |
EP3602341B1 (en) | Data replication system | |
CN107273506B (zh) | 一种数据库多表联合查询的方法 | |
CN102129478B (zh) | 数据库同步方法及*** | |
CN112445863B (zh) | 一种数据实时同步方法及*** | |
CN104899295B (zh) | 一种异构数据源数据关联分析方法 | |
CN109558452B (zh) | 一种查询建表操作的同步方法 | |
CN110222237A (zh) | 数据库表和xml报文的转换方法及其*** | |
US20150169654A1 (en) | Managing time series databases | |
CN102291416A (zh) | 一种客户端与服务器端双向同步的方法及*** | |
CN111563130A (zh) | 一种基于区块链技术的数据可信数据治理方法和*** | |
CN104599032A (zh) | 一种面向资源管理的分布式内存电网构建方法及*** | |
CN104699723A (zh) | 数据交换适配器、异构***之间数据同步***和方法 | |
CN104216962A (zh) | 一种基于HBase的海量网管数据索引设计方法 | |
EP3872703A2 (en) | Method and device for classifying face image, electronic device and storage medium | |
CN104317957A (zh) | 一种报表处理的开放平台、***及报表处理方法 | |
CN110704442A (zh) | 一种大数据的实时获取方法及装置 | |
CN109491988B (zh) | 一种支持全量更新的数据实时关联方法 | |
CN104750849B (zh) | 用于维护基于树形结构的目录关系的方法和*** | |
CN107577809A (zh) | 离线小文件处理方法及装置 | |
CN107291938A (zh) | 订单查询***及方法 | |
CN111221967A (zh) | 一种基于区块链架构的语言数据分类存储*** | |
CN115658815A (zh) | 基于cdc实现的数据同步的方法 | |
CN110515955B (zh) | 数据的存储、查询方法、***、电子设备和存储介质 | |
CN113032368A (zh) | 一种数据迁移方法、装置、存储介质及平台 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |