CN115617489B - 操作系统迁移方法、迁移应用及迁移应用部署方法 - Google Patents

操作系统迁移方法、迁移应用及迁移应用部署方法 Download PDF

Info

Publication number
CN115617489B
CN115617489B CN202211388529.6A CN202211388529A CN115617489B CN 115617489 B CN115617489 B CN 115617489B CN 202211388529 A CN202211388529 A CN 202211388529A CN 115617489 B CN115617489 B CN 115617489B
Authority
CN
China
Prior art keywords
operating system
migration
target
level
software package
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.)
Active
Application number
CN202211388529.6A
Other languages
English (en)
Other versions
CN115617489A (zh
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.)
Uniontech Software Technology Co Ltd
Original Assignee
Uniontech Software 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 Uniontech Software Technology Co Ltd filed Critical Uniontech Software Technology Co Ltd
Priority to CN202211388529.6A priority Critical patent/CN115617489B/zh
Publication of CN115617489A publication Critical patent/CN115617489A/zh
Application granted granted Critical
Publication of CN115617489B publication Critical patent/CN115617489B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/46Multiprogramming arrangements
    • G06F9/48Program initiating; Program switching, e.g. by interrupt
    • G06F9/4806Task transfer initiation or dispatching
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/61Installation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/65Updates
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5005Allocation of resources, e.g. of the central processing unit [CPU] to service a request
    • G06F9/5027Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Security & Cryptography (AREA)
  • Stored Programmes (AREA)
  • Debugging And Monitoring (AREA)

Abstract

本发明公开了一种操作系统迁移方法、迁移应用及迁移应用部署方法,涉及操作系统技术领域,方法包括:将目标操作系统与原始操作系统的软件包进行对比,以确定目标操作系统与原始操作系统的兼容度;根据兼容度确定是否迁移目标操作系统;如果确定迁移目标操作系统,则从服务端获取目标操作系统的当前迁移状态;如果当前迁移状态不是正在迁移,则从服务端获取目标操作系统的当前迁移级别;根据当前迁移级别,执行对应的当前迁移任务,并向服务端请求将当前迁移级别更新为下一迁移级别,直至执行完成最后级别对应的最后迁移任务。根据本发明的技术方案,可以根据兼容度来判断迁移的可实施性,并能实现根据操作系统软件包的重要程度来进行分级迁移。

Description

操作系统迁移方法、迁移应用及迁移应用部署方法
技术领域
本发明涉及操作系统技术领域,尤其涉及一种操作系统迁移方法、迁移应用及迁移应用部署方法。
背景技术
随着国产操作系统的发展,目前,针对市场上已有的操作系统(例如CentOS操作系统)的存量,需要在不删除用户业务数据、服务以及不重新安装新的操作系统前提下,将已有的操作系统以及已有的相关业务平滑迁移到国产操作系统上。在保证新的操作系统顺利迁移的同时,还需要确保业务在新的操作系统上正常运行。
现有技术中,无法将操作系统的多个软件包按照重要程度进行分级迁移,迁移中断后便无法继续迁移,需要重新开始迁移,并会中断系统运行服务。而且,在迁移过程中无法使用系统桌面环境。另外,对于批量迁移操作系统的场景,需要人工在多个客户端配置迁移服务,配置步骤繁琐。
为此,需要一种操作系统迁移方法,以解决上述技术方案中存在的问题。
发明内容
为此,本发明提供一种操作系统迁移方法、迁移应用及迁移应用部署方法,以解决或至少缓解上面存在的问题。
根据本发明的一个方面,提供一种操作系统迁移方法,在客户端执行,所述客户端包括原始操作系统,所述客户端与服务端通信连接,所述方法包括:将目标操作系统与所述原始操作系统的软件包进行对比,以确定所述目标操作系统与原始操作系统的兼容度;根据所述兼容度确定是否迁移所述目标操作系统;如果确定迁移所述目标操作系统,则从所述服务端获取所述目标操作系统的当前迁移状态;如果所述当前迁移状态不是正在迁移,则从所述服务端获取所述目标操作系统的当前迁移级别;根据所述当前迁移级别,执行对应的当前迁移任务,并向所述服务端请求将所述当前迁移级别更新为下一迁移级别,直至执行完成最后级别对应的最后迁移任务。
可选地,在根据本发明的操作系统迁移方法中,根据所述当前迁移级别,执行对应的当前迁移任务,包括:判断所述当前迁移级别是否是最后级别;如果不是最后级别,则根据所述当前迁移级别,执行对应的当前迁移任务。
可选地,在根据本发明的操作系统迁移方法中,还包括:如果所述当前迁移级别是最后级别,则执行最后级别对应的最后迁移任务。
可选地,在根据本发明的操作系统迁移方法中,向所述服务端请求将所述当前迁移级别更新为下一迁移级别,包括:判断所述当前迁移任务是否执行成功;如果执行成功,则向所述服务端请求将所述当前迁移级别更新为下一迁移级别。
可选地,在根据本发明的操作系统迁移方法中,所述目标操作系统包括多个目标软件包,所述原始操作系统包括与所述多个目标软件包相对应的多个原始软件包;其中,将目标操作系统与所述原始操作系统的软件包进行对比,以确定所述目标操作系统与原始操作系统的兼容度,包括:将每个目标软件包分别与对应的原始软件包进行对比,以确定每个目标软件包是否与对应的原始软件包兼容;根据每个目标软件包的级别,确定所述目标软件包对应的权重值;根据每个目标软件包是否与对应的原始软件包兼容、以及所述目标软件包对应的权重值,确定所述目标操作系统与原始操作系统的兼容度。
可选地,在根据本发明的操作系统迁移方法中,根据所述兼容度确定是否迁移所述目标操作系统,包括:判断所述兼容度是否达到预定兼容度;如果达到预定兼容度,则确定迁移所述目标操作系统。
根据本发明的一个方面,提供一种迁移应用,部署在客户端,所述客户端包括原始操作系统,所述客户端与服务端通信连接,所述迁移应用包括:评估模块,适于将目标操作系统与所述原始操作系统的软件包进行对比,以确定所述目标操作系统与原始操作系统的兼容度,并适于根据所述兼容度确定是否迁移所述目标操作系统;迁移模块,如果确定迁移所述目标操作系统,所述迁移模块适于从所述服务端获取所述目标操作系统的当前迁移状态;如果所述当前迁移状态不是正在迁移,所述迁移模块适于从所述服务端获取所述目标操作系统的当前迁移级别,根据所述当前迁移级别,执行对应的当前迁移任务,并向所述服务端请求将所述当前迁移级别更新为下一迁移级别,直至执行完成最后级别对应的最后迁移任务。
根据本发明的一个方面,提供一种迁移应用部署方法,在服务端执行,所述方法包括:获取客户端设备信息列表,将所述客户端设备信息列表中的多个客户端设备信息依次写入消息队列;创建多个线程,通过所述多个线程从所述消息队列中读取每个客户端设备信息,并根据所述客户端设备信息对客户端进行用户权限验证;如果用户权限验证通过,则在所述客户端安装迁移应用,以便所述客户端通过所述迁移应用进行操作系统迁移。
根据本发明的一个方面,提供一种计算设备,包括:至少一个处理器;存储器,存储有程序指令,其中,程序指令被配置为适于由上述至少一个处理器执行,所述程序指令包括用于执行如上所述的操作系统迁移方法的指令。
根据本发明的一个方面,提供一种存储有程序指令的可读存储介质,当该程序指令被计算设备读取并执行时,使得该计算设备执行如上所述的操作系统迁移方法。
根据本发明的技术方案,提供了一种操作系统迁移方法,其中,通过将目标操作系统与原始操作系统的软件包进行对比,来确定目标操作系统与原始操作系统的兼容度,根据兼容度是否达到预定兼容度来确定是否能够迁移目标操作系统。如果能够迁移目标操作系统,则从服务端获取目标操作系统的当前迁移状态,并在确定当前迁移状态不是正在迁移的情况下,从服务端获取目标操作系统的当前迁移级别。根据当前迁移级别,执行对应的当前迁移任务,并向服务端请求将当前迁移级别更新为下一迁移级别,并循环执行上述步骤,直至执行完成最后级别对应的最后迁移任务。这样,根据本发明的方法,可以根据兼容度来判断迁移的可实施性,并且,能实现根据操作系统软件包的重要程度来进行分级迁移。这样,在某一级别出错而导致迁移中断的情况下,通过处理相关问题后可以继续执行迁移任务,并且,在此期间系统桌面环境会保持运行状态,系统所运行的服务会继续运行,在整个迁移过程中,桌面环境为可使用状态。
此外,根据本发明的迁移应用部署方法,可以在多个客户端部署迁移应用,从而,能实现在多个客户端批量进行目标操作系统的迁移。
上述说明仅是本发明技术方案的概述,为了能够更清楚了解本发明的技术手段,而可依照说明书的内容予以实施,并且为了让本发明的上述和其它目的、特征和优点能够更明显易懂,以下特举本发明的具体实施方式。
附图说明
为了实现上述以及相关目的,本文结合下面的描述和附图来描述某些说明性方面,这些方面指示了可以实践本文所公开的原理的各种方式,并且所有方面及其等效方面旨在落入所要求保护的主题的范围内。通过结合附图阅读下面的详细描述,本公开的上述以及其它目的、特征和优势将变得更加明显。遍及本公开,相同的附图标记通常指代相同的部件或元素。
图1示出了根据本发明一个实施例的计算设备100的示意图;
图2示出了根据本发明一个实施例的操作系统迁移方法200的流程示意图;
图3出了根据本发明一个实施例的迁移应用300的示意图;
图4示出了根据本发明一个实施例的批量迁移系统400的示意图;
图5示出了根据本发明一个实施例的迁移应用部署方法500的流程示意图。
具体实施方式
下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。
图1示出了根据本发明一个实施例的计算设备100的示意图。如图1所示,在基本配置中,计算设备100包括至少一个处理单元102和系统存储器104。根据一个方面,取决于计算设备的配置和类型,处理单元102可以实现为处理器。系统存储器104包括但不限于易失性存储(例如,随机存取存储器)、非易失性存储(例如,只读存储器)、闪速存储器、或者这样的存储器的任何组合。根据一个方面,系统存储器104中包括操作系统105。
根据一个方面,操作系统105例如适合于控制计算设备100的操作。此外,示例结合图形库、其他操作系统、或任何其他应用程序而被实践,并且不限于任何特定的应用或系统。在图1中通过在虚线内的那些组件示出了该基本配置。根据一个方面,计算设备100具有额外的特征或功能。例如,根据一个方面,计算设备100包括额外的数据存储设备(可移动的和/或不可移动的),例如磁盘、光盘、或者磁带。这样额外的存储在图1中是由可移动存储设备109和不可移动存储设备110示出的。
如在上文中所陈述的,根据一个方面,在系统存储器104中存储有程序模块103。根据一个方面,程序模块103可以包括一个或多个应用程序,本发明不限制应用程序的类型,例如应用程序可以包括:电子邮件和联系人应用程序、文字处理应用程序、电子表格应用程序、数据库应用程序、幻灯片展示应用程序、绘画或计算机辅助应用程序、网络浏览器应用程序等。
根据一个方面,程序模块103包括迁移应用300,迁移应用300中包括适于执行本发明的操作系统迁移方法200的多条程序指令。
根据一个方面,可以在包括分立电子元件的电路、包含逻辑门的封装或集成的电子芯片、利用微处理器的电路、或者在包含电子元件或微处理器的单个芯片上实践示例。例如,可以经由其中在图1中所示出的每个或许多组件可以集成在单个集成电路上的片上系统(SOC)来实践示例。根据一个方面,这样的SOC设备可以包括一个或多个处理单元、图形单元、通信单元、系统虚拟化单元、以及各种应用功能,其全部作为单个集成电路而被集成(或“烧”)到芯片基底上。当经由SOC进行操作时,可以经由在单个集成电路(芯片)上与计算设备100的其他组件集成的专用逻辑来对在本文中所描述的功能进行操作。还可以使用能够执行逻辑操作(例如AND、OR和NOT)的其他技术来实践本发明的实施例,所述其他技术包括但不限于机械、光学、流体、和量子技术。另外,可以在通用计算机内或在任何其他任何电路或系统中实践本发明的实施例。
根据一个方面,计算设备100还可以具有一个或多个输入设备112,例如键盘、鼠标、笔、语音输入设备、触摸输入设备等。还可以包括输出设备114,例如显示器、扬声器、打印机等。前述设备是示例并且也可以使用其他设备。计算设备100可以包括允许与其他计算设备118进行通信的一个或多个通信连接116。合适的通信连接116的示例包括但不限于:RF发射机、接收机和/或收发机电路;通用串行总线(USB)、并行和/或串行端口。
如在本文中所使用的术语计算机可读介质包括计算机存储介质。计算机存储介质可以包括以任何用于存储信息(例如,计算机可读指示、数据结构、或程序模块103)的方法或技术来实现的易失性的和非易失性的、可移动的和不可移动的介质。系统存储器104、可移动存储设备109、和不可移动存储设备110都是计算机存储介质的示例(即,存储器存储)。计算机存储介质可以包括随机存取存储器(RAM) 、只读存储器(ROM) 、电可擦只读存储器(EEPROM)、闪速存储器或其他存储器技术、CD-ROM、数字通用盘(DVD)或其他光存储、盒式磁带、磁带、磁盘存储器或其他磁存储设备、或者可用于存储信息并且可以由计算设备100访问的任何其他制品。根据一个方面,任何这样的计算机存储介质都可以是计算设备100的一部分。计算机存储介质不包括载波或其他经传播的数据信号。
根据一个方面,通信介质是由计算机可读指令、数据结构、程序模块103、或者经调制的数据信号(例如,载波或其他传输机制)中的其他数据实施的,并且包括任何信息传递介质。根据一个方面,术语“经调制的数据信号”描述了具有一个或多个特征集或者以将信息编码在信号中的方式改变的信号。作为示例而非限制,通信介质包括诸如有线网络或直接有线连接之类的有线介质,以及诸如声学、射频(RF)、红外线的、以及其他无线介质之类的无线介质。
在根据本发明的实施例中,计算设备100被配置为执行根据本发明的操作系统迁移方法200或者迁移应用部署方法500。计算设备100包括一个或多个处理器、以及存储有程序指令的一个或多个可读存储介质,当程序指令被配置为由一个或多个处理器执行时,使得计算设备执行本发明实施例中的操作系统迁移方法200或者迁移应用部署方法500。
根据本发明的一个实施例,计算设备100中驻留有迁移应用300,迁移应用300被配置为执行根据本发明的操作系统迁移方法200。
图2示出了根据本发明一个实施例的操作系统迁移方法200的流程示意图。操作系统迁移方法200适于在客户端(例如前述计算设备100)的迁移应用300中执行。客户端与服务端通信连接。
需要说明的是,客户端包括原始操作系统,待迁移的新操作系统是目标操作系统,即,需要将目标操作系统迁移至客户端。
如图2所示,操作系统迁移方法200包括步骤210~250。
图3出了根据本发明一个实施例的迁移应用300的示意图。如图3所示,迁移应用300包括评估模块310、迁移模块320。其中,评估模块310可以被配置为执行步骤210~220,迁移模块320可以被配置为执行步骤230~250。
如图2所示,在步骤210中,通过评估模块310,将待迁移的目标操作系统与原始操作系统的软件包进行对比,以确定目标操作系统与原始操作系统的兼容度。这里,兼容度具体可以是兼容度百分比。
在一个实施例中,评估模块310可以利用libabigail工具,来将待迁移的目标操作系统与原始操作系统的软件包的二进制文件进行对比,以查找目标操作系统与原始操作系统的软件包之间的差异。
需要说明的是,原始操作系统、目标操作系统分别包括多个不同级别的软件包,不同级别的软件包可以对应不同的权重值,换言之,每个级别分别对应一个权重值,权重值可以反映相应级别的软件包的重要程度。也就是说,本发明将操作系统的多个软件包按照重要程度划分为多个级别,每个级别可以包含一个或多个软件包,每个级别分别对应一个权重值。
具体地,目标操作系统包括多个目标软件包,原始操作系统包括与多个目标软件包相对应的多个原始软件包,其中每个目标软件包分别对应一个原始软件包。
具体地,在步骤210中,将待迁移的目标操作系统与原始操作系统的软件包进行对比,具体可以将每个目标软件包分别与对应的原始软件包进行对比,以确定每个目标软件包是否与对应的原始软件包兼容。随后,根据每个目标软件包的级别,来确定目标软件包对应的权重值。也即,确定每个目标软件包的级别对应的权重值。进而,根据每个目标软件包是否与对应的原始软件包兼容、以及目标软件包对应的权重值,来确定目标操作系统与原始操作系统的兼容度。
在一个实施例中,对于目标操作系统的每个目标软件包,如果确定目标软件包与对应的原始软件包兼容,则可以将该目标软件包的名称以及对应的级别写入兼容列表。如果确定目标软件包与对应的原始软件包不兼容,则可以将该目标软件包的名称以及对应的级别写入不兼容列表。这样,在将目标操作系统与原始操作系统的全部软件包对比完成后,可以得到兼容列表、不兼容列表。
需要说明的是,本发明将操作系统的多个软件包划分为多个级别,其中,每个级别可以包含一个或多个软件包。这样,后续可以将软件包的级别作为迁移级别,根据级别来对软件包进行迁移,即,按照级别顺序依次迁移各个级别的软件包。
另外,可以分别为每个级别创建一个级别权重列表,每个级别权重列表分别对应一个权重值。这样,通过遍历兼容列表、不兼容列表中的每个目标软件包信息,确定目标软件包的级别、并将目标软件包名称写入与级别相对应的级别权重列表。在遍历完成后,便将兼容列表中的每个兼容的目标软件包、不兼容列表中的每个不兼容的目标软件包的名称分别写入相应的级别权重列表中。
进而,可以每个级别权重列表对应的权重值、以及级别权重列表中的每个目标软件包是否(与原始软件包)兼容,来计算目标操作系统与原始操作系统的兼容度,得到的是兼容度百分比。
随后,在步骤220中,通过评估模块310,根据目标操作系统与原始操作系统的兼容度,来确定是否迁移目标操作系统。
在一个实施例中,预定兼容度可以作为判断能否迁移目标操作系统的标准。具体地,在步骤220中,可以判断目标操作系统与原始操作系统的兼容度是否达到(大于或等于)预定兼容度。如果目标操作系统与原始操作系统的兼容度达到预定兼容度,则确定迁移目标操作系统。反之,目标操作系统与原始操作系统的兼容度未达到预定兼容度,则不能够迁移目标操作系统,此时结束迁移流程,不再进行目标操作系统的迁移。
在一种实现方式中,预定兼容度例如可以为90%。
但,应当指出,本发明对预定兼容度的具体数值不做限制,其可以由本领域技术人员根据实际情况来确定。
如果确定迁移目标操作系统,则通过迁移模块320执行下述步骤230。
在步骤230中,通过迁移模块320,请求从服务端获取客户端对目标操作系统的当前迁移状态。
需要说明的是,服务端的数据存储装置中可以存储客户端对目标操作系统的当前迁移状态和目标操作系统的当前迁移级别,并且,可以根据客户端的操作而更新目标操作系统的迁移状态和迁移级别。从而,迁移模块320可以从服务端的数据存储装置中获取目标操作系统的当前迁移状态。
随后,迁移模块320判断目标操作系统的当前迁移状态是否是正在迁移,如果当前迁移状态是正在迁移,则结束本次迁移流程。如果当前迁移状态不是正在迁移,并且,在确认没有正在执行其他任务的情况下,可以继续执行步骤240。
在步骤240中,从服务端(的数据存储装置)获取目标操作系统的当前迁移级别。这里,当前迁移级别即是当前迁移的目标操作系统的目标软件包的级别。
最后,在步骤250中,通过迁移模块320,根据目标操作系统的当前迁移级别,执行当前迁移级别对应的当前迁移任务。随后,判断当前迁移任务是否执行成功,如果当前迁移任务执行成功,则向服务端请求将目标操作系统的当前迁移级别更新为下一迁移级别(作为新的当前迁移级别)。
需要说明的是,执行当前迁移级别对应的当前迁移任务,即是,对当前迁移级别包含的一个或多个(目标操作系统的)目标软件包进行迁移。
另外,如果当前迁移任务执行失败,则可以将执行失败信息存储在报错日志,并退出迁移模块320。在根据报错日志处理相关问题后,可以重新调用迁移模块320来继续执行迁移任务。在此期间,系统桌面环境会一直保持运行状态,并且,系统运行的服务会继续运行。
通过循环执行上述步骤230~250,直至执行完成最后级别对应的最后迁移任务,完成对目标操作系统的迁移流程。
具体地,在向服务端请求将目标操作系统的当前迁移级别更新为下一迁移级别(作为新的当前迁移级别)之后,返回至上述步骤230,再次请求从服务端获取目标操作系统的新的当前迁移状态,并在步骤240中从服务端获取目标操作系统的新的当前迁移级别,此时获取到的是更新后的下一迁移级别,接着,根据下一迁移级别执行步骤250。这样,通过循环执行步骤230~250,直至执行完成最后级别对应的最后迁移任务。
在一个实施例中,在执行步骤240之后,即,在从服务端的数据存储装置获取目标操作系统的当前迁移级别后,还判断当前迁移级别是否是最后级别。
如果当前迁移级别不是最后级别,则执行步骤250,根据目标操作系统的当前迁移级别,执行对应的当前迁移任务。
另外,如果当前迁移级别是最后级别,则执行最后级别对应的最后迁移任务(即,对最后级别包含的一个或多个目标软件包进行迁移)。在执行最后迁移任务后,可以确定迁移完毕。
根据本发明的操作系统迁移方法200,可以根据兼容度来判断迁移的可实施性,并且,能实现根据操作系统软件包的重要程度来进行分级迁移,这样,在某一级别出错而导致迁移中断的情况下,通过处理相关问题后可以继续执行迁移任务,并且,在此期间系统桌面环境会保持运行状态,系统所运行的服务会继续运行,且在整个迁移过程中,桌面环境为可使用状态。另外,在客户端下一次启动操作系统内核时,会启动新迁移的目标操作系统的内核。
此外,需要说明的是,根据本发明的操作系统迁移方法200,可以在多个客户端执行,以便在多个客户端批量进行目标操作系统的迁移。
图4示出了根据本发明一个实施例的批量迁移系统400的示意图。如图4所示,批量迁移系统400包括服务端420、多个客户端410。其中,服务端420可以与多个客户端410分别建立远程通信连接。
在多个客户端410批量进行目标操作系统的迁移之前,需要在多个客户端410部署迁移应用300。
图5示出了根据本发明一个实施例的迁移应用部署方法500的流程示意图。迁移应用部署方法500适于在服务端420(例如前述计算设备100)执行,具体可以在服务端420的验证待检模块中执行。服务端420可以与多个客户端410通信连接。
如图5所示,迁移应用部署方法500包括步骤510~530。
在步骤510中,获取客户端设备信息列表,客户端设备信息列表中包括多个客户端设备信息,客户端设备信息例如包括客户端的IP信息。随后,通过创建消息队列,将客户端设备信息列表中的多个客户端设备信息依次写入消息队列中。
接着,在步骤520中,创建多个线程,具体地,创建包括多个线程的线程池。通过多个线程从可以消息队列中读取每个客户端设备信息,其中,每个线程每次从消息队列中读取一个客户端设备信息,并根据客户端设备信息来对客户端410进行用户权限验证。这里,服务端通过获取用户在客户端输入的用户信息(例如包括账号信息、密码信息),并对用户信息进行权限验证,以确定是否验证通过。
如果用户权限验证通过,则执行步骤530。
在步骤530中,在用户权限验证通过的客户端410安装迁移应用300,以便客户端410通过迁移应用300进行操作系统迁移,即迁移目标操作系统。
具体地,客户端的迁移应用300通过执行前文所述的操作系统迁移方法200,可以实现将目标操作系统迁移至客户端410。
在一个实施例中,在客户端410安装迁移应用300之后,服务端420可以根据迁移配置文件来确定该客户端410是否满足迁移服务条件,如果满足迁移服务条件,则服务端420可以远程启动客户端410的迁移应用300。随后,可以通过迁移应用300获取客户端410本地的操作系统信息。即,迁移应用300通过获取客户端410本地的原始操作系统信息,并将原始操作系统信息发送至服务端420,服务端420可以将客户端410的原始操作系统信息存储在与服务端420通信相连的数据存储装置中。
在一种实现方式中,迁移应用300可以调用客户端的本地信息接口来获取客户端本地的操作系统信息,并可以调用读取配置文件接口来获取服务端420的IP、数据存储装置的账户和密码信息,并将这些信息作为参数传递给数据存储装置的接口,以便将客户端本地的操作系统信息写入数据存储装置。
在一个实施例中,在步骤530中,可以通过远程调用Yum(Yellow dog Updater,Modified,前端软件包管理器),来实现在客户端410安装迁移应用300。
需要说明的是,Yum(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat以及CentOS中的Shell前端软件包管理器。基于RPM包管理,能够从指定的服务器自动下载RPM包并且安装,可以自动查询依赖性关系,并且一次安装所有依赖的软件包,无须繁琐下载和安装。
还需要说明的是,每个线程每次从消息队列中读取一个客户端设备信息,并根据客户端设备信息来对客户端410进行用户权限验证,并在用户权限验证通过后,执行步骤530。在执行完成步骤530后,向服务端返回安装和配置结果。多个线程同步执行该过程,直至消息队列中的所有客户端设备信息读取完毕、消息队列为空。
根据本发明的迁移应用部署方法500,通过将客户端设备信息列表中的信息写入消息队列中,并通过多个线程从消息队列中读取客户端设备信息,对客户端进行用户权限验证,并在验证通过后在客户端安装迁移应用。这样,不仅可以简化客户端配置迁移服务的步骤,在操作时不需要配置原始操作系统,而且,提高了配置过程的安全性。
根据本发明的操作系统迁移方法,通过将目标操作系统与原始操作系统的软件包进行对比,来确定目标操作系统与原始操作系统的兼容度,根据兼容度是否达到预定兼容度来确定是否能够迁移目标操作系统。如果能够迁移目标操作系统,则从服务端获取目标操作系统的当前迁移状态,并在确定当前迁移状态不是正在迁移的情况下,从服务端获取目标操作系统的当前迁移级别。根据当前迁移级别,执行对应的当前迁移任务,并向服务端请求将当前迁移级别更新为下一迁移级别,并循环执行上述步骤,直至执行完成最后级别对应的最后迁移任务。这样,根据本发明的方法,可以根据兼容度来判断迁移的可实施性,并且,能实现根据操作系统软件包的重要程度来进行分级迁移。这样,在某一级别出错而导致迁移中断的情况下,通过处理相关问题后可以继续执行迁移任务,并且,在此期间系统桌面环境会保持运行状态,系统所运行的服务会继续运行,在整个迁移过程中,桌面环境为可使用状态。
此外,根据本发明的迁移应用部署方法,可以在多个客户端部署迁移应用,从而,能实现在多个客户端批量进行目标操作系统的迁移。
这里描述的各种技术可结合硬件或软件,或者它们的组合一起实现。从而,本发明的方法和设备,或者本发明的方法和设备的某些方面或部分可采取嵌入有形媒介,例如可移动硬盘、U盘、软盘、CD-ROM或者其它任意机器可读的存储介质中的程序代码(即指令)的形式,其中当程序被载入诸如计算机之类的机器,并被所述机器执行时,所述机器变成实践本发明的设备。
在程序代码在可编程计算机上执行的情况下,移动终端一般包括处理器、处理器可读的存储介质(包括易失性和非易失性存储器和/或存储元件),至少一个输入装置,和至少一个输出装置。其中,存储器被配置用于存储程序代码;处理器被配置用于根据该存储器中存储的所述程序代码中的指令,执行本发明的操作系统迁移方法。
以示例而非限制的方式,可读介质包括可读存储介质和通信介质。可读存储介质存储诸如计算机可读指令、数据结构、程序模块或其它数据等信息。通信介质一般以诸如载波或其它传输机制等已调制数据信号来体现计算机可读指令、数据结构、程序模块或其它数据,并且包括任何信息传递介质。以上的任一种的组合也包括在可读介质的范围之内。
在此处所提供的说明书中,算法和显示不与任何特定计算机、虚拟系统或者其它设备固有相关。各种通用系统也可以与本发明的示例一起使用。根据上面的描述,构造这类系统所要求的结构是显而易见的。此外,本发明也不针对任何特定编程语言。应当明白,可以利用各种编程语言实现在此描述的本发明的内容,并且上面对特定语言所做的描述是为了披露本发明的最佳实施方式。
在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下被实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。
类似地,应当理解,为了精简本公开并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。
本领域那些技术人员应当理解在本文所公开的示例中的设备的模块或单元或组件可以布置在如该实施例中所描述的设备中,或者可替换地可以定位在与该示例中的设备不同的一个或多个设备中。前述示例中的模块可以组合为一个模块或者此外可以分成多个子模块。
本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组件组合成一个模块或单元或组件,以及此外可以把它们分成多个子模块或子单元或子组件。
此外,本领域的技术人员能够理解,尽管在此所述的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。
此外,所述实施例中的一些在此被描述成可以由计算机系统的处理器或者由执行所述功能的其它装置实施的方法或方法元素的组合。因此,具有用于实施所述方法或方法元素的必要指令的处理器形成用于实施该方法或方法元素的装置。此外,装置实施例的在此所述的元素是如下装置的例子:该装置用于实施由为了实施该发明的目的的元素所执行的功能。
如在此所使用的那样,除非另行规定,使用序数词“第一”、“第二”、“第三”等等来描述普通对象仅仅表示涉及类似对象的不同实例,并且并不意图暗示这样被描述的对象必须具有时间上、空间上、排序方面或者以任意其它方式的给定顺序。
尽管根据有限数量的实施例描述了本发明,但是受益于上面的描述,本技术领域内的技术人员明白,在由此描述的本发明的范围内,可以设想其它实施例。此外,应当注意,本说明书中使用的语言主要是为了可读性和教导的目的而选择的,而不是为了解释或者限定本发明的主题而选择的。

Claims (8)

1.一种操作系统迁移方法,在客户端执行,所述客户端包括原始操作系统,待迁移的操作系统为目标操作系统,所述原始操作系统、目标操作系统分别包括多个不同级别的软件包,每个级别分别对应一个权重值,其中,所述目标操作系统包括多个目标软件包,所述原始操作系统包括与所述多个目标软件包相对应的多个原始软件包,其中每个目标软件包分别对应一个原始软件包,所述客户端与服务端通信连接,所述方法包括:
利用libabigail工具,将目标操作系统与所述原始操作系统的软件包的二进制文件进行对比,包括:将每个目标软件包分别与对应的原始软件包进行对比,以确定每个目标软件包是否与对应的原始软件包兼容;根据每个目标软件包的级别,确定所述目标软件包对应的权重值;根据每个目标软件包是否与对应的原始软件包兼容、以及所述目标软件包对应的权重值,确定所述目标操作系统与原始操作系统的兼容度;
根据所述兼容度确定是否迁移所述目标操作系统;
如果确定迁移所述目标操作系统,则从所述服务端获取所述目标操作系统的当前迁移状态;
如果所述当前迁移状态不是正在迁移,则从所述服务端获取所述目标操作系统的当前迁移级别;
根据所述当前迁移级别,执行对应的当前迁移任务,并向所述服务端请求将所述当前迁移级别更新为下一迁移级别,直至执行完成最后级别对应的最后迁移任务。
2.如权利要求1所述的方法,其中,根据所述当前迁移级别,执行对应的当前迁移任务,包括:
判断所述当前迁移级别是否是最后级别;
如果不是最后级别,则根据所述当前迁移级别,执行对应的当前迁移任务。
3.如权利要求2所述的方法,其中,还包括:
如果所述当前迁移级别是最后级别,则执行最后级别对应的最后迁移任务。
4.如权利要求1-3中任一项所述的方法,其中,向所述服务端请求将所述当前迁移级别更新为下一迁移级别,包括:
判断所述当前迁移任务是否执行成功;
如果执行成功,则向所述服务端请求将所述当前迁移级别更新为下一迁移级别。
5.如权利要求1-3中任一项所述的方法,其中,根据所述兼容度确定是否迁移所述目标操作系统,包括:
判断所述兼容度是否达到预定兼容度;
如果达到预定兼容度,则确定迁移所述目标操作系统。
6.一种迁移装置,部署在客户端,所述客户端包括原始操作系统,待迁移的操作系统为目标操作系统,所述原始操作系统、目标操作系统分别包括多个不同级别的软件包,每个级别分别对应一个权重值,其中,所述目标操作系统包括多个目标软件包,所述原始操作系统包括与所述多个目标软件包相对应的多个原始软件包,其中每个目标软件包分别对应一个原始软件包,所述客户端与服务端通信连接,所述迁移装置包括:
评估模块,适于利用libabigail工具,将目标操作系统与所述原始操作系统的软件包的二进制文件进行对比,包括:将每个目标软件包分别与对应的原始软件包进行对比,以确定每个目标软件包是否与对应的原始软件包兼容;根据每个目标软件包的级别,确定所述目标软件包对应的权重值;根据每个目标软件包是否与对应的原始软件包兼容、以及所述目标软件包对应的权重值,确定所述目标操作系统与原始操作系统的兼容度,并适于根据所述兼容度确定是否迁移所述目标操作系统;
迁移模块,如果确定迁移所述目标操作系统,所述迁移模块适于从所述服务端获取所述目标操作系统的当前迁移状态;如果所述当前迁移状态不是正在迁移,所述迁移模块适于从所述服务端获取所述目标操作系统的当前迁移级别,根据所述当前迁移级别,执行对应的当前迁移任务,并向所述服务端请求将所述当前迁移级别更新为下一迁移级别,直至执行完成最后级别对应的最后迁移任务。
7.一种计算设备,包括:
至少一个处理器;以及
存储器,存储有程序指令,其中,所述程序指令被配置为适于由所述至少一个处理器执行,所述程序指令包括用于执行如权利要求1-5中任一项所述的方法的指令。
8.一种存储有程序指令的可读存储介质,当所述程序指令被计算设备读取并执行时,使得所述计算设备执行如权利要求1-5中任一项所述方法。
CN202211388529.6A 2022-11-08 2022-11-08 操作系统迁移方法、迁移应用及迁移应用部署方法 Active CN115617489B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202211388529.6A CN115617489B (zh) 2022-11-08 2022-11-08 操作系统迁移方法、迁移应用及迁移应用部署方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202211388529.6A CN115617489B (zh) 2022-11-08 2022-11-08 操作系统迁移方法、迁移应用及迁移应用部署方法

Publications (2)

Publication Number Publication Date
CN115617489A CN115617489A (zh) 2023-01-17
CN115617489B true CN115617489B (zh) 2023-03-28

Family

ID=84878420

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202211388529.6A Active CN115617489B (zh) 2022-11-08 2022-11-08 操作系统迁移方法、迁移应用及迁移应用部署方法

Country Status (1)

Country Link
CN (1) CN115617489B (zh)

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114296810A (zh) * 2021-12-29 2022-04-08 上海英方软件股份有限公司 一种操作系统迁移方法、装置、服务器与存储介质

Family Cites Families (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
GB2506177A (en) * 2012-09-25 2014-03-26 Ibm Method of migrating an operating system executing an application
US10740146B2 (en) * 2017-02-10 2020-08-11 Xilinx, Inc. Migrating virtual machines between compute systems by transmitting programmable logic accelerator state
CN111625498B (zh) * 2020-05-28 2022-06-07 浪潮电子信息产业股份有限公司 一种数据迁移方法、系统、电子设备及存储介质
CN113282482A (zh) * 2020-11-27 2021-08-20 苏州律点信息科技有限公司 软件包的兼容测试方法及系统
CN114691188A (zh) * 2020-12-30 2022-07-01 华为技术有限公司 兼容性评估方法、装置、设备及存储介质
CN113986478A (zh) * 2021-09-26 2022-01-28 阿里巴巴(中国)有限公司 资源迁移策略确定方法以及装置
CN114461404B (zh) * 2022-04-01 2022-07-08 统信软件技术有限公司 一种进程迁移方法、计算设备及可读存储介质

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114296810A (zh) * 2021-12-29 2022-04-08 上海英方软件股份有限公司 一种操作系统迁移方法、装置、服务器与存储介质

Also Published As

Publication number Publication date
CN115617489A (zh) 2023-01-17

Similar Documents

Publication Publication Date Title
US11422917B2 (en) Deriving software application dependency trees for white-box testing
CN113076248B (zh) 一种应用处理方法、装置、设备及可读存储介质
CN113946854B (zh) 一种文件访问控制方法、装置及计算机可读存储介质
CN115617489B (zh) 操作系统迁移方法、迁移应用及迁移应用部署方法
CN115576903B (zh) 一种文件系统构建方法、计算设备及存储介质
CN115617488A (zh) 操作系统迁移方法、装置、计算设备及存储介质
CN114816772B (zh) 基于兼容层运行的应用的排错方法、排错系统及计算设备
CN113867778A (zh) 一种镜像文件的生成方法、装置、电子设备及存储介质
CN115202830B (zh) 根文件系统的准备方法、系统、计算设备及可读存储介质
CN114756291B (zh) 一种硬件自适应方法和装置
CN110286913B (zh) 核对代码包部署方法及装置
US11915003B2 (en) Process parasitism-based branch prediction method and device for serverless computing, electronic device, and non-transitory readable storage medium
CN115016987B (zh) 一种操作系统检查方法、计算设备及存储介质
CN116149707B (zh) 分布式系统的升级风险检测和规避方法及装置
CN115904953A (zh) 测试方法、装置、计算设备及存储介质
CN114237754B (zh) 一种数据加载方法、装置、电子设备以及存储介质
CN118138454A (zh) 资源包下载方法、装置、计算设备及存储介质
CN115185820A (zh) 一种系统安装器的测试方法、测试装置及计算设备
CN116360828A (zh) 程序升级方法、装置、设备及计算机可读存储介质
CN114237754A (zh) 一种数据加载方法、装置、电子设备以及存储介质
CN112631650A (zh) 插件版本信息校验方法、计算设备及存储介质
CN116302543A (zh) 持续集成作业处理方法、装置、设备及存储介质
CN117008936A (zh) 一种页面更新方法、装置、计算设备及存储介质
CN114860308A (zh) 一种嵌入式软件重构方法及装置
CN113836001A (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