CN112416379B - 一种应用程序安装方法、装置、计算设备及可读存储介质 - Google Patents
一种应用程序安装方法、装置、计算设备及可读存储介质 Download PDFInfo
- Publication number
- CN112416379B CN112416379B CN202110078660.1A CN202110078660A CN112416379B CN 112416379 B CN112416379 B CN 112416379B CN 202110078660 A CN202110078660 A CN 202110078660A CN 112416379 B CN112416379 B CN 112416379B
- Authority
- CN
- China
- Prior art keywords
- program
- software package
- file
- package management
- management program
- 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
Links
- 238000000034 method Methods 0.000 title claims abstract description 127
- 230000008569 process Effects 0.000 claims abstract description 67
- 230000007246 mechanism Effects 0.000 claims abstract description 30
- 238000009434 installation Methods 0.000 claims description 41
- 238000011084 recovery Methods 0.000 claims description 32
- 230000000903 blocking effect Effects 0.000 claims description 5
- 238000012217 deletion Methods 0.000 claims description 2
- 230000037430 deletion Effects 0.000 claims description 2
- 238000012360 testing method Methods 0.000 description 17
- 238000004891 communication Methods 0.000 description 16
- 238000010586 diagram Methods 0.000 description 10
- 238000011900 installation process Methods 0.000 description 6
- 230000006870 function Effects 0.000 description 5
- 238000012545 processing Methods 0.000 description 4
- 230000002093 peripheral effect Effects 0.000 description 3
- 230000008901 benefit Effects 0.000 description 2
- 230000008859 change Effects 0.000 description 2
- 238000007726 management method Methods 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 230000007723 transport mechanism Effects 0.000 description 2
- 238000004458 analytical method Methods 0.000 description 1
- 238000004422 calculation algorithm Methods 0.000 description 1
- 230000001419 dependent effect Effects 0.000 description 1
- 238000011161 development Methods 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 238000007667 floating Methods 0.000 description 1
- 230000003993 interaction Effects 0.000 description 1
- 238000012423 maintenance Methods 0.000 description 1
- 238000012795 verification Methods 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/60—Software deployment
- G06F8/61—Installation
- G06F8/64—Retargetable
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/70—Software maintenance or management
- G06F8/71—Version control; Configuration management
Abstract
本发明公开了一种应用程序安装方法,适于在计算设备中执行,方法包括:启动第一执行程序;第一执行程序通过进程跟踪机制启动软件包管理程序;通过软件包管理程序安装目标程序;根据进程跟踪机制,通过第一执行程序获取软件包管理程序的系统调用数据,并生成目标程序恢复点数据。本发明一并公开了相应的装置、计算设备及可读存储介质。
Description
技术领域
本发明涉及计算机技术领域,尤其涉及一种应用程序安装方法、装置、计算设备及可读存储介质。
背景技术
在Linux操作系统中,为了解决应用程序中程序包的依赖关系,通常都借助于包管理程序安装目标应用程序,同时包管理程序也方便应用程序的卸载。常见的软件包管理程序如rpm、apt、yum等。在应用程序安装过程中,原始文件可能会被覆盖或删除,在安装过程成还会执行一些脚本文件,而包管理程序并不能感知到这些操作,一旦应用程序安装或升级程序包出现问题,并且某些系统文件被修改的情况下,会影响其他应用程序的运行。而如果要卸载应用程序,也只能还原包管理程序所记录的文件,而通过运行脚本文件修改的文件是不能恢复的,可能会对系统安装或者正常使用造成影响。
现有的一些操作系统中,会通过对磁盘的数据块操作,存储系统恢复点,即程序安装前的系统状态。在应用程序安装时启动恢复点功能,实际上是安装了一个磁盘设备过滤驱动,并在磁盘存储中预留出一块区域,这样在执行任何磁盘操作时,所有的数据会写到这个区域,当应用程序安装完成后,将上述区域中的数据搬迁到正常的磁盘位置进入使用状态。但是,这种方式需要手动操作,耗时长,且不产生日志文件,操作过程繁琐。
发明内容
为此,本发明提供了一种应用程序安装方法、装置、计算设备及可读存储介质,以力图解决或者至少缓解上面存在的问题。
根据本发明的一个方面,提供一种应用程序安装方法,适于在计算设备中执行,方法包括:启动第一执行程序;第一执行程序通过进程跟踪机制启动软件包管理程序;通过软件包管理程序安装目标程序;根据进程跟踪机制,通过第一执行程序获取软件包管理程序的系统调用数据,并生成目标程序恢复点数据。
可选的,在根据本发明的应用程序安装方法中,根据进程跟踪机制,通过第一执行程序获取软件包管理程序的系统调用数据包括:创建目标程序恢复点目录;在目标目标程序恢复点目录中创建日志文件;根据进程跟踪机制,当软件包管理程序完成每一个系统调用时,软件包管理程序进入阻塞状态;第一执行程序获取软件包管理程序的系统调用数据,并进行记录;第一执行程序将软件包管理程序的状态置位执行状态,以便软件包管理程序继续安装目标程序。
可选的,在根据本发明的应用程序安装方法中,第一执行程序获取软件包管理程序的系统调用数据,并进行记录包括:当系统调用数据为更新文件或删除文件时,备份该文件的原始文件并存储在目标程序恢复点目录中,记录文件的路径信息、操作类型以及文件名称;当系统调用数据为新建文件时,记录新建文件的路径信息、操作类型以及文件名称。
可选的,在根据本发明的应用程序安装方法中,操作类型包括:新建、更新以及删除。
可选的,在根据本发明的应用程序安装方法中,还包括:根据目标程序恢复点数据,将当前计算设备的系统环境还原为目标程序安装前的状态。
可选的,在根据本发明的应用程序安装方法中,根据目标程序恢复点数据,将当前计算设备的系统环境还原为目标程序安装前的状态包括:将操作类型为更新的文件恢复为原始文件;将操作类型为删除的文件恢复到原始路径;将操作类型为新建的文件进行删除。
可选的,在根据本发明的应用程序安装方法中,计算设备安装有Linux系统,进程跟踪机制为ptrace,软件包管理程序为apt。
可选的,在根据本发明的应用程序安装方法中,方法由系统管理员身份执行。
根据本发明的又一方面,提供一种应用程序安装装置,适于驻留在计算设备中,装置包括:程序安装单元:适于启动第一执行程序,第一执行程序通过进程跟踪机制启动软件包管理程序,通过软件包管理程序安装目标程序;恢复点备份单元:适于根据进程跟踪机制,通过第一执行程序获取软件包管理程序的系统调用数据,并生成目标程序恢复点数据。
根据本发明的又一个方面,提供一种计算设备,包括:至少一个处理器;以及存储器,存储有程序指令,其中,程序指令被配置为适于由至少一个处理器执行,程序指令包括用于执行如上的任一项任务调度方法的指令。
根据本发明的又一个方面,提供一种可读存储介质, 当程序指令被计算设备读取并执行时,使得计算设备执行如上的任一项任务调度方法。
根据本发明的应用程序安装方法,第一执行程序通过进程跟踪机制启动软件包管理程序,将进程跟踪机制和软件包管理程序性结合,从而实现了在应用程序安装/升级过程中,通过第一执行程序获取软件包管理程序安装/升级应用程序过程中的系统调用数据,从而获得系统文件的更新变化数据,将这些数据生成恢复点数据,利用该恢复点数据,在卸载对应的应用程序时,保证系统能够恢复到安装应用程序前的状态,保证系统和其他应用程序正常运行,尤其当所安装的应用程序或应用程序的升级包存在错误时,能够将系统恢复到原始状态,使系统文件和其他应用程序不受影响。
附图说明
为了实现上述以及相关目的,本文结合下面的描述和附图来描述某些说明性方面,这些方面指示了可以实践本文所公开的原理的各种方式,并且所有方面及其等效方面旨在落入所要求保护的主题的范围内。通过结合附图阅读下面的详细描述,本公开的上述以及其它目的、特征和优势将变得更加明显。遍及本公开,相同的附图标记通常指代相同的部件或元素。
图1示出了根据本发明一个实施例的计算设备100 的框图;
图2示出了根据本发明一个实施例的应用程序安装方法200的流程图;
图3示出了根据本发明一个实施例的恢复点数据生成过程300的流程图;
图4示出了根据本发明一个实施例的系统恢复过程400的流程图;
图5示出了根据本发明一个实施例的应用程序安装装置500的示意图。
具体实施方式
下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。
本发明针对创建系统恢复点数据的问题,提供了一种应用程序安装方法,该方法适于在计算设备中执行,图1示出了根据本发明一个实施例的计算设备100的示意图。需要说明的是,图1所示的计算设备100仅为一个示例,在实践中,用于实施本发明的应用程序安装方法的计算设备可以是任意型号的设备,其硬件配置情况可以与图1所示的计算设备100相同,也可以与图1所示的计算设备100不同。实践中用于实施本发明的应用程序安装方法的计算设备可以对图1所示的计算设备100的硬件组件进行增加或删减,本发明对计算设备的具体硬件配置情况不做限制。
如图1所示,在基本配置102中,计算设备100典型地包括系统存储器106和一个或者多个处理器104。存储器总线108可以用于在处理器104和系统存储器106之间的通信。
取决于期望的配置,处理器104可以是任何类型的处理,包括但不限于:微处理器(µP)、微控制器(µC)、数字信息处理器(DSP)或者它们的任何组合。处理器104可以包括诸如一级高速缓存110和二级高速缓存112之类的一个或者多个级别的高速缓存、处理器核心114和寄存器116。示例的处理器核心114可以包括运算逻辑单元(ALU)、浮点数单元(FPU)、数字信号处理核心(DSP核心)或者它们的任何组合。示例的存储器控制器118可以与处理器104一起使用,或者在一些实现中,存储器控制器118可以是处理器104的一个内部部分。
取决于期望的配置,系统存储器106可以是任意类型的存储器,包括但不限于:易失性存储器(诸如RAM)、非易失性存储器(诸如ROM、闪存等)或者它们的任何组合。计算设备中的物理内存通常指的是易失性存储器RAM,磁盘中的数据需要加载至物理内存中才能够被处理器104读取。系统存储器106可以包括操作系统120、一个或者多个应用122以及程序数据124。在一些实施方式中,应用122可以布置为在操作系统上由一个或多个处理器104利用程序数据124执行指令。操作系统120例如可以是Linux、Windows等,其包括用于处理基本系统服务以及执行依赖于硬件的任务的程序指令。应用122包括用于实现各种用户期望的功能的程序指令,应用122例如可以是浏览器、即时通讯软件、软件开发工具(例如集成开发环境IDE、编译器等)等,但不限于此。当应用122被安装到计算设备100中时,可以向操作系统120添加驱动模块。
在计算设备100启动运行时,处理器104会从存储器106中读取操作系统120的程序指令并执行。应用122运行在操作系统120之上,利用操作系统120以及底层硬件提供的接口来实现各种用户期望的功能。当用户启动应用122时,应用122会加载至存储器106中,处理器104从存储器106中读取并执行应用122的程序指令。
计算设备100还包括储存设备132,储存设备132包括可移除储存器136和不可移除储存器138,可移除储存器136和不可移除储存器138均与储存接口总线134连接。
计算设备100还可以包括有助于从各种接口设备(例如,输出设备142、外设接口144和通信设备146)到基本配置102经由总线/接口控制器130的通信的接口总线140。示例的输出设备142包括图形处理单元148和音频处理单元150。它们可以被配置为有助于经由一个或者多个A/V端口152与诸如显示器或者扬声器之类的各种外部设备进行通信。示例外设接口144可以包括串行接口控制器154和并行接口控制器156,它们可以被配置为有助于经由一个或者多个I/O端口158和诸如输入设备(例如,键盘、鼠标、笔、语音输入设备、触摸输入设备)或者其他外设(例如打印机、扫描仪等)之类的外部设备进行通信。示例的通信设备146可以包括网络控制器160,其可以被布置为便于经由一个或者多个通信端口164与一个或者多个其他计算设备162通过网络通信链路的通信。
网络通信链路可以是通信介质的一个示例。通信介质通常可以体现为在诸如载波或者其他传输机制之类的调制数据信号中的计算机可读指令、数据结构、程序模块,并且可以包括任何信息递送介质。“调制数据信号”可以这样的信号,它的数据集中的一个或者多个或者它的改变可以在信号中编码信息的方式进行。作为非限制性的示例,通信介质可以包括诸如有线网络或者专线网络之类的有线介质,以及诸如声音、射频(RF)、微波、红外(IR)或者其它无线介质在内的各种无线介质。这里使用的术语计算机可读介质可以包括存储介质和通信介质二者。
在根据本发明的计算设备100中,应用122包括用于执行本发明的应用程序安装方法200的指令,该指令可以指示处理器104执行本发明的应用程序安装方法200。
图2示出了根据本发明一个实施例的应用程序安装方法200的流程图,适于在计算设备(如图1所示的计算设备)中执行。如图2所示,方法200始于步骤S210,在本步骤中,启动应用程序安装或应用程序升级(即启动第一执行程序)。
随后进入步骤S220,在本步骤中,第一执行程序通过进程跟踪机制启动软件包管理程序。
软件包管理程序的作用可以消除手动安装和更新,这对于Linux/Unix操作系统尤为重要,对于不同的Linux发行版,所使用的软件包管理程序也不尽相同,比如debian的apt、dpkg,redhat的rpm等。软件包管理程序将编译好的应用程序和各个组成文件打包成一个或几个程序包文件,从而能够更方便的实现程序包的安装、升级、卸载和查询等管理操作。每个程序包都是单独实现的,包含了自身文件清单,安装或卸载时运行的脚本,共用一个公共数据库来存放程序包的名称、版本、依赖关系、功能说明、安装生成的文件位置及校验信息等。
根据本发明的一个实施例,在Linux系统中,进程跟踪机制通常指ptrace,从名字上可以看出,它是用于进程跟踪的,提供了一种父进程可以控制子进程运行的机制,并允许父进程检查和改变其内核镜像。它主要用于实现断点调试。基本工作原理是:当ptrace被使用时,被跟踪的子进程的信号会转发给父进程,而此时子进程被阻塞,并标记位暂停/跟踪状态。同时,父进程会对停下来的子进程进行检查或者修改,进而,父进程还可以使子进程继续执行,并选择是否忽略引起中止的信号。
在根据本发明的应用程序安装方法中,第一执行程序启动软件包管理程序(例如:apt),其中第一执行程序为父进程,软件包管理程序的执行为子进程,从而可以通过进程跟踪机制实现第一执行程序对软件包管理程序的监督、检查。
在步骤S230中,通过软件包管理程序安装目标程序。
在本实施例中,应用程序安装方法在Linux系统的计算设备中执行,软件包管理程序为apt,进程跟踪机制为ptrace,在一个具体示例中,第一执行程序A通过ptrace启动apt,由apt执行安装B_Package,该指令可以表示为如下形式,其中sudo表示该指令有当前系统的管理员身份的用户执行。
sudo A apt install B_Package
在步骤 240中,在软件包管理程序安装/升级目标程序过程中,第一执行程序获取软件包管理程序的系统调用数据,备份相应的原始文件,并在日志文件中记录被修改文件的路径信息、操作类型、文件名称等信息,最终生成当前安装/升级的目标程序的恢复点数据,具体的生成过程如图3所示。
在步骤S250中,如果所安装或升级的目标程序出现错误,卸载相应的程序时,根据步骤S240中生成的恢复点数据进行系统恢复,保证系统能够恢复到安装应用程序前的状态,保证系统和其他应用程序正常运行。具体的系统恢复过程如图4所示。
图3示出了根据本发明一个实施例的恢复点数据生成过程300的流程图。如图3所示,该过程始于步骤S310,在该步骤前还包括创建目标程序恢复点目录和在该目录中创建日志文件的步骤,目录文件夹命名,以及文件命名上可以根据便于查找或记录的原则实现。例如,在上述实施例sudo A apt install B_Package中,首先在/data/var/cache/A目录中创建文件夹B_Package,作为应用程序B_Package的恢复点数据目录,同时在B_Package文件夹下面创建install.log文件作为日志文件,用于记录文件的修改过程。
在步骤S310中,软件包管理程序安装应用程序过程中,软件包管理程序每完成一个系统调用,信号被转发给第一执行程序,并进入阻塞状态。
继续以上述安装B_Package应用程序为例,软件包管理程序apt在安装应用程序B_Package中,删除一个文件,根据进程跟踪机制ptrace,软件包管理程序apt进入阻塞状态,即停止应用程序B_Package的安装,并且,信号传递给其父进程第一执行程序。
随后进入步骤S320,软件包管理程序的父进程第一执行程序对子进程进行查看,获取软件包管理程序的系统调用数据,包括B_Package安装过程中对文件的变更过程。
随后进入步骤S330,根据系统调用数据中对文件的操作类型,记录恢复点数据,其中操作类型包括:新建、更新以及删除。
继续以B_Package安装过程为例,比如当前系统调用数据显示本次系统调用在目录/user/share/doc中创建一个新文件test.txt,则在相应的日志文件install.log中记录如下记录,其中,/user/share/doc/为新建文件的绝对路径,new对应文件的操作类型为“新建”,test.txt为文件名称,即test.txt为新创建的文件,##**##为分割符号。
/user/share/doc/##**##new##**##test.txt
根据本发明又一个实施例,根据当前系统调用数据,将/user/bin下的文件B_test进行了更新覆盖,在该步骤中,首先将B_test的原始文件备份到恢复点数据文件夹/data/var/cache/A/B_Package中,并在日志文件中增加如下记录,其中,/user/bin/B_test为被覆盖文件的绝对路径,writeover表示文件的操作类型为更新,B_test为文件名称。
/user/bin/##**##writeover##**##B_test
根据本发明的又一个实施例,当前系统调用数据表示,本次系统调用从目录/usr/share/doc/中删除文件M,在本步骤中,首先将原始文件M备份到恢复点数据文件夹/data/var/cache/A/B_Package中,并在日志文件中增加如下记录,其中,/usr/share/doc/M为删除文件的绝对路径,delete表示文件被删除,M为文件名称。
/usr/share/doc/##**##delete##**##M
日志文件中的文件操作记录可以根据需求进行设置,本发明对此不做限制。
随后进入步骤S340,第一执行程序在完成系统调用数据分析和记录后,将子程序软件包管理程序的装态置位执行状态,继续应用程序的安装过程。
每一次系统调用都会重复过程300中的步骤,在安装完成后,甚至apt非正常结束后,所有apt操作过的文件的原始文件的备份文件和日志文件都存储到/data/var/cache/A/B_Package中,将该文件夹打包压缩成文件(例如:B_Package.diff),即生成恢复点数据文件。可以根据该文件完成系统恢复,将系统恢复到程序安装前的状态。
根据本发明的一个实施例,如果安装的B_Package,造成了某些系统问题,可以通过B_Package.diff恢复B_Package安装包安装前的系统状态,可以通过执行指令sudo A B_Package实现。
图4示出了根据本发明一个实施例的系统恢复过程400的流程图。如图4所示,该过程始于步骤S410,解压恢复点数据文件。以B_Package为例,其恢复点数据文件为B_Package.diff,对其进行解压,其中包括日志文件install.log以及相关的备份文件。
随后进入步骤S420,依次获取日志文件中的记录信息,并根据记录信息进行数据恢复。
根据本发明的一个实施例,获取到的日志文件中的数据记录为/user/share/doc/test.txt##**##new##**##test.txt,即在/user/share/doc/中新创建了文件test.txt,在进行数据恢复时,则直接删除/user/share/doc/test.txt。
当获取到的日志数据为/user/bin/B_test##**##writeover##**##B_test时,在本步骤中,将恢复点数据文件夹中的B_test复制到/user/bin/B_test。
当获取到的日志数据为/usr/share/doc/M##**##delete##**##M时,将恢复点数据文件夹中的M复制到/usr/share/doc/中完成数据恢复。
图5示出了根据本发明一个实施例的应用程序安装装置500的示意图。该装置属于驻留在计算设备中执行方法200,如图5所示,应用程序安装装置500包括程序安装单元510、恢复点备份单元520以及数据恢复单元530。
程序安装单元510适于启动第一执行程序,第一执行程序通过进程跟踪机制启动软件包管理程序,通过软件包管理程序安装目标应用程序。
恢复点备份单元520适于根据进程跟踪机制,通过第一执行程序获取软件包管理程序安装应用程序中的系统调用数据,并生成恢复点数据。
数据恢复单元530适于根据目标程序恢复点数据,将当前计算设备的系统环境还原为目标程序安装前的状态。
根据本发明的应用程序安装方法,第一执行程序通过进程跟踪机制启动软件包管理程序,将进程跟踪机制和软件包管理程序性结合,从而可以实现,在应用程序安装/升级过程中,通过第一执行程序获取软件包管理程序安装/升级应用程序过程中的系统调用数据,从而获得系统文件的更新变化数据,将这些数据生成恢复点数据,从而可以实现,在卸载所安装的应用程序时,保证系统能够恢复到安装应用程序前的状态,保证系统和其他应用程序正常运行。尤其当所安装的应用程序或应用程序的升级包存在错误时,能够将系统恢复到原始状态,使系统文件和其他应用程序不受影响。
本方案实现了操作系统恢复点的自动生成,伴随现有系统的安装程序,自动感知系统变化,自动实时生成恢复脚本,在linux的运维领域方面,将带来极大的便利,可以避免程序相互影响造成的系统故障,同时生成的恢复脚本,对故障的分析也会起到很大的作用。
这里描述的各种技术可结合硬件或软件,或者它们的组合一起实现。从而,本发明的方法和设备,或者本发明的方法和设备的某些方面或部分可采取嵌入有形媒介,例如可移动硬盘、U盘、软盘、CD-ROM或者其它任意机器可读的存储介质中的程序代码(即指令)的形式,其中当程序被载入诸如计算机之类的机器,并被所述机器执行时,所述机器变成实践本发明的设备。
在程序代码在可编程计算机上执行的情况下,计算设备一般包括处理器、处理器可读的存储介质(包括易失性和非易失性存储器和/或存储元件),至少一个输入装置,和至少一个输出装置。其中,存储器被配置用于存储程序代码;处理器被配置用于根据该存储器中存储的所述程序代码中的指令,执行本发明的应用程序安装方法。
以示例而非限制的方式,可读介质包括可读存储介质和通信介质。可读存储介质存储诸如计算机可读指令、数据结构、程序模块或其它数据等信息。通信介质一般以诸如载波或其它传输机制等已调制数据信号来体现计算机可读指令、数据结构、程序模块或其它数据,并且包括任何信息传递介质。以上的任一种的组合也包括在可读介质的范围之内。
在此处所提供的说明书中,算法和显示不与任何特定计算机、虚拟系统或者其它设备固有相关。各种通用系统也可以与本发明的示例一起使用。根据上面的描述,构造这类系统所要求的结构是显而易见的。此外,本发明也不针对任何特定编程语言。应当明白,可以利用各种编程语言实现在此描述的本发明的内容,并且上面对特定语言所做的描述是为了披露本发明的最佳实施方式。
在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下被实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。
应当理解,为了精简本公开并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释成反映如下意图:即所要求保护的本发明要求比在每个权利要求中所明确记载的特征更多特征。
本领域那些技术人员应当理解在本文所公开的示例中的设备的模块或单元或组件可以布置在如该实施例中所描述的设备中,或者可替换地可以定位在与该示例中的设备不同的一个或多个设备中。前述示例中的模块可以组合为一个模块或者此外可以分成多个子模块。
本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组件组合成一个模块或单元或组件,以及此外可以把它们分成多个子模块或子单元或子组件。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书(包括伴随的权利要求、摘要和附图)中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书(包括伴随的权利要求、摘要和附图)中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。
此外,本领域的技术人员能够理解,尽管在此所述的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。例如,在下面的权利要求书中,所要求保护的实施例的任意之一都可以以任意的组合方式来使用。
此外,所述实施例中的一些在此被描述成可以由计算机系统的处理器或者由执行所述功能的其它装置实施的方法或方法元素的组合。因此,具有用于实施所述方法或方法元素的必要指令的处理器形成用于实施该方法或方法元素的装置。此外,装置实施例的在此所述的元素是如下装置的例子:该装置用于实施由为了实施该发明的目的的元素所执行的功能。
如在此所使用的那样,除非另行规定,使用序数词“第一”、“第二”、“第三”等等来描述普通对象仅仅表示涉及类似对象的不同实例,并且并不意图暗示这样被描述的对象必须具有时间上、空间上、排序方面或者以任意其它方式的给定顺序。
尽管根据有限数量的实施例描述了本发明,但是受益于上面的描述,本技术领域内的技术人员明白,在由此描述的本发明的范围内,可以设想其它实施例。此外,应当注意,本说明书中使用的语言主要是为了可读性和教导的目的而选择的,而不是为了解释或者限定本发明的主题而选择的。因此,在不偏离所附权利要求书的范围和精神的情况下,对于本技术领域的普通技术人员来说许多修改和变更都是显而易见的。对于本发明的范围,对本发明所做的公开是说明性的,而非限制性的,本发明的范围由所附权利要求书限定。
Claims (9)
1.一种应用程序安装方法,适于在计算设备中执行,所述计算设备安装有Linux系统,所述方法包括:
启动第一执行程序;
所述第一执行程序通过进程跟踪机制启动软件包管理程序,其中,所述第一执行程序为父进程,所述软件包管理程序为子进程;
通过所述软件包管理程序安装目标程序;
根据所述进程跟踪机制,通过所述第一执行程序获取所述软件包管理程序的系统调用数据,并生成目标程序恢复点数据,其中,所述进程跟踪机制适于实现父进程对子进程的控制,该步骤具体包括:
创建目标程序恢复点目录;
在所述目标程序恢复点目录中创建日志文件;
根据所述进程跟踪机制,当所述软件包管理程序完成每一个系统调用时,所述软件包管理程序进入阻塞状态;
所述第一执行程序获取所述软件包管理程序的系统调用数据,并记录在所述日志文件中;
所述第一执行程序将所述软件包管理程序的状态置位执行状态,以便所述软件包管理程序继续安装所述目标程序。
2.如权利要求1所述的方法,其中,所述第一执行程序获取所述软件包管理程序的系统调用数据,并进行记录包括:
当所述系统调用数据为更新文件或删除文件时,备份该文件的原始文件并存储在所述目标程序恢复点目录中,记录文件的路径信息、操作类型以及文件名称;
当所述系统调用数据为新建文件时,记录所述新建文件的路径信息、操作类型以及文件名称。
3.如权利要求2所述方法,其中,所述操作类型包括:新建、更新以及删除。
4.如权利要求1-3中任意一项所述的方法,还包括:
根据所述目标程序恢复点数据,将当前计算设备的系统环境还原为所述目标程序安装前的状态。
5.如权利要求2或3所述的方法,所述根据所述目标程序恢复点数据,将当前计算设备的系统环境还原为所述目标程序安装前的状态包括:
将所述操作类型为更新的文件恢复为原始文件;
将所述操作类型为删除的文件恢复到原始路径;
将所述操作类型为新建的文件进行删除。
6.如权利要求1-3中任意一项所述的方法,所述计算设备安装有Linux系统,所述进程跟踪机制为ptrace,所述软件包管理程序为apt。
7.一种应用程序安装装置,适于驻留在计算设备中,所述计算设备安装有Linux系统,所述装置包括:
程序安装单元:适于启动第一执行程序,所述第一执行程序通过进程跟踪机制启动软件包管理程序,通过所述软件包管理程序安装目标程序,其中所述第一执行程序为父进程,所述软件包管理程序为子进程;
恢复点备份单元:适于根据所述进程跟踪机制,通过所述第一执行程序获取所述软件包管理程序的系统调用数据,并生成目标程序恢复点数据,其中,所述进程跟踪机制适于实现父进程对子进程的控制,具体包括:
创建目标程序恢复点目录;
在所述目标程序恢复点目录中创建日志文件;
根据所述进程跟踪机制,当所述软件包管理程序完成每一个系统调用时,所述软件包管理程序进入阻塞状态;
所述第一执行程序获取所述软件包管理程序的系统调用数据,并记录在所述日志文件中;
所述第一执行程序将所述软件包管理程序的状态置位执行状态,以便所述软件包管理程序继续安装所述目标程序。
8.一种计算设备,包括:
至少一个处理器;以及
存储器,存储有程序指令,其中,所述程序指令被配置为适于由所述至少一个处理器执行,所述程序指令包括用于执行如权利要求1-6中任一项所述方法的指令。
9.一种存储有程序指令的可读存储介质,当所述程序指令被计算设备读取并执行时,使得所述计算设备执行如权利要求1-6中任一项所述方法。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110078660.1A CN112416379B (zh) | 2021-01-21 | 2021-01-21 | 一种应用程序安装方法、装置、计算设备及可读存储介质 |
PCT/CN2021/124288 WO2022156277A1 (zh) | 2021-01-21 | 2021-10-18 | 一种应用程序安装方法、装置、计算设备及可读存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110078660.1A CN112416379B (zh) | 2021-01-21 | 2021-01-21 | 一种应用程序安装方法、装置、计算设备及可读存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN112416379A CN112416379A (zh) | 2021-02-26 |
CN112416379B true CN112416379B (zh) | 2021-06-01 |
Family
ID=74783116
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110078660.1A Active CN112416379B (zh) | 2021-01-21 | 2021-01-21 | 一种应用程序安装方法、装置、计算设备及可读存储介质 |
Country Status (2)
Country | Link |
---|---|
CN (1) | CN112416379B (zh) |
WO (1) | WO2022156277A1 (zh) |
Families Citing this family (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112416379B (zh) * | 2021-01-21 | 2021-06-01 | 统信软件技术有限公司 | 一种应用程序安装方法、装置、计算设备及可读存储介质 |
CN113066515B (zh) * | 2021-04-14 | 2022-04-29 | 统信软件技术有限公司 | 一种光盘刻录方法、计算设备及可读存储介质 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103345411A (zh) * | 2013-07-09 | 2013-10-09 | 北京奇虎科技有限公司 | 卸载应用程序的方法及装置 |
CN103677963A (zh) * | 2013-12-26 | 2014-03-26 | 清华大学 | 应用程序虚拟化方法及系统 |
CN103699420A (zh) * | 2013-12-31 | 2014-04-02 | 海信集团有限公司 | 系统恢复方法和系统恢复装置 |
CN108733380A (zh) * | 2017-04-21 | 2018-11-02 | 北京京东尚科信息技术有限公司 | 应用部署方法和装置 |
Family Cites Families (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8490082B2 (en) * | 2005-11-03 | 2013-07-16 | International Business Machines Corporation | System and method for representing user processes as software packages in a software package management system |
CN102591745B (zh) * | 2011-12-26 | 2014-03-12 | Tcl集团股份有限公司 | 基于安卓系统的系统恢复方法、装置及智能设备 |
CN102902564B (zh) * | 2012-09-26 | 2016-06-01 | 北京奇虎科技有限公司 | 安装补丁的方法及装置 |
CN104111848B (zh) * | 2014-06-27 | 2017-04-26 | 华中科技大学 | 一种基于异步检查点的多线程软件动态升级方法 |
CN108008962A (zh) * | 2017-12-12 | 2018-05-08 | 郑州云海信息技术有限公司 | 一种Linux系统下PXE服务器的配置方法和系统 |
CN112416379B (zh) * | 2021-01-21 | 2021-06-01 | 统信软件技术有限公司 | 一种应用程序安装方法、装置、计算设备及可读存储介质 |
-
2021
- 2021-01-21 CN CN202110078660.1A patent/CN112416379B/zh active Active
- 2021-10-18 WO PCT/CN2021/124288 patent/WO2022156277A1/zh active Application Filing
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103345411A (zh) * | 2013-07-09 | 2013-10-09 | 北京奇虎科技有限公司 | 卸载应用程序的方法及装置 |
CN103677963A (zh) * | 2013-12-26 | 2014-03-26 | 清华大学 | 应用程序虚拟化方法及系统 |
CN103699420A (zh) * | 2013-12-31 | 2014-04-02 | 海信集团有限公司 | 系统恢复方法和系统恢复装置 |
CN108733380A (zh) * | 2017-04-21 | 2018-11-02 | 北京京东尚科信息技术有限公司 | 应用部署方法和装置 |
Also Published As
Publication number | Publication date |
---|---|
WO2022156277A1 (zh) | 2022-07-28 |
CN112416379A (zh) | 2021-02-26 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP5444368B2 (ja) | アプリケーション復元ポイント | |
US8806476B2 (en) | Implementing a software installation process | |
JP5007046B2 (ja) | コンポーネントベースのソフトウェア・プロダクトの保守 | |
US8135813B2 (en) | Method, system and program product for remotely deploying and automatically customizing workstation images | |
US8886995B1 (en) | Fault tolerant state machine for configuring software in a digital computer | |
US6374401B1 (en) | System, method, and program for updating registry objects with a cross-platform installation program | |
US7937697B2 (en) | Method, system and computer program for distributing software patches | |
US8639973B2 (en) | System reset | |
US7966612B2 (en) | Method, system and computer program for installing shared software components | |
US20070168956A1 (en) | System and method for representing user processes as software packages in a software package management system | |
CN113032032B (zh) | 一种系统管理方法、装置、计算设备及可读存储介质 | |
CN112416379B (zh) | 一种应用程序安装方法、装置、计算设备及可读存储介质 | |
US20070277033A1 (en) | Method for re-imaging a computer system | |
US8132047B2 (en) | Restoring application upgrades using an application restore point | |
JP2614361B2 (ja) | ファイル内容変更方法 | |
CN112925549A (zh) | 基于安卓框架的系统应用升级系统 | |
KR102423056B1 (ko) | 부팅 디스크 변경 방법 및 시스템 | |
US20150046414A1 (en) | Computer product, managing apparatus, and managing method | |
CN113434342A (zh) | 一种操作系统恢复方法、计算设备及存储介质 | |
CN115964059A (zh) | 虚拟化资源池升级方法及相关装置 | |
CN115827013A (zh) | 系统的升级方法、计算设备及可读存储介质 | |
Lewandowski | Maintaining Node Symmetry In a Networked Windows NT Environment | |
CA2539407A1 (en) | Method and apparatus for implementing a software installation process | |
JPH0756728A (ja) | プログラム開発環境復元設定装置 |
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 |