CN102439564B - 在Linux容器中启动应用程序的方法和系统 - Google Patents

在Linux容器中启动应用程序的方法和系统 Download PDF

Info

Publication number
CN102439564B
CN102439564B CN201180002154.9A CN201180002154A CN102439564B CN 102439564 B CN102439564 B CN 102439564B CN 201180002154 A CN201180002154 A CN 201180002154A CN 102439564 B CN102439564 B CN 102439564B
Authority
CN
China
Prior art keywords
container
application
start process
application program
started
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
CN201180002154.9A
Other languages
English (en)
Other versions
CN102439564A (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.)
Huawei Technologies Co Ltd
Original Assignee
Huawei Technologies 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 Huawei Technologies Co Ltd filed Critical Huawei Technologies Co Ltd
Publication of CN102439564A publication Critical patent/CN102439564A/zh
Application granted granted Critical
Publication of CN102439564B publication Critical patent/CN102439564B/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/44Arrangements for executing specific programs
    • G06F9/445Program loading or initiating
    • 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/54Interprogram communication
    • 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/44Arrangements for executing specific programs
    • G06F9/4401Bootstrapping
    • 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/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Stored Programmes (AREA)

Abstract

一种在Linux容器中启动应用程序的方法,包括:容器启动进程根据用户输入的命令创建容器,创建第一应用启动进程,并将所述第一应用启动进程放入所述容器中执行;所述第一应用启动进程根据用户输入的命令获取待启动的应用程序的个数N,并创建N-1个第二应用启动进程,N为不小于2正整数;所述的第一应用启动进程和N-1个第二应用启动进程在所述容器中启动所述的N个应用程序,其中每个应用启动进程启动一个应用程序。本发明实施例还提供相应的Linux系统。本发明技术方案采用在容器创建时,创建多个应用启动进程,每个应用启动进程启动一个应用程序的技术方案,使得在容器创建时可以同时启动多个应用程序。

Description

在Linux容器中启动应用程序的方法和系统
技术领域
本发明涉及操作系统技术领域,具体涉及一种在Linux容器中启动应用程序的方法和一种Linux系统。
背景技术
Linux系统中,容器(Container)可以提供轻量级的虚拟化,以便隔离进程和资源。容器可以有效地将由单个操作系统管理的资源划分到孤立的组中,以更好地在孤立的组之间平衡有冲突的资源使用需求。与其他虚拟化方案相比,既不需要指令级模拟,也不需要即时编译。容器可以在核心中央处理器(CPU)本地运行指令,不需要任何专门的解释机制。避免了准虚拟化(paravirtualization)和系统调用替换中的复杂性。
通过提供一种创建和进入容器的方式,Linux操作系统可以让应用程序就像在独立的机器上运行一样,但又能共享很多底层的资源。容器在提供隔离的同时,还通过共享资源节省开销,容器比真正的虚拟化的开销要小得多。
请参考图1,Linux容器(Linux Container,LXC)根据用户输入的命令,如lxc-start…[command],启动应用程序,流程如下:
容器启动进程创建一个新的容器,同时作为该容器的守护进程存在;
容器启动进程创建一个应用启动进程,并将该应用启动进程放入容器中执行,然后该应用启动进程根据用户输入的命令行参数初始化容器;
应用启动进程根据用户从命令行传递的命令,在容器内启动应用程序,该应用程序进程是容器中的初始(init)进程;
当需要将其他应用程序放入容器中执行的时候,首先需要在容器外将该应用程序启动,并获得该应用程序的进程标识符(Process IDentity,PID)列表,然后将当前进程PID写入控制文件中使进程执行环境向容器中迁移,使得该应用程序在容器中执行,且每次是以进程为粒度执行;
当调用容器销毁命令后,容器守护进程作为容器销毁进程存在,容器守护进程通过套接字通信获取容器中进程组的组标识符(Identity,ID),通过kill()系统调用向容器内进程组发送SIGKILL信号,将容器中的进程组终止;容器守护进程检测到容器中的init进程已经死亡终止后,该容器守护进程退出,实现将容器销毁。
上述现有的在Linux容器中启动应用程序的方法,在容器创建时只能启动一个应用程序,如果需要在容器中启动另外的应用程序,则需要先在容器外部将应用程序启动,然后再将应用程序的进程放入容器中执行,操作较为繁琐,且操作过程中改变了应用程序的执行环境。进一步的,如果需要另外启动的应用程序是多进程应用,则需要获取该应用程序所有进程的PID,分多次手动将当前应用进程PID写入控制文件,这就要求使用容器的系统管理员必须对应用程序比较熟悉才能完成上述操作,操作复杂,出错概率高。另外,当应用程序部分进程处于容器内部,部分进程处于容器外部时,由于容器本身的隔离性,可能会导致应用程序故障。
发明内容
本发明实施例提供一种在Linux容器中启动应用程序的方法和一种Linux系统,可以在容器创建时启动多个应用程序。
一种在Linux容器中启动应用程序的方法,包括:
容器启动进程根据用户输入的命令创建容器,随后所述容器启动进程作为所述容器的容器守护进程存在;
所述容器启动进程创建第一应用启动进程,并将所述第一应用启动进程放入所述容器中执行;
所述第一应用启动进程根据用户输入的命令获取待启动的应用程序的个数N,并创建N-1个第二应用启动进程,N为不小于2的正整数;
所述的第一应用启动进程和N-1个第二应用启动进程在所述容器中启动所述的N个待启动的应用程序,其中每个第一或第二应用启动进程启动一个待启动的应用程序。
一种Linux系统,包括中央处理器,其特征在于,所述中央处理器包括:容器启动进程单元,第一应用启动进程单元,和第二应用启动进程;
所述容器启动进程单元,用于根据用户输入的命令创建容器,随后作为容器守护进程单元存在,创建所述第一应用启动进程单元,并将所述第一应用启动进程单元放入所述容器中执行;
所述第一应用启动进程单元,用于根据用户输入的命令获取待启动的应用程序的个数N,并创建N-1个所述第二应用启动进程单元,N为不小于2的正整数;
所述第一应用启动进程单元每个第二应用启动进程单元用于启动一个待启动的应用程序。
本发明实施例采用在容器创建时,先创建第一应用启动进程,由第一应用启动进程创建一个以上第二应用启动进程,然后每个应用启动进程启动一个应用程序的技术方案,使得在容器创建时,通过一条命令,就可以同时启动多个应用程序。
附图说明
图1是现有的在Linux容器中启动应用程序的方法的流程图;
图2是本发明实施例一的在Linux容器中启动应用程序的方法的流程图;
图3是本发明实施例二的在Linux容器中启动应用程序的方法的流程图;
图4是本发明实施例提供的Linux系统的示意图。
具体实施方式
本发明实施例提供一种在Linux容器中启动应用程序的方法,采用在容器创建时,创建多个应用启动进程,每个应用启动进程启动一个应用程序的技术方案,使得在容器创建时可以同时启动多个应用程序。以下进行详细说明。
请参考图2,本发明实施例提供一种在Linux容器中启动应用程序的方法,包括:
步骤101、容器启动进程根据用户输入的命令创建容器,随后所述容器启动进程作为所述容器的容器守护进程存在;
对于Linux操纵系统(operating system,OS),用户可以通过在命令行输入命令,实现在Linux容器中创建容器和在创建的容器中启动应用程序。所说的命令可以是lxc-stard…[command],该命令的命令行参数中包括以下内容:待创建的容器名称、待启动的应用程序路径名称、应用程序个数和配置文件路径名称。其中,容器名称和应用程序路径名称是必要的,应用程序路径名称包括多个,应用程序个数和配置文件路径名称则是可选的。
获取用户输入的命令后,OS中的当前进程,即,用于执行用户输入的命令的进程,作为容器启动进程,根据命令行参数创建一个容器。创建容器就是将一个容器名称与一个配置文件关联起来。所述配置文件用于指定容器的属性,例如容器的主机名、网络、root文件系统等,该配置文件是预先建立的。若命令行参数中没有包括配置文件的路径名称,容器启动进程可以根据默认的配置文件创建容器;若命令行参数中包括了配置文件的路径名称,则容器启动进程可以根据该指定的配置文件创建容器。
步骤102、容器启动进程创建第一应用启动进程,并将所述第一应用启动进程放入所述容器中执行。
容器启动进程创建第一应用启动进程后,所述容器启动进程与第一应用启动进程会有一个同步的过程,该过程中两个进程协商彼此的信息交互格式,以便相互传递信息。然后,容器启动进程将第一应用启动进程放入所述容器中执行,在容器中,这两个进程可以互相合作、互相等待。第一应用启动进程是容器内执行的第一个进程,可以称为初始(init)进程。
可选的,所述第一应用启动进程可以根据用户输入的命令初始化所述容器。所述初始化包括:根据用户在命令行输入的容器配置选项,完成对容器资源属性的配置,例如:配置容器的CPU节点绑定限制等信息。
步骤103、所述第一应用启动进程根据用户输入的命令获取待启动的应用程序的个数N,并创建N-1个第二应用启动进程,N为不小于2的整数。
用户输入的命令行参数中可以包括应用程序的个数N,供第一应用进程从命令行参数中获取。若命令行参数中没有包括应用程序的个数N,则第一应用进程可以解析命令行参数,统计其中包括的应用程序路径名称的个数,获取应用程序的个数N。为了启动该N个程序,第一应用启动进程在容器中另外创建N-1个第二应用启动进程。第一应用启动进程可以利用fork()系统调用来创建N个第二应用启动进程,fork()是Linux系统的一种内核接口,用于创建子进程。
步骤104、所述的第一应用启动进程和N-1个第二应用启动进程在所述容器中启动所述的N个待启动的应用程序,其中每个第一或第二应用启动进程启动一个待启动的应用程序。
这N个应用启动进程可以利用execvp()系统调用来启动应用程序,execvp()为Linux系统的另一种内核接口,用于启动给定路径名称的应用程序。N个应用启动进程在容器中启动N个应用程序具体可以包括:N个应用启动进程按照设定的对应关系启动相应的应用程序,所述对应关系为应用启动进程与应用程序的对应关系,例如,可以将应用启动进程的PID与命令行参数中输入应用程序路径名称的顺序相对应。具体的,可以按照PID从大到小的顺序将N个应用启动进程与输入N个应用程序对应,使得PID最大的应用启动进程启动第1个应用程序,PID最小的应用启动进程启动第N个应用程序;或者,使PID最小的应用启动进程启动第1个应用程序,PID最大的应用启动进程启动第N个应用程序;当然,也可以按照其它的对应关系。
可选的,步骤104之后还可以包括:
容器守护进程获取用户输入的容器销毁命令后,终止容器中的所有进程组;所述容器守护进程检测到所述容器中的初始进程被终止后,将所述容器销毁。此过程中,容器守护进程作为容器销毁进程存在。值得说明的是,本文中提到的容器启动进程、容器守护进程和容器销毁进程实质是同一个进程。
其中,容器守护进程可以通过套接字通信获取容器中进程组的组ID,然后利用kill()系统调用向容器内的进程组发送SIGKILL信号,将容器中的所有进程终止;容器守护进程也可以获取容器中所有进程的ID,直接向所有进程分别发送SIGKILL信号,将容器中的所有进程终止。所说的进程组是容器中进程的组合,包括了第一应用启动进程和N-1个第二应用启动进程。
以上,本发明实施例提供了一种在Linux容器中启动应用程序的方法,采用在容器创建时,由第一应用启动进程创建多个第二应用启动进程,其中每个应用启动进程启动一个应用程序的技术方案,使得在容器创建时可以同时启动多个应用程序在容器中执行,实现了通过一条命令同时启动多个应用程序。该技术方案简化了应用程序的启动步骤,在启动过程中,不会改变应用程序的执行环境,尤其在启动多进程应用时,用户不需要知道多进程应用程序具体包括哪些进程,多进程应用也不会发生部分进程处于容器内部、部分进程处于容器外部的问题,不会因此导致故障。
下面结合图3进行对本实施例提供的方法做进一步详细的说明:
用户通过在命令行输入命令,实现创建一个容器并在创建的容器中启动多个应用程序,其中,只需要输入一条命令即可。下面分别以容器启动进程和应用启动进程作为执行主体,对本发明实施例提供的方法进行说明:
一、对于容器启动进程:
容器启动进程根据用户输入的命令创建一个容器,并在容器中创建一个第一应用启动进程,后续容器启动进程作为该容器的容器守护进程存在。
然后,容器启动进程和第一应用启动进程进行同步,协商信息交互格式。
然后,容器启动进程将第一应用启动进程放入创建的容器中执行。
然后,容器启动进程执行函数Poll,作用是把当前的文件指针挂到设备内部定义的等待,本实施例中定义内部的等待为等待容器销毁命令。
然后,当用户调用容器销毁命令后,容器守护进程销毁该容器。
二、对于应用启动进程:
第一应用启动进程被创建后,先与容器启动进程进行同步,协商信息交互格式。
然后,第一应用启动进程根据用户输入的命令初始化所述容器。
然后,第一应用启动进程获取根据用户输入的命令获取待启动的应用程序的个数N,并创建N-1个第二应用启动进程,N为不小于2的整数。
然后,第一应用启动进程和N-1个第二应用启动进程在容器中启动所述的N个待启动的应用程序,其中第一或第二每个应用启动进程启动一个待启动的应用程序。
综上,本发明实施例提供了一种在Linux容器中启动应用程序的方法,采用该技术方案,用户可以在创建容器时,通过一条命令在容器中同时启动多个应用程序,方便了容器的管理和使用,增强了容器的可用性和可管理性。
请参考图4,本发明实施例还提供一种Linux系统,包括中央处理器,所述中央处理器包括:
容器启动进程单元,第一应用启动进程单元,和第二应用启动进程单元;
所述容器启动进程单元,用于根据用户输入的命令创建容器,随后作为容器守护进程单元存在,创建所述第一应用启动进程单元,并将所述第一应用启动进程单元放入所述容器中执行;
所述第一应用启动进程单元,用于根据用户输入的命令获取待启动的应用程序的个数N,并创建N-1个所述第二应用启动进程单元,N为不小于2的正整数;所述第一应用启动进程单元和每个第二应用启动进程单元用于启动一个待启动的应用程序。
进一步的,所述容器启动进程单元可以包括:
容器创建子单元,用于获取用户输入的命令,根据容器名称和配置文件路径名称创建容器,所述容器名称是所述命令中指定的,所述配置文件路径名称是所述命令中指定的或者是默认的。
进一步的,所述第一或第二应用启动进程单元可以具体用于按照设定的对应关系启动相应的待启动的应用程序,所述对应关系为应用启动进程与待启动的应用程序的对应关系。
再进一步的,所述容器守护进程单元还可以用于收到容器销毁命令后,终止所述容器中的所有进程,检测到所述容器中的初始进程终止后,将所述容器销毁。
更进一步的,所述容器守护进程单元可以具体用于向容器内的进程组发送SIGKILL信号或者向容器内的所有进程分别发送SIGKILL信号,将容器中的所有进程终止。
综上,本发明实施例提供了一种在Linux系统,该系统可以在容器中同时启动多个应用程序,方便了容器的管理和使用,增强了容器的可用性和可管理性。
本领域普通技术人员可以理解上述实施例的各种方法中的全部或部分步骤是可以通过程序来指令相关的硬件完成,该程序可以存储于一计算机可读存储介质中,存储介质可以包括:只读存储器、随机读取存储器、磁盘或光盘等。
以上对本发明实施例所提供的在Linux容器中启动应用程序的方法和相应的Linux系统进行了详细介绍,但以上实施例的说明只是用于帮助理解本发明的方法及其核心思想,不应理解为对本发明的限制。

Claims (6)

1.一种在Linux容器中启动应用程序的方法,其特征在于,包括:
容器启动进程根据用户输入的命令创建容器,随后所述容器启动进程作为所述容器的容器守护进程存在;
所述容器启动进程创建第一应用启动进程,并将所述第一应用启动进程放入所述容器中执行;
所述第一应用启动进程根据用户输入的命令获取待启动的应用程序的个数N,并创建N-1个第二应用启动进程,N为不小于2的正整数;所述根据用户输入的命令获取待启动的应用程序的个数N包括:获取用户输入的命令行参数中包括的待启动应用程序的个数N,或者,通过解析用户输入的命令行参数来统计其中包括的应用程序路径名称的个数,获取待启动的应用程序的个数N;
所述的第一应用启动进程和N-1个第二应用启动进程在所述容器中启动N个所述待启动的应用程序,其中每个第一或第二应用启动进程启动一个待启动的应用程序;所述的第一应用启动进程和N-1个第二应用启动进程在所述容器中启动所述的N个待启动的应用程序包括:所述第一或第二应用启动进程按照设定的对应关系启动相应的待启动的应用程序,所述对应关系为应用启动进程与待启动的应用程序的对应关系。
2.根据权利要求1所述的方法,其特征在于,所述容器启动进程根据用户输入的命令创建容器还包括:
容器启动进程获取用户输入的命令;
根据容器名称和配置文件路径名称创建容器,所述容器名称是所述命令中指定的,所述配置文件路径名称是所述命令中指定的或者是默认的。
3.根据权利要求1至2中任一所述的方法,其特征在于,所述的第一应用启动进程和N-1个第二应用启动进程在所述容器中启动所述的N个待启动的应用程序之后还包括:
所述容器守护进程收到容器销毁命令后,向容器内的进程组发送SIGKILL信号或者向容器内的所有进程分别发送SIGKILL信号,将容器中的所有进程终止;
所述容器守护进程检测到所述容器中的进程终止后,将所述容器销毁。
4.一种在Linux容器中启动应用程序的装置,其特征在于,包括:
容器创建单元,用于使容器启动进程根据用户输入的命令创建容器,随后所述容器启动进程作为所述容器的容器守护进程存在;
第一进程创建单元,用于使所述容器启动进程创建第一应用启动进程,并将所述第一应用启动进程放入所述容器中执行;
第二进程创建单元,用于使所述第一应用启动进程根据用户输入的命令获取待启动的应用程序的个数N,并创建N-1个第二应用启动进程,N为不小于2的正整数;所述根据用户输入的命令获取待启动的应用程序的个数N包括:获取用户输入的命令行参数中包括的待启动应用程序的个数N,或者,通过解析用户输入的命令行参数来统计其中包括的应用程序路径名称的个数,获取待启动的应用程序的个数N;
启动单元,用于使所述的第一应用启动进程和N-1个第二应用启动进程在所述容器中启动N个所述待启动的应用程序,其中每个第一或第二应用启动进程启动一个待启动的应用程序;所述的第一应用启动进程和N-1个第二应用启动进程在所述容器中启动所述的N个待启动的应用程序包括:所述第一或第二应用启动进程按照设定的对应关系启动相应的待启动的应用程序,所述对应关系为应用启动进程与待启动的应用程序的对应关系。
5.根据权利要求4所述的装置,其特征在于,所述容器创建单元包括:
获取子单元,用于使容器启动进程获取用户输入的命令;
创建子单元,用于使容器启动进程根据容器名称和配置文件路径名称创建容器,所述容器名称是所述命令中指定的,所述配置文件路径名称是所述命令中指定的或者是默认的。
6.根据权利要求4至5中任一所述的装置,其特征在于,还包括:
收发单元,用于使所述容器守护进程收到容器销毁命令后,向容器内的进程组发送SIGKILL信号或者向容器内的所有进程分别发送SIGKILL信号,将容器中的所有进程终止;
销毁单元,用于使所述容器守护进程检测到所述容器中的进程终止后,将所述容器销毁。
CN201180002154.9A 2011-10-24 2011-10-24 在Linux容器中启动应用程序的方法和系统 Active CN102439564B (zh)

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
PCT/CN2011/081168 WO2012167529A1 (zh) 2011-10-24 2011-10-24 在Linux容器中启动应用程序的方法和系统

Publications (2)

Publication Number Publication Date
CN102439564A CN102439564A (zh) 2012-05-02
CN102439564B true CN102439564B (zh) 2014-03-26

Family

ID=45986235

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201180002154.9A Active CN102439564B (zh) 2011-10-24 2011-10-24 在Linux容器中启动应用程序的方法和系统

Country Status (4)

Country Link
US (1) US9183008B2 (zh)
EP (1) EP2746936A4 (zh)
CN (1) CN102439564B (zh)
WO (1) WO2012167529A1 (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107025135A (zh) * 2017-03-03 2017-08-08 网易(杭州)网络有限公司 Docker容器内应用进程管理方法、装置和介质

Families Citing this family (41)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9860274B2 (en) 2006-09-13 2018-01-02 Sophos Limited Policy management
CN102707990B (zh) 2012-05-14 2015-04-08 华为技术有限公司 基于容器的处理方法和装置
CN103678203A (zh) * 2013-12-13 2014-03-26 国家计算机网络与信息安全管理中心 一种实现网卡零拷贝方法及装置
CN104270317B (zh) * 2014-09-12 2018-01-16 普联技术有限公司 一种路由器运行应用程序的控制方法、系统及路由器
US9256467B1 (en) 2014-11-11 2016-02-09 Amazon Technologies, Inc. System for managing and scheduling containers
CN105786334A (zh) * 2014-12-18 2016-07-20 宇龙计算机通信科技(深圳)有限公司 程序操作方法、程序操作装置和终端
CN106326226B (zh) * 2015-06-16 2019-05-07 苏宁易购集团股份有限公司 一种公有云上启动数据库服务的方法及系统
CN104915239B (zh) * 2015-06-30 2018-10-09 北京奇虎科技有限公司 使用容器进行多进程启动的方法及装置
CN104899068A (zh) * 2015-06-30 2015-09-09 北京奇虎科技有限公司 使用容器进行多进程启动的方法及装置
CN105204925A (zh) * 2015-08-26 2015-12-30 北京元心科技有限公司 在多操作系统中管理音视频设备的方法及装置
CN105045669A (zh) * 2015-08-26 2015-11-11 北京元心科技有限公司 容器系统的管理服务方法以及智能终端
US10152330B2 (en) * 2015-09-21 2018-12-11 Bae Systems Information And Electronic Systems Integration Inc. Memory protection using a tagged architecture
CN105357256B (zh) * 2015-09-28 2018-10-30 深信服网络科技(深圳)有限公司 管理移动设备的方法及服务器
US10133590B2 (en) * 2015-09-29 2018-11-20 International Business Machines Corporation Container runtime support
CN105871580A (zh) * 2015-11-02 2016-08-17 乐视致新电子科技(天津)有限公司 跨集群自动化部署运维系统及方法
US10157003B1 (en) * 2015-12-17 2018-12-18 EMC IP Holding Company LLC Storage system with distributed tiered parallel file system comprising software-defined unified memory cluster
US9817648B2 (en) 2016-01-15 2017-11-14 Google Inc. Application containers with dynamic sub-package loading
KR102000266B1 (ko) 2016-01-15 2019-07-15 구글 엘엘씨 애플리케이션 인스턴스들에 걸친 식별자들
CN107196982B (zh) 2016-03-14 2021-01-22 阿里巴巴集团控股有限公司 一种用户请求的处理方法和装置
CN107193577B (zh) 2016-03-15 2021-08-03 斑马智行网络(香港)有限公司 一种应用启动方法、装置和智能终端
US10157136B2 (en) * 2016-03-31 2018-12-18 Intel Corporation Pipelined prefetcher for parallel advancement of multiple data streams
US10069869B2 (en) 2016-05-17 2018-09-04 Amazon Technologies, Inc. Versatile autoscaling
CN106155778A (zh) * 2016-07-07 2016-11-23 中国科学院声学研究所 一种应用容器的启动方法及系统
US10375111B2 (en) 2016-11-12 2019-08-06 Microsoft Technology Licensing, Llc Anonymous containers
US10409642B1 (en) 2016-11-22 2019-09-10 Amazon Technologies, Inc. Customer resource monitoring for versatile scaling service scaling policy recommendations
US11017102B2 (en) 2017-09-12 2021-05-25 Sophos Limited Communicating application information to a firewall
CN109947553B (zh) * 2017-12-21 2022-04-26 中国电信股份有限公司 容器的进程调度方法、装置和计算机可读存储介质
WO2019127399A1 (zh) * 2017-12-29 2019-07-04 浙江大学 Linux容器的细粒度沙盒策略执行方法
CN110134454B (zh) * 2018-02-09 2022-06-14 聚好看科技股份有限公司 一种启动应用程序的方法及其装置
US10977066B2 (en) 2018-04-06 2021-04-13 Red Hat, Inc. Virtual machine to container conversion and optimization
US20190347127A1 (en) * 2018-05-09 2019-11-14 Red Hat, Inc. Service provisioning and orchestration for virtual machine to container migration
US10996973B2 (en) 2018-11-13 2021-05-04 International Business Machines Corporation Executing commands in a virtual environment
CN111324385A (zh) * 2018-12-12 2020-06-23 中兴通讯股份有限公司 应用模块的启动方法、容器、控制设备及可读存储介质
CN110427248B (zh) * 2019-07-12 2021-10-01 中国人民解放军国防科技大学 一种基于容器的轻量级用户环境构建方法、系统及介质
US11669365B1 (en) 2019-08-26 2023-06-06 Amazon Technologies, Inc. Task pool for managed compute instances
CN112527403B (zh) 2019-09-19 2022-07-05 荣耀终端有限公司 一种应用启动方法及电子设备
CN110674043B (zh) * 2019-09-24 2023-09-12 聚好看科技股份有限公司 应用调试的处理方法及服务器
CN111414256B (zh) * 2020-03-27 2022-10-04 中国人民解放军国防科技大学 基于麒麟移动操作系统的应用程序进程派生方法、系统及介质
CN112817492A (zh) * 2021-01-12 2021-05-18 张宇翔 移动终端中应用程序管理方法及系统
CN113296868B (zh) * 2021-07-27 2021-11-23 杭州筋斗腾云科技有限公司 应用平台及应用管理方法
CN117632074A (zh) * 2022-08-16 2024-03-01 华为技术有限公司 一种音频数据处理方法、装置及存储介质

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101178662A (zh) * 2006-11-08 2008-05-14 中兴通讯股份有限公司 一种嵌入式linux应用进程的监控方法
CN101639787A (zh) * 2009-09-07 2010-02-03 中兴通讯股份有限公司 应用程序启动方法及装置

Family Cites Families (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7047252B2 (en) * 2003-12-02 2006-05-16 Oracle International Corporation Complex computation across heterogenous computer systems
JP4741292B2 (ja) * 2005-06-09 2011-08-03 株式会社日立製作所 デバイス管理システム
JP4815938B2 (ja) * 2005-08-16 2011-11-16 ソニー株式会社 情報処理装置および方法、並びにプログラム
US9378066B2 (en) * 2008-02-25 2016-06-28 Sap Se Dynamic resizing of applications running on virtual machines
US9098698B2 (en) * 2008-09-12 2015-08-04 George Mason Research Foundation, Inc. Methods and apparatus for application isolation

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101178662A (zh) * 2006-11-08 2008-05-14 中兴通讯股份有限公司 一种嵌入式linux应用进程的监控方法
CN101639787A (zh) * 2009-09-07 2010-02-03 中兴通讯股份有限公司 应用程序启动方法及装置

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107025135A (zh) * 2017-03-03 2017-08-08 网易(杭州)网络有限公司 Docker容器内应用进程管理方法、装置和介质
CN107025135B (zh) * 2017-03-03 2020-02-21 网易(杭州)网络有限公司 Docker容器内应用进程管理方法、装置和介质

Also Published As

Publication number Publication date
EP2746936A4 (en) 2015-03-11
US20140229951A1 (en) 2014-08-14
EP2746936A1 (en) 2014-06-25
US9183008B2 (en) 2015-11-10
WO2012167529A1 (zh) 2012-12-13
CN102439564A (zh) 2012-05-02

Similar Documents

Publication Publication Date Title
CN102439564B (zh) 在Linux容器中启动应用程序的方法和系统
CN109104467B (zh) 开发环境构建方法、装置以及平台系统和存储介质
CN111641515B (zh) Vnf的生命周期管理方法及装置
US20170085419A1 (en) System and method for deploying an application
EP3284213B1 (en) Managing virtual network functions
EP2630567B1 (en) Coordinated upgrades in distributed systems
CN108255497B (zh) 一种应用的部署方法及装置
US9348646B1 (en) Reboot-initiated virtual machine instance migration
US11422843B2 (en) Virtual machine migration method and apparatus having automatic user registration at a destination virtual machine
EP3133771A1 (en) Virtual machine resource changing method, device and virtual network function device
US11343141B2 (en) Methods and apparatus to migrate physical server hosts between virtual standard switches and virtual distributed switches in a network
EP3531280A1 (en) Accelerator loading method and system, and accelerator loading apparatus
EP3879875A1 (en) Resource change method and device, apparatus, and storage medium
KR20220070020A (ko) 네트워크 자원 관리 방법, 시스템, 네트워크 디바이스 및 판독 가능한 저장 매체
CN112035121A (zh) 一种边缘应用部署方法及系统
CN109857464A (zh) 用于平台部署与操作移动操作系统的系统及其方法
EP3893451A1 (en) Network isolation method and apparatus based on user mode protocol stack
CN110083366B (zh) 应用运行环境的生成方法、装置、计算设备及存储介质
CN108234174B (zh) 虚拟网络功能的管理方法和装置
CN112948102B (zh) 虚拟机事件处理方法、装置和系统
CN109522111B (zh) 异构生态系统的调用方法、装置、电子设备及存储介质
CN110782040A (zh) 一种pytorch任务训练方法、装置、设备及介质
CN115525396A (zh) 基于云原生的应用管理方法及装置
CN115113975A (zh) 集群管理的方法、装置、电子设备及存储介质
US20200344305A1 (en) Commissioning a virtualised network function

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant