1.一种数据同步方法,其特征在于,所述方法包括:响应于检测到数据定义语言事件,在主数据库上执行所述数据定义语言事件所指示的操作,以及生成用于记录所述数据定义语言事件的操作的第一日志,将所述第一日志缓存至预先建立的第一缓存中;
若预先建立的第二缓存中缓存有用于记录数据操纵语言事件的操作的第二日志,则将所述第一缓存中的第一日志和所述第二缓存中的第二日志,以预设的分隔标识区分写入日志文件中;
根据所述分隔标识,将所述日志文件中的第一日志和第二日志分发至从数据库中的对应工作线程中处理,以便在从数据库上并行执行所述数据定义语言事件和所述数据操纵语言事件。
2.根据权利要求1所述的数据同步方法,其特征在于,所述方法还包括:向操作系统请求分配两个内存空间,以及将所分配的两个内存空间建立为所述第一缓存和所述第二缓存,其中,所述第一缓存用于存储记录数据定义语言事件的操作的第一日志,所述第二缓存用于存储记录数据操纵语言事件的操作的第二日志。
3.根据权利要求1所述的数据同步方法,其特征在于,所述方法还包括:响应于检测到所述数据操纵语言事件,在所述主数据库上执行所述数据操纵语言事件所指示的操作,以及生成用于记录所述数据操纵语言事件的操作的所述第二日志,将所述第二日志缓存至预先建立的所述第二缓存中。
4.根据权利要求1所述的数据同步方法,其特征在于,所述根据所述分隔标识,将所述日志文件中的第一日志和第二日志分发至从数据库中的对应工作线程中处理,包括:将所述日志文件传递至所述从数据库的协作线程,使得所述协作线程在检测到所述日志文件中包括所述分隔标识时,将所述分隔标识两侧的第一日志和第二日志分配至处于空闲状态的对应工作线程中处理。
5.根据权利要求4所述的数据同步方法,其特征在于,若所述日志文件中的第二日志有多个,则所述将所述分隔标识两侧的第一日志和第二日志分配至处于空闲状态的对应工作线程中处理,包括:
将所述分隔标识一侧的第一日志分配至处于空闲状态的第一工作线程中处理,以及将所述分隔标识另一侧的多个第二日志分别分配至处于空闲状态的多个第二工作线程中处理。
6.根据权利要求1所述的数据同步方法,其特征在于,所述方法还包括:针对每个工作线程,若所述工作线程对目标日志处理完成,则执行预设资源释放函数以释放分配给对目标日志处理完成的所述工作线程的处理资源,以及将对目标日志处理完成的所述工作线程的状态确定为空闲状态,其中,所述目标日志为第一日志或/及第二日志。
7.根据权利要求1‑6中任一项所述的数据同步方法,其特征在于,所述方法还包括:若未检测到数据定义语言事件且所述第二缓存满足预设转写条件,将所述第二缓存中的第二日志写入所述日志文件;
其中,所述预设转写条件包括以下至少一项:所述第二缓存的当前使用率大于预设使用率阈值、达到预设转存周期。
8.一种数据同步装置,其特征在于,所述装置包括:第一执行单元,用于响应于检测到数据定义语言事件,在主数据库上执行所述数据定义语言事件所指示的操作,以及生成用于记录所述数据定义语言事件的操作的第一日志,将所述第一日志缓存至预先建立的第一缓存中;
数据写入单元,用于若预先建立的第二缓存中缓存有用于记录数据操纵语言事件的操作的第二日志,则将所述第一缓存中的第一日志和所述第二缓存中的第二日志,以预设的分隔标识区分写入日志文件中;
第二执行单元,用于根据所述分隔标识,将所述日志文件中的第一日志和第二日志分发至从数据库中的对应工作线程中处理,以便在从数据库上并行执行所述数据定义语言事件和所述数据操纵语言事件。
9.一种服务器,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现如权利要求1至7任一项所述方法的步骤。
10.一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1至7任一项所述方法的步骤。