CN117851506A - 基于git的跨库同步方法、装置、电子设备及存储介质 - Google Patents

基于git的跨库同步方法、装置、电子设备及存储介质 Download PDF

Info

Publication number
CN117851506A
CN117851506A CN202311600444.4A CN202311600444A CN117851506A CN 117851506 A CN117851506 A CN 117851506A CN 202311600444 A CN202311600444 A CN 202311600444A CN 117851506 A CN117851506 A CN 117851506A
Authority
CN
China
Prior art keywords
library
synchronization
cross
source
target
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.)
Pending
Application number
CN202311600444.4A
Other languages
English (en)
Inventor
陈晓明
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
China Merchants Finance Technology Co Ltd
Original Assignee
China Merchants Finance Technology Co Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by China Merchants Finance Technology Co Ltd filed Critical China Merchants Finance Technology Co Ltd
Priority to CN202311600444.4A priority Critical patent/CN117851506A/zh
Publication of CN117851506A publication Critical patent/CN117851506A/zh
Pending legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/27Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor
    • G06F16/275Synchronous replication
    • YGENERAL 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
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE 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/00Energy efficient computing, e.g. low power processors, power management or thermal management

Landscapes

  • Engineering & Computer Science (AREA)
  • Databases & Information Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Computing Systems (AREA)
  • Data Mining & Analysis (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本发明涉及数据同步技术,揭露一种基于GIT的跨库同步方法,包括:响应源库与目标库的跨库同步请求,并获取源库地址、源库认证信息目标库地址及目标库认证信息;基于所述源库地址及所述源库认证信息构建预设的跨库同步程序与所述源库的第一同步连接,并基于所述目标库地址及所述目标库认证信息构建所述跨库同步程序与所述目标数据库的第二同步连接;循环获取所述源库的commit信息,基于获取的commit信息判断所述源库是否需要同步,当所述源库需要同步时,基于所述第一同步连接及所述第二同步连接,利用所述跨库同步程序执行源数据库及目标库间的跨库同步。本发明还提出一种基于GIT的跨库同步装置、设备以及介质。本发明可以提高基于GIT的跨库同步效率。

Description

基于GIT的跨库同步方法、装置、电子设备及存储介质
技术领域
本发明涉及数据同步技术,尤其涉及一种基于GIT的跨库同步方法、装置、电子设备及存储介质。
背景技术
为了在不同的代码仓库之间保持代码的一致性,方便协作和版本管理,常常需要在不同GIT仓库间进行跨库同步。
但是现有的GIT的跨库同步方法,无法监控待同步GIT仓库的变化情况及时进行同步,导致GIT仓库的跨库同步效率较低。
发明内容
本发明提供一种基于GIT的跨库同步方法、装置、电子设备及存储介质,其主要目的在于提高了基于GIT的跨库同步效率。
响应源库与目标库的跨库同步请求,并获取源库地址、源库认证信息目标库地址及目标库认证信息;
基于所述源库地址及所述源库认证信息构建预设的跨库同步程序与所述源库的第一同步连接,并基于所述目标库地址及所述目标库认证信息构建所述跨库同步程序与所述目标数据库的第二同步连接;
循环获取所述源库的commit信息,在每次获取所述源库的commit信息后,基于获取的commit信息判断所述源库是否需要同步,当所述源库需要同步时,基于所述第一同步连接及所述第二同步连接,利用所述跨库同步程序执行源数据库及目标库间的跨库同步。
可选地,所述基于获取的commit信息判断所述源库是否需要同步,包括:
判断获取的所有commit信息的数量是否为1;
当获取的所有commit信息的数量为1,则所述源库需要同步;
当获取的所有commit信息的数量不为1,判断最新获取的commit信息与上一次获取的commit信息是否一致;
若最新获取的commit信息与上一次获取的commit信息不一致,则所述源库需要同步;
若最新获取的commit信息与上一次获取的commit信息一致,则所述源库不需要同步。
可选地,所述基于所述第一同步连接及所述第二同步连接,利用所述跨库同步程序执行源数据库及目标库间的跨库同步,包括:
将所述源库中的内容通过所述第一同步连接发送至所述跨库同步程序,并将所述跨库同步程序接受的源库中的内容确定为中转同步内容;
通过所述第二同步连接将所述中转同步内容发送至所述目标库,以将所述中转同步内容同步至所述目标库,实现所述源库与所述目标库的跨库同步。
可选地,所述基于所述第一同步连接及所述第二同步连接,利用所述跨库同步程序执行源数据库及目标库间的跨库同步,包括:
获取所述源库中需要同步的分支范围;
将所述源库中包含在所述分支范围内的分支确定为目标分支;
将所述源库中所有分支的内容通过所述第一同步连接发送至所述跨库同步程序,并将所述跨库同步程序接受的源库中的内容确定为中转同步内容;
通过所述第二同步连接将所述中转同步内容发送至所述目标库,以将所述中转同步内容同步至所述目标库,实现所述源库与所述目标库的跨库同步。
可选地,所述循环获取所述源库的commit信息,包括:
在所述跨库同步请求响应期间,不断获取所述源库的commit信息,并根据所述第一同步连接及所述第二同步连接,利用所述跨库同步程序对所述源数据库及所述目标库进行定时跨库同步。
可选地,所述根据所述第一同步连接及所述第二同步连接,利用所述跨库同步程序对所述源数据库及所述目标库进行定时跨库同步,包括:
根据所述第一同步连接及所述第二同步连接,按照固定的同步时间间隔,定时利用所述跨库同步程序执行源数据库及目标库间的跨库同步。
为了解决上述问题,本发明还提供一种基于GIT的跨库同步装置,所述装置包括:
数据获取模块,用于响应源库与目标库的跨库同步请求,并获取源库地址、源库认证信息目标库地址及目标库认证信息任务执行模块,用于执行所有所述目标定时任务,并获取每个所述定时任务的任务执行结果;
连接构建模块,用于基于所述源库地址及所述源库认证信息构建预设的跨库同步程序与所述源库的第一同步连接,并基于所述目标库地址及所述目标库认证信息构建所述跨库同步程序与所述目标数据库的第二同步连接;
跨库同步模块,用于循环获取所述源库的commit信息,在每次获取所述源库的commit信息后,基于获取的commit信息判断所述源库是否需要同步,当所述源库需要同步时,基于所述第一同步连接及所述第二同步连接,利用所述跨库同步程序执行源数据库及目标库间的跨库同步。
可选地,所述基于获取的commit信息判断所述源库是否需要同步,包括:
判断获取的所有commit信息的数量是否为1;
当获取的所有commit信息的数量为1,则所述源库需要同步;
当获取的所有commit信息的数量不为1,判断最新获取的commit信息与上一次获取的commit信息是否一致;
若最新获取的commit信息与上一次获取的commit信息不一致,则所述源库需要同步;
若最新获取的commit信息与上一次获取的commit信息一致,则所述源库不需要同步。
为了解决上述问题,本发明还提供一种电子设备,所述电子设备包括:
存储器,存储至少一个计算机程序;及
处理器,执行所述存储器中存储的计算机程序以实现上述所述的基于GIT的跨库同步方法。
为了解决上述问题,本发明还提供一种计算机可读存储介质,所述计算机可读存储介质中存储有至少一个计算机程序,所述至少一个计算机程序被电子设备中的处理器执行以实现上述所述的基于GIT的跨库同步方法。
本发明实施例循环获取所述源库的commit信息,在每次获取所述源库的commit信息后,基于获取的commit信息判断所述源库是否需要同步,当所述源库需要同步时,基于所述第一同步连接及所述第二同步连接,利用所述跨库同步程序执行源数据库及目标库间的跨库同步。通过循环获取所述源库的commit信息可以及时监控源库的数据变化情况,进而可以判断所述源库是否需要同步时,从而及时的进行跨库同步,提高了跨库同步的效率。因此本发明实施例提出的基于GIT的跨库同步方法、装置、电子设备及可读存储介质提高了基于GIT的跨库同步效率。
附图说明
图1为本发明一实施例提供的基于GIT的跨库同步方法的流程示意图;
图2为本发明一实施例提供的基于GIT的跨库同步装置的模块示意图;
图3为本发明一实施例提供的实现基于GIT的跨库同步方法的电子设备的内部结构示意图;
本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
本发明实施例提供一种基于GIT的跨库同步方法。所述基于GIT的跨库同步方法的执行主体包括但不限于服务端、终端等能够被配置为执行本申请实施例提供的该方法的电子设备中的至少一种。换言之,所述基于GIT的跨库同步方法可以由安装在终端设备或服务端设备的软件或硬件来执行,所述软件可以是区块链平台。所述服务端包括但不限于:单台服务器、服务器集群、云端服务器或云端服务器集群等,服务器可以是独立的服务器,也可以是提供云服务、云数据库、云计算、云函数、云存储、网络服务、云通信、中间件服务、域名服务、安全服务、内容分发网络(Content Delivery Network,CDN)、以及大数据和人工智能平台等基础云计算服务的云服务器。
参照图1所示的本发明一实施例提供的基于GIT的跨库同步方法的流程示意图,在本发明实施例中,所述基于GIT的跨库同步方法包括:
S1、响应源库与目标库的跨库同步请求,并获取源库地址、源库认证信息目标库地址及目标库认证信息;
本发明实施例中所述源库为被同步的Git代码库,所述目标库为同步所述源库内容的Git代码库,所述跨库同步请求为需要将源库与目标库进行跨库同步的请求。
进一步地,本发明实施例中为了方便对所述源库及所述目标库进行跨库同步,方便对所述源库及所述目标库进行连接,获取源库地址、源库认证信息目标库地址及目标库认证信息。
S2、基于所述源库地址及所述源库认证信息构建预设的跨库同步程序与所述源库的第一同步连接,并基于所述目标库地址及所述目标库认证信息构建所述跨库同步程序与所述目标数据库的第二同步连接;
本发明实施例中为了避免所述源库及所述目标库无法直接连接,从而导致无法进行跨库同步的情况,基于所述源库地址及所述源库认证信息构建预设的跨库同步程序与所述源库连接(即第一同步连接)的,并基于所述目标库地址及所述目标库认证信息构建所述跨库同步程序与所述目标数据库的连接(即第二同步连接)。
进一步地,本发明实施例中第一同步连接与第二同步连接的构建为本领域技术人员常用的连接构建方法,在此不在赘述。
本发明实施例中所述跨库同步程序为可以进行数据接受发送,且分别可以和源库及目标库构建连接的程序。本发明实施例中通过所述跨库同步程序作为中转,避免了所述源库和所述目标库无法直接连接,造成无法同步的情况,提高了跨库同步的稳定性,进而提高了跨库同步的效率。
S3、循环获取所述源库的commit信息,在每次获取所述源库的commit信息后,基于获取的commit信息判断所述源库是否需要同步,当所述源库需要同步时,基于所述第一同步连接及所述第二同步连接,利用所述跨库同步程序执行源数据库及目标库间的跨库同步;
本发明实施例中为了判断所述源库中的代码是否发生变化,是否需要同步,循环获取所述源库的commit信息,每次获取所述源库的commit信息后,基于获取的commit信息判断所述源库是否需要同步。
需要解释的是,本发明实施例中commit信息是git中用来描述每次提交代码的变更内容的一段文字,因此,可以通过获取的commit信息判断所述源库是否需要同步。
进一步地,由于所述源库中的内容发生变化进行跨库同步时,可能发生同步失败的情况,因此,本发明实施例中除了监控在所述源库中的内容是否发生变化,及时跨库同步的情况,还定时对所述源数据库及所述目标库进行跨库同步,以避免某一次同步不成功的情况。
具体地,本发明实施例中所述循环获取所述源库的commit信息,包括:
在所述跨库同步请求响应期间,不断获取所述源库的commit信息,并根据所述第一同步连接及所述第二同步连接,利用所述跨库同步程序对所述源数据库及所述目标库进行定时跨库同步。
进一步地,本发明实施例中所述根据所述第一同步连接及所述第二同步连接,利用所述跨库同步程序对所述源数据库及所述目标库进行定时跨库同步,包括:
根据所述第一同步连接及所述第二同步连接,按照固定的同步时间间隔,定时利用所述跨库同步程序对所述源数据库及所述目标库进行跨库同步。
需要解释的,因一个跨库同步程序可支持数十个或上百个代码仓库同步。每隔一段时间都会触发一次主动代码同步。为了避免在同一时间有大量的代码仓库同时进行同步,导致对CPU带来巨大压力和线程排队情况。因此,利用所述跨库同步程序进行多个代码仓库同步时,每个代码仓库的同步时间间隔,为在固定时间间隔增加或者减少1%~50%时间。避免在同一时间有大量的代码仓库同时进行定时同步,这样能使得线程执行均衡分布,cpu调度均衡,线程同步效率更高。
本发明实施例中通过获取的commit信息来监控源库中的内容是否发生变化,进而判断所述源库需不需要同步,具体地,所述基于获取的commit信息判断所述源库是否需要同步,包括:
判断获取的所有commit信息的数量是否为1;
当获取的所有commit信息的数量为1,则所述源库需要同步;
当获取的所有commit信息的数量不为1,判断最新获取的commit信息与上一次获取的commit信息是否一致;
若最新获取的commit信息与上一次获取的commit信息不一致,则所述源库需要同步;
若最新获取的commit信息与上一次获取的commit信息一致,则所述源库不需要同步。
可选地,本发明实施例中可利用调用所述源库的commit信息接口来获取commit信息。
本发明实施例中当最新获取的commit信息发生变化时,表示所述源库中的代码发生了变化,需要对所述源库中内容同步到所述目标数据库,因此,基于所述第一同步连接及所述第二同步连接,利用所述跨库同步程序执行源数据库及目标库间的跨库同步。
详细地,本发明实施例中所述基于所述第一同步连接及所述第二同步连接,利用所述跨库同步程序执行源数据库及目标库间的跨库同步,包括:
将所述源库中的内容通过所述第一同步连接发送至所述跨库同步程序,并将所述跨库同步程序接受的源库中的内容确定为中转同步内容;
通过所述第二同步连接将所述中转同步内容发送至所述目标库,以将所述中转同步内容同步至所述目标库,实现所述源库与所述目标库的跨库同步。
本发明另一可选实施例中对所述源库进行同步时,并不需要对整个源库的内容进行同步,只是需要对源库中某些需要同步的分支中的内容进行同步,因此,所述基于所述第一同步连接及所述第二同步连接,利用所述跨库同步程序执行源数据库及目标库间的跨库同步,包括:
获取所述源库中需要同步的分支范围;
将所述源库中包含在所述分支范围内的分支确定为目标分支;
将所述源库中所有分支的内容通过所述第一同步连接发送至所述跨库同步程序,并将所述跨库同步程序接受的源库中的内容确定为中转同步内容;
通过所述第二同步连接将所述中转同步内容发送至所述目标库,以将所述中转同步内容同步至所述目标库,实现所述源库与所述目标库的跨库同步。
如图2所示,是本发明基于GIT的跨库同步装置的功能模块图。
本发明所述基于GIT的跨库同步装置100可以安装于电子设备中。根据实现的功能,所述基于GIT的跨库同步装置可以包括数据获取模块101、连接构建模块102、跨库同步模块103,本发所述模块也可以称之为单元,是指一种能够被电子设备处理器所执行,并且能够完成固定功能的一系列计算机程序段,其存储在电子设备的存储器中。
在本实施例中,关于各模块/单元的功能如下:
所述数据获取模块101用于响应源库与目标库的跨库同步请求,并获取源库地址、源库认证信息目标库地址及目标库认证信息任务执行模块,用于执行所有所述目标定时任务,并获取每个所述定时任务的任务执行结果;
所述连接构建模块102用于基于所述源库地址及所述源库认证信息构建预设的跨库同步程序与所述源库的第一同步连接,并基于所述目标库地址及所述目标库认证信息构建所述跨库同步程序与所述目标数据库的第二同步连接;
所述跨库同步模块103用于循环获取所述源库的commit信息,在每次获取所述源库的commit信息后,基于获取的commit信息判断所述源库是否需要同步,当所述源库需要同步时,基于所述第一同步连接及所述第二同步连接,利用所述跨库同步程序执行源数据库及目标库间的跨库同步。
详细地,本发明实施例中所述基于GIT的跨库同步装置100中所述的各模块在使用时采用与上述图1中所述的基于GIT的跨库同步方法一样的技术手段,并能够产生相同的技术效果,这里不再赘述。
如图3所示,是本发明实现基于GIT的跨库同步方法的电子设备的结构示意图。
所述电子设备可以包括处理器10、存储器11、通信总线12和通信接口13,还可以包括存储在所述存储器11中并可在所述处理器10上运行的计算机程序,如基于GIT的跨库同步程序。
其中,所述存储器11至少包括一种类型的可读存储介质,所述可读存储介质包括闪存、移动硬盘、多媒体卡、卡型存储器(例如:SD或DX存储器等)、磁性存储器、磁盘、光盘等。所述存储器11在一些实施例中可以是电子设备的内部存储单元,例如该电子设备的移动硬盘。所述存储器11在另一些实施例中也可以是电子设备的外部存储设备,例如电子设备上配备的插接式移动硬盘、智能存储卡(Smart Media Card,SMC)、安全数字(SecureDigital,SD)卡、闪存卡(Flash Card)等。进一步地,所述存储器11还可以既包括电子设备的内部存储单元也包括外部存储设备。所述存储器11不仅可以用于存储安装于电子设备的应用软件及各类数据,例如基于GIT的跨库同步程序的代码等,还可以用于暂时地存储已经输出或者将要输出的数据。
所述处理器10在一些实施例中可以由集成电路组成,例如可以由单个封装的集成电路所组成,也可以是由多个相同功能或不同功能封装的集成电路所组成,包括一个或者多个中央处理器(Central Processing unit,CPU)、微处理器、数字处理芯片、图形处理器及各种控制芯片的组合等。所述处理器10是所述电子设备的控制核心(Control Unit),利用各种接口和线路连接整个电子设备的各个部件,通过运行或执行存储在所述存储器11内的程序或者模块(例如基于GIT的跨库同步程序等),以及调用存储在所述存储器11内的数据,以执行电子设备的各种功能和处理数据。
所述通信总线12可以是外设部件互连标准(perIPheral componentinterconnect,简称PCI)总线或扩展工业标准结构(extended industry standardarchitecture,简称EISA)总线等。该总线可以分为地址总线、数据总线、控制总线等。所述通信总线12总线被设置为实现所述存储器11以及至少一个处理器10等之间的连接通信。为便于表示,图中仅用一条粗线表示,但并不表示仅有一根总线或一种类型的总线。
图3仅示出了具有部件的电子设备,本领域技术人员可以理解的是,图3示出的结构并不构成对所述电子设备的限定,可以包括比图示更少或者更多的部件,或者组合某些部件,或者不同的部件布置。
例如,尽管未示出,所述电子设备还可以包括给各个部件供电的电源(比如电池),优选地,电源可以通过电源管理装置与所述至少一个处理器10逻辑相连,从而通过电源管理装置实现充电管理、放电管理、以及功耗管理等功能。电源还可以包括一个或一个以上的直流或交流电源、再充电装置、电源故障分类电路、电源转换器或者逆变器、电源状态指示器等任意组件。所述电子设备还可以包括多种传感器、蓝牙模块、Wi-Fi模块等,在此不再赘述。
可选地,所述通信接口13可以包括有线接口和/或无线接口(如WI-FI接口、蓝牙接口等),通常用于在该电子设备与其他电子设备之间建立通信连接。
可选地,所述通信接口13还可以包括用户接口,用户接口可以是显示器(Display)、输入单元(比如键盘(Keyboard)),可选地,用户接口还可以是标准的有线接口、无线接口。可选地,在一些实施例中,显示器可以是LED显示器、液晶显示器、触控式液晶显示器以及OLED(Organic Light-Emitting Diode,有机发光二极管)触摸器等。其中,显示器也可以适当的称为显示屏或显示单元,用于显示在电子设备中处理的信息以及用于显示可视化的用户界面。
应该了解,所述实施例仅为说明之用,在专利申请范围上并不受此结构的限制。
所述电子设备中的所述存储器11存储的基于GIT的跨库同步程序是多个计算机程序的组合,在所述处理器10中运行时,可以实现:
响应源库与目标库的跨库同步请求,并获取源库地址、源库认证信息目标库地址及目标库认证信息;
基于所述源库地址及所述源库认证信息构建预设的跨库同步程序与所述源库的第一同步连接,并基于所述目标库地址及所述目标库认证信息构建所述跨库同步程序与所述目标数据库的第二同步连接;
循环获取所述源库的commit信息,在每次获取所述源库的commit信息后,基于获取的commit信息判断所述源库是否需要同步,当所述源库需要同步时,基于所述第一同步连接及所述第二同步连接,利用所述跨库同步程序执行源数据库及目标库间的跨库同步。
具体地,所述处理器10对上述计算机程序的具体实现方法可参考图1对应实施例中相关步骤的描述,在此不赘述。
进一步地,所述电子设备集成的模块/单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。所述计算机可读介质可以是非易失性的,也可以是易失性的。所述计算机可读介质可以包括:能够携带所述计算机程序代码的任何实体或装置、记录介质、U盘、移动硬盘、磁碟、光盘、计算机存储器、只读存储器(ROM,Read-Only Memory)。
本发明实施例还可以提供一种计算机可读存储介质,所述可读存储介质存储有计算机程序,所述计算机程序在被电子设备的处理器所执行时,可以实现:
响应源库与目标库的跨库同步请求,并获取源库地址、源库认证信息目标库地址及目标库认证信息;
基于所述源库地址及所述源库认证信息构建预设的跨库同步程序与所述源库的第一同步连接,并基于所述目标库地址及所述目标库认证信息构建所述跨库同步程序与所述目标数据库的第二同步连接;
循环获取所述源库的commit信息,在每次获取所述源库的commit信息后,基于获取的commit信息判断所述源库是否需要同步,当所述源库需要同步时,基于所述第一同步连接及所述第二同步连接,利用所述跨库同步程序执行源数据库及目标库间的跨库同步。
进一步地,所述计算机可用存储介质可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序等;存储数据区可存储根据区块链节点的使用所创建的数据等。
在本发明所提供的几个实施例中,应该理解到,所揭露的设备,装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述模块的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式。
所述作为分离部件说明的模块可以是或者也可以不是物理上分开的,作为模块显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部模块来实现本实施例方案的目的。
本申请实施例可以基于人工智能技术对相关的数据进行获取和处理。其中,人工智能(Artificial Intelligence,AI)是利用数字计算机或者数字计算机控制的机器模拟、延伸和扩展人的智能,感知环境、获取知识并使用知识获得最佳结果的理论、方法、技术及应用系统。
另外,在本发明各个实施例中的各功能模块可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用硬件加软件功能模块的形式实现。
对于本领域技术人员而言,显然本发明不限于上述示范性实施例的细节,而且在不背离本发明的精神或基本特征的情况下,能够以其他的具体形式实现本发明。
因此,无论从哪一点来看,均应将实施例看作是示范性的,而且是非限制性的,本发明的范围由所附权利要求而不是上述说明限定,因此旨在将落在权利要求的等同要件的含义和范围内的所有变化涵括在本发明内。不应将权利要求中的任何附关联图标记视为限制所涉及的权利要求。
本发明所指区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。区块链(Blockchain),本质上是一个去中心化的数据库,是一串使用密码学方法相关联产生的数据块,每一个数据块中包含了一批次网络交易的信息,用于验证其信息的有效性(防伪)和生成下一个区块。区块链可以包括区块链底层平台、平台产品服务层以及应用服务层等。
此外,显然“包括”一词不排除其他单元或步骤,单数不排除复数。系统权利要求中陈述的多个单元或装置也可以由一个单元或装置通过软件或者硬件来实现。第二等词语用来表示名称,而并不表示任何特定的顺序。
最后应说明的是,以上实施例仅用以说明本发明的技术方案而非限制,尽管参照较佳实施例对本发明进行了详细说明,本领域的普通技术人员应当理解,可以对本发明的技术方案进行修改或等同替换,而不脱离本发明技术方案的精神和范围。

Claims (10)

1.一种基于GIT的跨库同步方法,其特征在于,所述方法包括:
响应源库与目标库的跨库同步请求,并获取源库地址、源库认证信息目标库地址及目标库认证信息;
基于所述源库地址及所述源库认证信息构建预设的跨库同步程序与所述源库的第一同步连接,并基于所述目标库地址及所述目标库认证信息构建所述跨库同步程序与所述目标数据库的第二同步连接;
循环获取所述源库的commit信息,在每次获取所述源库的commit信息后,基于获取的commit信息判断所述源库是否需要同步,当所述源库需要同步时,基于所述第一同步连接及所述第二同步连接,利用所述跨库同步程序执行源数据库及目标库间的跨库同步。
2.如权利要求1所述的基于GIT的跨库同步方法,其特征在于,所述基于获取的commit信息判断所述源库是否需要同步,包括:
判断获取的所有commit信息的数量是否为1;
当获取的所有commit信息的数量为1,则所述源库需要同步;
当获取的所有commit信息的数量不为1,判断最新获取的commit信息与上一次获取的commit信息是否一致;
若最新获取的commit信息与上一次获取的commit信息不一致,则所述源库需要同步;
若最新获取的commit信息与上一次获取的commit信息一致,则所述源库不需要同步。
3.如权利要求1所述的基于GIT的跨库同步方法,其特征在于,所述基于所述第一同步连接及所述第二同步连接,利用所述跨库同步程序执行源数据库及目标库间的跨库同步,包括:
将所述源库中的内容通过所述第一同步连接发送至所述跨库同步程序,并将所述跨库同步程序接受的源库中的内容确定为中转同步内容;
通过所述第二同步连接将所述中转同步内容发送至所述目标库,以将所述中转同步内容同步至所述目标库,实现所述源库与所述目标库的跨库同步。
4.如权利要求1所述的基于GIT的跨库同步方法,其特征在于,所述基于所述第一同步连接及所述第二同步连接,利用所述跨库同步程序执行源数据库及目标库间的跨库同步,包括:
获取所述源库中需要同步的分支范围;
将所述源库中包含在所述分支范围内的分支确定为目标分支;
将所述源库中所有分支的内容通过所述第一同步连接发送至所述跨库同步程序,并将所述跨库同步程序接受的源库中的内容确定为中转同步内容;
通过所述第二同步连接将所述中转同步内容发送至所述目标库,以将所述中转同步内容同步至所述目标库,实现所述源库与所述目标库的跨库同步。
5.如权利要求1所述的基于GIT的跨库同步方法,其特征在于,所述循环获取所述源库的commit信息,包括:
在所述跨库同步请求响应期间,不断获取所述源库的commit信息,并根据所述第一同步连接及所述第二同步连接,利用所述跨库同步程序对所述源数据库及所述目标库进行定时跨库同步。
6.如权利要求5中所述的基于GIT的跨库同步方法,其特征在于,所述根据所述第一同步连接及所述第二同步连接,利用所述跨库同步程序对所述源数据库及所述目标库进行定时跨库同步,包括:
根据所述第一同步连接及所述第二同步连接,按照固定的同步时间间隔,定时利用所述跨库同步程序执行源数据库及目标库间的跨库同步。
7.一种基于GIT的跨库同步装置,其特征在于,包括:
数据获取模块,用于响应源库与目标库的跨库同步请求,并获取源库地址、源库认证信息目标库地址及目标库认证信息任务执行模块,用于执行所有所述目标定时任务,并获取每个所述定时任务的任务执行结果;
连接构建模块,用于基于所述源库地址及所述源库认证信息构建预设的跨库同步程序与所述源库的第一同步连接,并基于所述目标库地址及所述目标库认证信息构建所述跨库同步程序与所述目标数据库的第二同步连接;
跨库同步模块,用于循环获取所述源库的commit信息,在每次获取所述源库的commit信息后,基于获取的commit信息判断所述源库是否需要同步,当所述源库需要同步时,基于所述第一同步连接及所述第二同步连接,利用所述跨库同步程序执行源数据库及目标库间的跨库同步。
8.如权利要求7所述的基于GIT的跨库同步装置,其特征在于,所述基于获取的commit信息判断所述源库是否需要同步,包括:
判断获取的所有commit信息的数量是否为1;
当获取的所有commit信息的数量为1,则所述源库需要同步;
当获取的所有commit信息的数量不为1,判断最新获取的commit信息与上一次获取的commit信息是否一致;
若最新获取的commit信息与上一次获取的commit信息不一致,则所述源库需要同步;
若最新获取的commit信息与上一次获取的commit信息一致,则所述源库不需要同步。
9.一种电子设备,其特征在于,所述电子设备包括:
至少一个处理器;以及,
与所述至少一个处理器通信连接的存储器;
其中,所述存储器存储有可被所述至少一个处理器执行的计算机程序,所述计算机程序被所述至少一个处理器执行,以使所述至少一个处理器能够执行如权利要求1至6中任一项所述的基于GIT的跨库同步方法。
10.一种计算机可读存储介质,存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1至6中任一项所述的基于GIT的跨库同步方法。
CN202311600444.4A 2023-11-24 2023-11-24 基于git的跨库同步方法、装置、电子设备及存储介质 Pending CN117851506A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202311600444.4A CN117851506A (zh) 2023-11-24 2023-11-24 基于git的跨库同步方法、装置、电子设备及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202311600444.4A CN117851506A (zh) 2023-11-24 2023-11-24 基于git的跨库同步方法、装置、电子设备及存储介质

Publications (1)

Publication Number Publication Date
CN117851506A true CN117851506A (zh) 2024-04-09

Family

ID=90543891

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202311600444.4A Pending CN117851506A (zh) 2023-11-24 2023-11-24 基于git的跨库同步方法、装置、电子设备及存储介质

Country Status (1)

Country Link
CN (1) CN117851506A (zh)

Similar Documents

Publication Publication Date Title
CN112015815A (zh) 数据同步方法、装置及计算机可读存储介质
CN112653760A (zh) 跨服务器的文件传输方法、装置、电子设备及存储介质
CN111880948A (zh) 数据刷新方法、装置、电子设备及计算机可读存储介质
CN113890712A (zh) 数据传输方法、装置、电子设备及可读存储介质
CN112256783A (zh) 数据导出方法、装置、电子设备及存储介质
CN113542387B (zh) 系统发布方法、装置、电子设备及存储介质
CN114817408B (zh) 调度资源识别方法、装置、电子设备及存储介质
CN113918305B (zh) 节点调度方法、装置、电子设备及可读存储介质
CN113918296B (zh) 模型训练任务调度执行方法、装置、电子设备及存储介质
CN117851506A (zh) 基于git的跨库同步方法、装置、电子设备及存储介质
CN115033605A (zh) 数据查询方法、装置、电子设备及存储介质
CN114124835A (zh) 基于接口的数据传输方法、装置、设备及介质
CN114185588A (zh) 增量包生成方法、装置、设备及存储介质
CN114547011A (zh) 数据抽取方法、装置、电子设备及存储介质
CN114510400A (zh) 任务执行方法、装置、电子设备及存储介质
CN113360375A (zh) 交易测试方法、装置、电子设备及存储介质
CN114598624B (zh) 集群监控方法、装置、电子设备及可读存储介质
CN116418896B (zh) 基于定时器的任务执行方法、装置、设备及介质
CN114640618B (zh) 集群路由调度方法、装置、电子设备及可读存储介质
CN115001945B (zh) 日志收集监控方法、装置、设备及计算机可读介质
CN115174691B (zh) 基于页面请求的大数据加载方法、装置、设备及介质
CN116414366B (zh) 中间件接口生成方法、装置、设备及介质
CN117633075A (zh) 微服务应用数据协同方法、装置、电子设备及存储介质
CN114785789A (zh) 数据库故障管理方法、装置、电子设备及存储介质
CN116431653A (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