CN113672031A - 一种时间同步方法、装置、计算机设备及存储介质 - Google Patents
一种时间同步方法、装置、计算机设备及存储介质 Download PDFInfo
- Publication number
- CN113672031A CN113672031A CN202111044383.9A CN202111044383A CN113672031A CN 113672031 A CN113672031 A CN 113672031A CN 202111044383 A CN202111044383 A CN 202111044383A CN 113672031 A CN113672031 A CN 113672031A
- Authority
- CN
- China
- Prior art keywords
- time
- operating system
- virtual machine
- software
- virtualization management
- 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
Links
- 238000000034 method Methods 0.000 title claims abstract description 46
- 238000012544 monitoring process Methods 0.000 claims abstract description 10
- 230000004044 response Effects 0.000 claims abstract description 8
- 230000006870 function Effects 0.000 claims description 20
- 238000004590 computer program Methods 0.000 claims description 9
- 230000008859 change Effects 0.000 description 7
- 230000008569 process Effects 0.000 description 7
- 230000001360 synchronised effect Effects 0.000 description 6
- 238000004891 communication Methods 0.000 description 5
- 230000009471 action Effects 0.000 description 4
- 230000007246 mechanism Effects 0.000 description 3
- 238000012545 processing Methods 0.000 description 3
- 238000010586 diagram Methods 0.000 description 2
- 238000000691 measurement method Methods 0.000 description 2
- 230000002457 bidirectional effect Effects 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 230000014509 gene expression Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000008447 perception Effects 0.000 description 1
- 230000003068 static effect Effects 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F1/00—Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
- G06F1/04—Generating or distributing clock signals or signals derived directly therefrom
- G06F1/12—Synchronisation of different clock signals provided by a plurality of clock generators
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3003—Monitoring arrangements specially adapted to the computing system or computing system component being monitored
- G06F11/302—Monitoring arrangements specially adapted to the computing system or computing system component being monitored where the computing system component is a software system
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3051—Monitoring arrangements for monitoring the configuration of the computing system or of the computing system component, e.g. monitoring the presence of processing resources, peripherals, I/O links, software programs
-
- 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/44—Arrangements for executing specific programs
- G06F9/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45533—Hypervisors; Virtual machine monitors
- G06F9/45558—Hypervisor-specific management and integration aspects
-
- 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/44—Arrangements for executing specific programs
- G06F9/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45533—Hypervisors; Virtual machine monitors
- G06F9/45558—Hypervisor-specific management and integration aspects
- G06F2009/45575—Starting, stopping, suspending or resuming virtual machine instances
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Software Systems (AREA)
- Computing Systems (AREA)
- Quality & Reliability (AREA)
- Mathematical Physics (AREA)
- Stored Programmes (AREA)
Abstract
本发明公开了一种时间同步方法、装置、计算机设备及存储介质。所述方法包括:在宿主机运行的第一操作系统中创建并运行虚拟化管理软件,并通过虚拟化管理软件启动至少一个虚拟机,每一虚拟机均运行第二操作系统;在至少一个虚拟机对应的第二操作系统中运行监控软件,监控软件用于监测第二操作系统的时间设定事件;响应于监控软件监测到时间设定事件,则将监控软件对应的虚拟机作为目标虚拟机,并获取目标虚拟机的第二操作系统的当前时间;基于第二操作系统的当前时间确定第一时间;利用虚拟化管理软件基于第一时间对宿主机的第一操作系统的时间进行同步。本发明的方案实现了由下向上时间同步,丰富了时间同步的种类,提高了时间设定的灵活性。
Description
技术领域
本发明涉及计算机技术领域,尤其涉及一种时间同步方法、装置、计算机设备及存储介质。
背景技术
虚拟机(英文全称:Virtual Machine)是指通过软件模拟的具有完整硬件系统功能的、运行在一个完全隔离环境中的完整计算机系统。宿主机就是计算机主机,这个概念是相对于虚拟机而言的,比如某一计算机上安装有虚拟机,那么相对于虚拟机而言该计算机就是宿主机。目前较为常见虚拟机软件有VMware(VMWare ACE)、Virtual Box和VirtualPC,它们都能在Windows系统上虚拟出多个计算机,每个虚拟计算机可以独立运行,可以安装各种软件与应用等。宿主机和主机上各自运行操作系统,每个操作系统都具有系统时间,为了保证时间相对有效需要对二者的系统时间进行同步。
目前,传统的宿主机与虚拟机的时间同步策略是以宿主机的时间为准,对该宿主机上运行的虚拟机进行同步。例如在VirtualBox虚拟化平台中提供了宿主机与虚拟机时间同步的机制,当宿主机时间做了变更,虚拟机中的时间会更新为宿主机的时间。也就是,虚拟机中的时间是以宿主机的时间为基准,当且仅当宿主机的时间变化时,虚拟机中的时间才能变化。如果通过应用程序或者手动的修改虚拟机中时间,宿主机中的时间不会同步进行变更,而且虚拟机中的时间会自动再次变更为与宿主机一致的时间,对虚拟机的时间设定无法保持,需要反复设定,给使用者带来极大不便。
发明内容
有鉴于此,有必要针对以上技术问题,提供一种时间同步方法、装置、计算机设备及存储介质。
根据本发明的第一方面,提供了一种时间同步方法,所述方法包括:
在宿主机运行的第一操作系统中创建并运行虚拟化管理软件,并通过所述虚拟化管理软件启动至少一个虚拟机,其中,每一虚拟机均运行第二操作系统;
在所述至少一个虚拟机对应的第二操作系统中运行监控软件,其中,所述监控软件用于监测第二操作系统的时间设定事件;
响应于所述监控软件监测到时间设定事件,则将所述监控软件对应的虚拟机作为目标虚拟机,并获取所述目标虚拟机的第二操作系统的当前时间;
基于第二操作系统的当前时间确定第一时间;
利用所述虚拟化管理软件基于所述第一时间对所述宿主机的第一操作系统的时间进行同步。
在一些实施例中,所述基于第二操作系统的当前时间确定第一时间包括:
将第二操作系统的当前时间与第一预设时间之和作为所述第一时间。
在一些实施例中,所述利用所述虚拟化管理软件基于所述第一时间对所述宿主机的第一操作系统的时间进行同步包括:
利用虚拟化管理软件调用第一操作系统的时间设定函数接口;
通过第一操作系统的时间设定函数接口将第一操作系统的系统时间修改为第一时间。
在一些实施例中,所述方法还包括:
响应于所述宿主机的第一操作系统完成时间同步,则获取所述第一操作系统当前时间;
基于所述第一操作系统的当前时间确定第二时间;
利用所述虚拟化管理软件基于所述第二时间对所述至少一个虚拟机中除所述目标虚拟机以外的每一虚拟机进行时间同步。
在一些实施例中,所述基于所述第一操作系统的当前时间确定第二时间包括:
将第一操作系统的当前时间与第二预设时间之和作为所述第二时间。
在一些实施例中,所述利用所述虚拟化管理软件基于所述第二时间对所述至少一个虚拟机中除所述目标虚拟机以外的每一虚拟机进行时间同步,包括:
利用虚拟化管理软件调用所述至少一个虚拟机中除所述目标虚拟机以外的每一虚拟机对应的第二操作系统的时间设定函数接口;
通过每一虚拟机对应的第二操作系统的时间设定函数接口将对应的第二操作系统的系统时间修改为第二时间。
在一些实施例中,所述第一操作系统和第二操作系统均包括:Linux系统,Unix系统,Ubuntu系统、mac系统、Windows,所述虚拟化管理软件为VirtualBox软件,所述监控软件为GuestTools软件。
根据本发明的第二方面,提供了一种时间同步装置,所述装置包括:
虚拟机创建模块,配置为在宿主机运行的第一操作系统中创建并运行虚拟化管理软件,并通过所述虚拟化管理软件启动至少一个虚拟机,其中,每一虚拟机均运行第二操作系统;
监控模块,配置为在所述至少一个虚拟机对应的第二操作系统中运行监控软件;
时间获取模块,配置为响应于所述监控软件监测到时间设定事件,则将所述监控软件对应的虚拟机作为目标虚拟机,并获取所述目标虚拟机的第二操作系统的当前时间;
时间确定模块,配置为基于第二操作系统的当前时间确定第一时间;
同步模块,配置为利用所述虚拟化管理软件基于所述第一时间对所述宿主机的第一操作系统的时间进行同步。
根据本发明的第三方面,还提供了一种计算机设备,该计算机设备包括:
至少一个处理器;以及
存储器,存储器存储有可在处理器上运行的计算机程序,处理器执行程序时执行前述的时间同步方法。
根据本发明的第四方面,还提供了一种计算机可读存储介质,计算机可读存储介质存储有计算机程序,计算机程序被处理器执行时执行前述的时间同步方法。
上述一种时间同步方法,首先利用第一操作系统的虚拟化管理软件启动至少一个虚拟机,在每个虚拟机的第二操作系统中运行监控软件以监控第二操作的时间设定事件,若第二操作系统存在时间设定事件,则将该第二操作系统对应的虚拟机作为目标虚拟机,然后通过目标虚拟机的当前时间确定第一时间,最后利用虚拟化管理软件基于第一时间对宿主机的第一操作系统时间进行同步,实现了虚拟机到宿主机的由下向上时间同步,丰富了时间同步的种类,提高了时间设定的灵活性。
此外,本发明还提供了一种时间同步装置、一种计算机设备和一种计算机可读存储介质,同样能实现上述技术效果,这里不再赘述。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的实施例。
图1为本发明一个实施例提供的由下向上的一种时间同步方法100的流程示意图;
图2为本发明另一个实施例提供的双向时间的另一种时间同步方法200的流程示意图;
图3为本发明一个实施例提供的宿主机与虚拟机的通信示意图;
图4为本发明一个实施例提供的一种时间同步装置300的结构示意图;
图5本发明另一个实施例中计算机设备的内部结构图。
具体实施方式
为使本发明的目的、技术方案和优点更加清楚明白,以下结合具体实施例,并参照附图,对本发明实施例进一步详细说明。
需要说明的是,本发明实施例中所有使用“第一”和“第二”的表述均是为了区分两个相同名称非相同的实体或者非相同的参量,可见“第一”“第二”仅为了表述的方便,不应理解为对本发明实施例的限定,后续实施例对此不再一一说明。
在一个实施例中,请参照图1所示,本发明提供了对宿主机与虚拟机进行单向时间同步的一种时间设定方法100,具体来说该方法包括以下步骤:
S101,在宿主机运行的第一操作系统中创建并运行虚拟化管理软件,并通过所述虚拟化管理软件启动至少一个虚拟机,其中,每一虚拟机均运行第二操作系统;
需要说明的是,本实施例中不对第一操作系统和第二操作系统的具体类型和版本进行限定,第一操作系统和第二操作系统可以是任何现有的操作系统,比如第一操作系统可以是Linux操作系统,而第二操作系统可以是Windows操作系统,而以上提及的Linux操作系统和Windows操作系统的版本可以是任意现有或者未来可能更新的操作的版本。需要说明的是第一操作系统和第二操作系统可以相同,当然第一操作系统和第二操作系统也可以采用不同的操作系统,对于具有多个虚拟机的情形第二操作系统可以相同也可以不同,例如部分虚拟机操作系统为Windows操作系统,部分虚拟机操作系统为Linux操作系统。在具体实施过程中可根据用户的需要在宿主机或虚拟机中安装合适的操作系统。虚拟化管理软件可以是任何现有的能够启动并管理虚拟机的软件,例如虚拟化管理软件可以选自VMware(VMWare ACE)、Virtual Box和Virtual PC。
S102,在所述至少一个虚拟机对应的第二操作系统中运行监控软件,其中,所述监控软件用于监测第二操作系统的时间设定事件;具体来说时间设定事件可以是人为在虚拟机操作系统中进行时间设定的行为,也可以是利用运行在第二操作系统中的程序或命令实现的时间设定行为。
S103,响应于所述监控软件监测到时间设定事件,则将所述监控软件对应的虚拟机作为目标虚拟机,并获取所述目标虚拟机的第二操作系统的当前时间;
S104,基于第二操作系统的当前时间确定第一时间;
S105,利用所述虚拟化管理软件基于所述第一时间对所述宿主机的第一操作系统的时间进行同步。
上述一种时间同步方法,首先利用第一操作系统的虚拟化管理软件启动至少一个虚拟机,在每个虚拟机的第二操作系统中运行监控软件以监控第二操作的时间设定事件,若第二操作系统存在时间设定事件,则将该第二操作系统对应的虚拟机作为目标虚拟机,然后通过目标虚拟机的当前时间确定第一时间,最后利用虚拟化管理软件基于第一时间对宿主机的第一操作系统时间进行同步,实现了虚拟机到宿主机的由下向上时间同步,丰富了时间同步的种类,提高了时间设定的灵活性。
在一些实施例中,前述步骤104具体可以采用以下方式实施:
将第二操作系统的当前时间与第一预设时间之和作为所述第一时间。
举例来说,在具体实施过程中第二操作系统和第一操作系统进行通信需要一定的时间,而且获取操作系统当前时间也需要时间,对于一些时间精确度要求较高的应用场景,为了尽可能的减少时间设定的误差,可以利用经验或者其他现有的测量技术对第二操作系统与第一操作系统通信所需时间进行预测从而设置第一预设时间,例如假设用户获取到第二操作系统的当前时间为2020年4月1日19点12分36秒,而依据经验第一预设时间为2秒,那么所确定的第一时间即为2020年4月1日19点12分38秒,后续第一操作系统可以基于该新确定的第一时间进行时间同步。需要说明的是虽然本实施精确到秒,但是对于时间设定要求精确度较高的应用场景第一预设时间还可精确到毫秒或者更精确时间单位。
在一些实施例中,前述步骤105具体可以采用以下步骤实施:
利用虚拟化管理软件调用第一操作系统的时间设定函数接口;
通过第一操作系统的时间设定函数接口将第一操作系统的系统时间修改为第一时间。
在又一个实施例中,请参照图2所示,在前述实施例的基础上本发明还提供了能对宿主机与虚拟机进行双向时间同的另一种时间同步方法200,具体来说该方法包括以下步骤:
S201,在宿主机运行的第一操作系统中创建并运行虚拟化管理软件,并通过所述虚拟化管理软件启动至少一个虚拟机,其中,每一虚拟机均运行第二操作系统;
需要说明的是,本实施例中不对第一操作系统和第二操作系统的具体类型和版本进行限定,第一操作系统和第二操作系统可以是任何现有的操作系统,比如第一操作系统可以是Linux操作系统,而第二操作系统可以是Windows操作系统,而以上提及的Linux操作系统和Windows操作系统的版本可以是任意现有或者未来可能更新的操作的版本。需要说明的是第一操作系统和第二操作系统可以相同,当然第一操作系统和第二操作系统也可以采用不同的操作系统,对于具有多个虚拟机的情形第二操作系统可以相同也可以不同,例如部分虚拟机操作系统为Windows操作系统,部分虚拟机操作系统为Linux操作系统。在具体实施过程中可根据用户的需要在宿主机或虚拟机中安装合适的操作系统。虚拟化管理软件可以是任何现有的能够启动并管理虚拟机的软件,例如虚拟化管理软件可以选自VMware(VMWare ACE)、Virtual Box和Virtual PC。
S202,在所述至少一个虚拟机对应的第二操作系统中运行监控软件,其中,所述监控软件用于监测第二操作系统的时间设定事件;具体来说时间设定事件可以是人为在虚拟机操作系统中进行时间设定的行为,也可以是利用运行在第二操作系统中的程序或命令实现的时间设定行为。
S203,响应于所述监控软件监测到时间设定事件,则将所述监控软件对应的虚拟机作为目标虚拟机,并获取所述目标虚拟机的第二操作系统的当前时间;
S204,基于第二操作系统的当前时间确定第一时间;
S205,利用所述虚拟化管理软件基于所述第一时间对所述宿主机的第一操作系统的时间进行同步;
S206,响应于所述宿主机的第一操作系统完成时间同步,则获取所述第一操作系统当前时间;
S207,基于所述第一操作系统的当前时间确定第二时间;
S208,利用所述虚拟化管理软件基于所述第二时间对所述至少一个虚拟机中除所述目标虚拟机以外的每一虚拟机进行时间同步。
需要说明的是与前一实施例的区别是,本实施例还提供宿主机与其他虚拟机的由上向下的时间同步,通过将宿主机修改以后的时间作为第二时间,然后利用该确定的第二时间对运行在宿主机上的其他虚拟机进行时间同步,即采用自上向下对虚拟机的时间进行同步,使得该宿主机上运行的虚拟机可以采用相同的时间,避免了在多个虚拟机上进行单独时间设定操作,极大的减小了同一宿主机上各个虚拟机的时间差异,简化了用户对虚拟机的时间设定流程,提高了虚拟机与宿主机之间的时间设定效率
在一些实施例中,前述步骤207具体可以采用一些方式实施:
将第一操作系统的当前时间与第二预设时间之和作为所述第二时间。
举例来说,在具体实施过程中第一操作系统和每个第二操作系统进行通信需要一定的时间,而且获取操作系统当前时间也需要时间,对于一些时间精确度要求较高的应用场景,为了尽可能的减少时间设定的误差,可以利用经验或者其他现有的测量技术度对第一操作系统与第二操作系统通信所需时间进行预测从而设置第二预设时间,例如假设用户获取到第一操作系统的当前时间为2020年4月1日16点33分2秒,而依据经验第一预设时间为1秒,那么所确定的第二时间即为2020年4月1日19点33分3秒,后续每个第二操作系统可以基于该新确定的第二时间进行时间同步。需要说明的是虽然本实施精确到秒,但是对于时间设定要求精确度较高的应用场景第一预设时间还可精确到毫秒或者更精确时间单位。
在一些实施例中,前述步骤S208具体包括以下步骤:
利用虚拟化管理软件调用所述至少一个虚拟机中除所述目标虚拟机以外的每一虚拟机对应的第二操作系统的时间设定函数接口;
通过每一虚拟机对应的第二操作系统的时间设定函数接口将对应的第二操作系统的系统时间修改为第二时间。
优选地,所述第一操作系统和第二操作系统均包括:Linux系统,Unix系统,Ubuntu系统、mac系统、Windows,所述虚拟化管理软件为VirtualBox软件,所述监控软件为GuestTools软件。
在一些实施例中,为了便于理解本发明的技术方案,下面以一个具体的应用场景为例,请结合图3所示,本实施例以宿主机第一操作系统为Ubuntu系统为例,该宿主机上运行一个虚拟机,该虚拟机的操作系统为Windows系统,本发明方法分为三个部分;
第一部分是GuestTools,该工具是VirtualBox提供的虚拟机中安装的增强软件。GuestTools能够与VirtualBox虚拟化层进行通信,当宿主机的时间变更时,VirutalBox虚拟化层就将当前时间通知到GuestTools中,由GuestTools设置虚拟机的时间,这样就实现了宿主机与虚拟机之间的单向(即由上向下)的时间同步。
本在上述宿主机与虚拟机之间时间同步的基础上,增加了基于事件触发的时间感知机制,由于虚拟机中的操作系统(假设为Windows7操作系统)提供了时间设定的事件回调机制,所以需要在GuestTools中捕获时间设定事件,当虚拟机中的时间被设定时,Windows7操作系统能够自动触发该事件,并且GuestTools中能够自动捕获到该事件。
第二部分是GuestTools与VirtualBox虚拟化层之间的通信消息。VirtualBox已经提供了虚拟化层与GuestTools之间的通信通道,当GuestTools基于上述的原理捕获到时间变更的事件时,会将该事件封装为一个消息,并将该消息通过已有的通道发送到VirtualBox的虚拟化层。
第三部分是VirtualBox虚拟化层,该层安装在宿主机中,基于上述的原理,VirtualBox虚拟化层会接收到虚拟机时间变更的事件消息,基于消息的类型,调用宿主机操作系统(假设是Ubuntu操作系统)的时间设定的函数接口,进行宿主机的时间设定。
具体实现方法如下:
步骤一,在宿主机中安装Ubuntu16.04.2操作系统,安装VirtualBox6.0虚拟化软件,启动一个虚拟机,该虚拟机安装Windows7操作系统。
步骤二,在虚拟机中安装GuestTools软件,该软件增加了Windows时间变更事件处理函数,当该函数捕获到Windows的时间变更事件时,将事件封装为时间变更消息,调用VirutalBox已有的消息通道的函数,将消息发送到VirutalBox的虚拟化层。
步骤三,VirtualBox虚拟化层增加接收Windows时间变更消息的处理函数,该消息包含虚拟机变更后的时间。该处理函数通过调用宿主操作系统的时间设定函数,使得虚拟机中时间能够同步到宿主机中。
本实施例的时间同步方法,通过利用GuestTools软件与VirtualBox虚拟化层已预先创建的通信通道,实现了虚拟机与宿主机之间的向下时间同步,无需在宿主机和虚拟机之间重新搭建新的通信通道,节省了时间同步成本,具有较佳的通用性。
在又一个实施例中,请参照图4所示,本发明还提供了一种时间同步装置300,所述装置包括:
虚拟机创建模块301,配置为在宿主机运行的第一操作系统中创建并运行虚拟化管理软件,并通过所述虚拟化管理软件启动至少一个虚拟机,其中,每一虚拟机均运行第二操作系统;
监控模块302,配置为在所述至少一个虚拟机对应的第二操作系统中运行监控软件;
时间获取模块303,配置为响应于所述监控软件监测到时间设定事件,则将所述监控软件对应的虚拟机作为目标虚拟机,并获取所述目标虚拟机的第二操作系统的当前时间;
时间确定模块304,配置为基于第二操作系统的当前时间确定第一时间;
同步模块305,配置为利用所述虚拟化管理软件基于所述第一时间对所述宿主机的第一操作系统的时间进行同步。
需要说明的是,关于时间同步装置的具体限定可以参见上文中对时间同步方法的限定,在此不再赘述。上述时间同步装置中的各个模块可全部或部分通过软件、硬件及其组合来实现。上述各模块可以硬件形式内嵌于或独立于计算机设备中的处理器中,也可以以软件形式存储于计算机设备中的存储器中,以便于处理器调用执行以上各个模块对应的操作。
根据本发明的另一方面,提供了一种计算机设备,该计算机设备可以是服务器,其内部结构图请参照图4所示。该计算机设备包括通过系统总线连接的处理器、存储器、网络接口和数据库。其中,该计算机设备的处理器用于提供计算和控制能力。该计算机设备的存储器包括非易失性存储介质、内存储器。该非易失性存储介质存储有操作系统、计算机程序和数据库。该内存储器为非易失性存储介质中的操作系统和计算机程序的运行提供环境。该计算机设备的数据库用于存储数据。该计算机设备的网络接口用于与外部的终端通过网络连接通信。该计算机程序被处理器执行时实现以上所述的时间同步方法,具体来说,所述方法包括以下步骤:
在宿主机运行的第一操作系统中创建并运行虚拟化管理软件,并通过所述虚拟化管理软件启动至少一个虚拟机,其中,每一虚拟机均运行第二操作系统;
在所述至少一个虚拟机对应的第二操作系统中运行监控软件,其中,所述监控软件用于监测第二操作系统的时间设定事件;
响应于所述监控软件监测到时间设定事件,则将所述监控软件对应的虚拟机作为目标虚拟机,并获取所述目标虚拟机的第二操作系统的当前时间;
基于第二操作系统的当前时间确定第一时间;
利用所述虚拟化管理软件基于所述第一时间对所述宿主机的第一操作系统的时间进行同步。
根据本发明的又一方面,提供了一种计算机可读存储介质,其上存储有计算机程序,计算机程序被处理器执行时实现以上所述的时间同步方法,具体来说,包括执行以下步骤:
在宿主机运行的第一操作系统中创建并运行虚拟化管理软件,并通过所述虚拟化管理软件启动至少一个虚拟机,其中,每一虚拟机均运行第二操作系统;
在所述至少一个虚拟机对应的第二操作系统中运行监控软件,其中,所述监控软件用于监测第二操作系统的时间设定事件;
响应于所述监控软件监测到时间设定事件,则将所述监控软件对应的虚拟机作为目标虚拟机,并获取所述目标虚拟机的第二操作系统的当前时间;
基于第二操作系统的当前时间确定第一时间;
利用所述虚拟化管理软件基于所述第一时间对所述宿主机的第一操作系统的时间进行同步。
本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,是可以通过计算机程序来指令相关的硬件来完成,所述的计算机程序可存储于一非易失性计算机可读取存储介质中,该计算机程序在执行时,可包括如上述各方法的实施例的流程。其中,本申请所提供的各实施例中所使用的对存储器、存储、数据库或其它介质的任何引用,均可包括非易失性和/或易失性存储器。非易失性存储器可包括只读存储器(ROM)、可编程ROM(PROM)、电可编程ROM(EPROM)、电可擦除可编程ROM(EEPROM)或闪存。易失性存储器可包括随机存取存储器(RAM)或者外部高速缓冲存储器。作为说明而非局限,RAM以多种形式可得,诸如静态RAM(SRAM)、动态RAM(DRAM)、同步DRAM(SDRAM)、双数据率SDRAM(DDRSDRAM)、增强型SDRAM(ESDRAM)、同步链路(Synchlink)DRAM(SLDRAM)、存储器总线(Rambus)直接RAM(RDRAM)、直接存储器总线动态RAM(DRDRAM)、以及存储器总线动态RAM(RDRAM)等。
以上实施例的各技术特征可以进行任意的组合,为使描述简洁,未对上述实施例中的各个技术特征所有可能的组合都进行描述,然而,只要这些技术特征的组合不存在矛盾,都应当认为是本说明书记载的范围。
以上所述实施例仅表达了本申请的几种实施方式,其描述较为具体和详细,但并不能因此而理解为对发明专利范围的限制。应当指出的是,对于本领域的普通技术人员来说,在不脱离本申请构思的前提下,还可以做出若干变形和改进,这些都属于本申请的保护范围。因此,本申请专利的保护范围应以所附权利要求为准。
Claims (10)
1.一种时间同步方法,其特征在于,所述方法包括:
在宿主机运行的第一操作系统中创建并运行虚拟化管理软件,并通过所述虚拟化管理软件启动至少一个虚拟机,其中,每一虚拟机均运行第二操作系统;
在所述至少一个虚拟机对应的第二操作系统中运行监控软件,其中,所述监控软件用于监测第二操作系统的时间设定事件;
响应于所述监控软件监测到时间设定事件,则将所述监控软件对应的虚拟机作为目标虚拟机,并获取所述目标虚拟机的第二操作系统的当前时间;
基于第二操作系统的当前时间确定第一时间;
利用所述虚拟化管理软件基于所述第一时间对所述宿主机的第一操作系统的时间进行同步。
2.根据权利要求1所述的方法,其特征在于,所述基于第二操作系统的当前时间确定第一时间包括:
将第二操作系统的当前时间与第一预设时间之和作为所述第一时间。
3.根据权利要求1或2所述的方法,其特征在于,所述利用所述虚拟化管理软件基于所述第一时间对所述宿主机的第一操作系统的时间进行同步包括:
利用虚拟化管理软件调用第一操作系统的时间设定函数接口;
通过第一操作系统的时间设定函数接口将第一操作系统的系统时间修改为第一时间。
4.根据权利要求1所述的方法,其特征在于,所述方法还包括:
响应于所述宿主机的第一操作系统完成时间同步,则获取所述第一操作系统当前时间;
基于所述第一操作系统的当前时间确定第二时间;
利用所述虚拟化管理软件基于所述第二时间对所述至少一个虚拟机中除所述目标虚拟机以外的每一虚拟机进行时间同步。
5.根据权利要求4所述的方法,其特征在于,所述基于所述第一操作系统的当前时间确定第二时间包括:
将第一操作系统的当前时间与第二预设时间之和作为所述第二时间。
6.根据权利要求4或5所述的方法,其特征在于,所述利用所述虚拟化管理软件基于所述第二时间对所述至少一个虚拟机中除所述目标虚拟机以外的每一虚拟机进行时间同步包括:
利用虚拟化管理软件调用所述至少一个虚拟机中除所述目标虚拟机以外的每一虚拟机对应的第二操作系统的时间设定函数接口;
通过每一虚拟机对应的第二操作系统的时间设定函数接口将对应的第二操作系统的系统时间修改为第二时间。
7.根据权利要求1所述的方法,其特征在于,所述第一操作系统和第二操作系统均包括:Linux系统,Unix系统,Ubuntu系统、mac系统、Windows,所述虚拟化管理软件为VirtualBox软件,所述监控软件为GuestTools软件。
8.一种时间同步装置,其特征在于,所述装置包括:
虚拟机创建模块,配置为在宿主机运行的第一操作系统中创建并运行虚拟化管理软件,并通过所述虚拟化管理软件启动至少一个虚拟机,其中,每一虚拟机均运行第二操作系统;
监控模块,配置为在所述至少一个虚拟机对应的第二操作系统中运行监控软件;
时间获取模块,配置为响应于所述监控软件监测到时间设定事件,则将所述监控软件对应的虚拟机作为目标虚拟机,并获取所述目标虚拟机的第二操作系统的当前时间;
时间确定模块,配置为基于第二操作系统的当前时间确定第一时间;
同步模块,配置为利用所述虚拟化管理软件基于所述第一时间对所述宿主机的第一操作系统的时间进行同步。
9.一种计算机设备,其特征在于,包括:
至少一个处理器;以及
存储器,所述存储器存储有可在所述处理器中运行的计算机程序,所述处理器执行所述程序时执行权利要求1-7任意一项所述的方法。
10.一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,其特征在于,所述计算机程序被处理器执行时执行权利要求1-7任意一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111044383.9A CN113672031A (zh) | 2021-09-07 | 2021-09-07 | 一种时间同步方法、装置、计算机设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111044383.9A CN113672031A (zh) | 2021-09-07 | 2021-09-07 | 一种时间同步方法、装置、计算机设备及存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN113672031A true CN113672031A (zh) | 2021-11-19 |
Family
ID=78548644
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202111044383.9A Pending CN113672031A (zh) | 2021-09-07 | 2021-09-07 | 一种时间同步方法、装置、计算机设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN113672031A (zh) |
Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103593246A (zh) * | 2012-08-15 | 2014-02-19 | 中国电信股份有限公司 | 虚拟机和宿主机之间的通信方法、宿主机和虚拟机系统 |
KR20170061048A (ko) * | 2015-11-25 | 2017-06-02 | 한국전자통신연구원 | 하이퍼바이저 기반 가상화 시스템의 지연 시간을 측정하기 위한 장치 및 이를 포함하는 가상화 시스템 |
CN108829493A (zh) * | 2018-06-22 | 2018-11-16 | 山东超越数控电子股份有限公司 | 一种虚拟机时间同步方法与装置 |
CN109194432A (zh) * | 2018-08-13 | 2019-01-11 | 华东计算技术研究所(中国电子科技集团公司第三十二研究所) | 一种kvm下多虚拟机时间同步系统 |
CN110377106A (zh) * | 2019-06-21 | 2019-10-25 | 湖南麒麟信安科技有限公司 | 一种时统卡虚拟化方法、系统及介质 |
CN111857237A (zh) * | 2020-07-27 | 2020-10-30 | 山东超越数控电子股份有限公司 | 一种时钟同步方法、系统、设备以及介质 |
CN112904932A (zh) * | 2021-05-08 | 2021-06-04 | 鹏城实验室 | 时钟同步方法、板卡、计算机存储介质及终端设备 |
-
2021
- 2021-09-07 CN CN202111044383.9A patent/CN113672031A/zh active Pending
Patent Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103593246A (zh) * | 2012-08-15 | 2014-02-19 | 中国电信股份有限公司 | 虚拟机和宿主机之间的通信方法、宿主机和虚拟机系统 |
KR20170061048A (ko) * | 2015-11-25 | 2017-06-02 | 한국전자통신연구원 | 하이퍼바이저 기반 가상화 시스템의 지연 시간을 측정하기 위한 장치 및 이를 포함하는 가상화 시스템 |
CN108829493A (zh) * | 2018-06-22 | 2018-11-16 | 山东超越数控电子股份有限公司 | 一种虚拟机时间同步方法与装置 |
CN109194432A (zh) * | 2018-08-13 | 2019-01-11 | 华东计算技术研究所(中国电子科技集团公司第三十二研究所) | 一种kvm下多虚拟机时间同步系统 |
CN110377106A (zh) * | 2019-06-21 | 2019-10-25 | 湖南麒麟信安科技有限公司 | 一种时统卡虚拟化方法、系统及介质 |
CN111857237A (zh) * | 2020-07-27 | 2020-10-30 | 山东超越数控电子股份有限公司 | 一种时钟同步方法、系统、设备以及介质 |
CN112904932A (zh) * | 2021-05-08 | 2021-06-04 | 鹏城实验室 | 时钟同步方法、板卡、计算机存储介质及终端设备 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN109766124B (zh) | 业务开发方法、装置、计算机设备和存储介质 | |
WO2019000630A1 (zh) | 多任务调度方法、系统、应用服务器及计算机可读存储介质 | |
CN108829485A (zh) | 应用界面布局的更新方法、装置、存储介质及计算机设备 | |
CN103559054A (zh) | 智能终端多操作系统的实现、删除方法和装置 | |
CN110602165B (zh) | 政务数据同步方法、装置、系统、计算机设备和存储介质 | |
EP3879875A1 (en) | Resource change method and device, apparatus, and storage medium | |
CN112463239A (zh) | Bios与bmc交互选项默认值修改方法、系统、终端及存储介质 | |
CN111857777A (zh) | 基于双芯智能电表的系统更新方法、装置和计算机设备 | |
CN110764788A (zh) | 云存储部署方法、装置、计算机设备和可读存储介质 | |
CN112003895B (zh) | OpenStack云平台中云主机疏散方法、装置、设备及存储介质 | |
CN112910723A (zh) | 边缘终端管理方法、装置、设备及存储介质 | |
CN110955508A (zh) | 基于分布式架构的异步任务调度方法、装置和计算机设备 | |
CN109634140B (zh) | 运行环境数据的更新方法、装置、机组及计算机设备 | |
CN109189499B (zh) | Java程序的管理方法、装置、计算机设备及存储介质 | |
CN106293790B (zh) | 基于Firefox操作系统的应用程序升级方法和装置 | |
CN113672031A (zh) | 一种时间同步方法、装置、计算机设备及存储介质 | |
CN112416350A (zh) | 视图页面构建方法、装置、计算机设备和存储介质 | |
CN112783866A (zh) | 数据读取方法、装置、计算机设备和存储介质 | |
CN112148351A (zh) | 一种应用软件跨版本兼容的方法和系统 | |
CN111159271A (zh) | 数据处理方法、装置、计算机设备及存储介质 | |
CN115622815A (zh) | 基于虚拟化环境的端口隔离实现方法、装置、设备及介质 | |
CN107453959B (zh) | 一种网卡的管理方法及其装置 | |
CN114138408A (zh) | 克隆卷创建的方法、装置、计算机设备和存储介质 | |
CN112559248A (zh) | 预处理服务恢复方法、装置、设备及存储介质 | |
CN113031984A (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 |