CN112887352B - 一种Docker容器的镜像文件上传方法、装置 - Google Patents

一种Docker容器的镜像文件上传方法、装置 Download PDF

Info

Publication number
CN112887352B
CN112887352B CN201911203168.1A CN201911203168A CN112887352B CN 112887352 B CN112887352 B CN 112887352B CN 201911203168 A CN201911203168 A CN 201911203168A CN 112887352 B CN112887352 B CN 112887352B
Authority
CN
China
Prior art keywords
image file
uploading
file
application
uploaded
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
CN201911203168.1A
Other languages
English (en)
Other versions
CN112887352A (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.)
Ultrapower Software Co ltd
Original Assignee
Ultrapower Software 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 Ultrapower Software Co ltd filed Critical Ultrapower Software Co ltd
Priority to CN201911203168.1A priority Critical patent/CN112887352B/zh
Publication of CN112887352A publication Critical patent/CN112887352A/zh
Application granted granted Critical
Publication of CN112887352B publication Critical patent/CN112887352B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/06Protocols specially adapted for file transfer, e.g. file transfer protocol [FTP]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1095Replication or mirroring of data, e.g. scheduling or transport for data synchronisation between network nodes
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D10/00Energy efficient computing, e.g. low power processors, power management or thermal management

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本发明公开了一种Docker容器的镜像文件上传方法、装置。所述方法包括:在各应用的上传页面中接收上传请求和需上传到镜像仓库的镜像文件;将所述镜像文件导入到所述Docker容器所在的系统;若所述镜像文件导入到所述Docker容器所在的系统成功,则登录所述Docker容器的镜像仓库;若登录所述Docker容器的镜像仓库成功,则将所述镜像文件上传至所述镜像仓库。通过上述轻量级、自动化的镜像文件上传方案,能够将该镜像文件上传至Harbor等私有镜像仓库,并能够将是否上传成功的信息通过上传页面通知给相应的操作人员。

Description

一种Docker容器的镜像文件上传方法、装置
技术领域
本发明涉及Docker容器技术领域,具体涉及一种Doker容器的镜像文件上传方法、装置、电子设备和可读存储介质。
背景技术
Docker一个快速部署的轻量级虚拟技术项目,它允许开发者把应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,从而保证应用环境的一致性;Docker镜像可以理解为是容器的模板,一个镜像可以通过命令启动一个或多个容器;镜像仓库是管理镜像的重要工具之一,为存储、上传或下载镜像等提供服务,DockerRegistry是Docker默认带的镜像仓库,而Harbor镜像仓库是构建企业级私有Docker镜像的仓库的开源解决方案,它是Docker Registry的更高级封装,提供友好的Web UI界面、角色和用户权限管理、用户操作审计等功能。
现有技术中将镜像上传至镜像仓库的方案主要为手工执行docker push上传命令,并且依靠上传者判断是否上传成功,操作复杂,难以满足一般企业项目中降低使用人员学习成本的需求,更无法满足如操作简单、界面设计风格统一以及上传工具接口统一等个性化的要求。
发明内容
鉴于上述问题,提出了本发明以便提供一种克服上述问题或者至少部分地解决上述问题的一种Doker镜像文件上传方法、装置、电子设备和可读存储介质。
依据本发明的一个方面,提供了一种Docker容器的镜像文件上传方法,所述方法包括:
在各应用中接收上传请求和需上传到镜像仓库的镜像文件;
将所述镜像文件导入到所述Docker容器所在的系统;
若所述镜像文件导入到所述Docker容器所在的系统成功,则登录所述Docker容器的镜像仓库;
若登录所述Docker容器的镜像仓库成功,则将所述镜像文件上传至所述镜像仓库。
可选的,所述在各应用中接收上传请求和需上传到镜像仓库的镜像文件包括:
通过各所述应用的上传页面获取所述镜像文件,并重新命名所述镜像文件,使得所述镜像文件的名称包括如下的至少一种信息:镜像仓库名称、镜像名称、版本号。
可选的,所述在各应用中接收上传请求和需上传到镜像仓库的镜像文件还包括:
创建记录各所述应用的上传页面URL的回调文件,若所述镜像文件上传操作失败,则通过所述回调文件通知该应用所述镜像文件上传失败;若所述镜像文件上传成功,通知该应用所述镜像文件上传成功。
可选的,所述创建记录各所述应用的上传页面URL的回调文件包括:
创建一个以镜像文件的名称命名的文件夹,将所述镜像文件和回调文件保存在所述文件夹下。
可选的,所述若所述镜像文件上传操作失败,则通过所述回调文件通知该应用所述镜像文件上传失败包括:
解析将所述镜像文件导入到所述Docker容器所在的系统的第一返回结果,若从所述第一返回结果中不能解析出镜像文件的信息,则提取所述回调文件中的URL,通知该应用所述镜像文件上传失败。
可选的,所述若所述镜像文件上传操作失败,则通过所述回调文件通知该应用所述镜像文件上传失败包括:
解析登录所述镜像仓库的第二返回结果,若从所述第二返回结果中不能解析出登录成功的信息,则提取所述回调文件中的URL,通知该应用所述镜像文件上传失败。
可选的,所述若所述镜像文件上传操作失败,则通过所述回调文件通知各所述应用所述镜像文件上传失败包括:
解析上传镜像仓库的第三返回结果,若从所述第三返回结果中不能解析出上传成功的信息,则提取所述回调文件中的URL,通知该应用所述镜像文件上传失败;
所述若所述镜像文件上传成功,通知该应用所述镜像文件上传成功包括:
若从所述第三返回结果中解析出上传成功的信息,则提取所述回调文件中的URL,通知该应用所述镜像文件上传成功。
依据本发明的另一方面,提供了一种Docker容器的镜像文件上传装置,所述装置包括:
页面上传模块,适于在各应用中接收上传请求和需上传到镜像仓库的镜像文件;
导入模块,适于将所述镜像文件导入到所述Docker容器所在的系统;
登录模块,适于若所述镜像文件导入到所述Docker容器所在的系统成功,则登录所述Docker容器的镜像仓库;
仓库上传模块,适于若登录所述Docker容器的镜像仓库成功,则将所述镜像文件上传至所述镜像仓库。
依据本发明的又一方面,提供了一种电子设备,包括:处理器;以及被安排成存储计算机可执行指令的存储器,所述可执行指令在被执行时使所述处理器执行如上述任一所述的方法。
依据本发明的再一方面,提供了一种计算机可读存储介质,其中,所述计算机可读存储介质存储一个或多个程序,所述一个或多个程序当被处理器执行时,实现如上述任一所述的方法。
由上述可知,本发明的技术方案公开了一种Docker容器的镜像文件上传方法,所述方法包括:在各应用的上传页面中接收上传请求和需上传到镜像仓库的镜像文件;将所述镜像文件导入到所述Docker容器所在的系统;若所述镜像文件导入到所述Docker容器所在的系统成功,则登录所述Docker容器的镜像仓库;若登录所述Docker容器的镜像仓库成功,则将所述镜像文件上传至所述镜像仓库。通过上述轻量级、自动化的镜像文件上传方案,能够将该镜像文件上传至私有的镜像仓库,并能够将是否上传成功的信息通过上传页面通知给相应的操作人员。
上述说明仅是本发明技术方案的概述,为了能够更清楚了解本发明的技术手段,而可依照说明书的内容予以实施,并且为了让本发明的上述和其它目的、特征和优点能够更明显易懂,以下特举本发明的具体实施方式。
附图说明
通过阅读下文优选实施方式的详细描述,各种其他的优点和益处对于本领域普通技术人员将变得清楚明了。附图仅用于示出优选实施方式的目的,而并不认为是对本发明的限制。而且在整个附图中,用相同的参考符号表示相同的部件。在附图中:
图1示出了根据本发明一个实施例的Docker容器的镜像文件上传方法的流程示意图;
图2示出了根据本发明一个实施例的Docker容器的镜像文件上传装置的结构示意图;
图3示出了根据本发明一个实施例的电子设备的结构示意图;
图4示出了根据本发明一个实施例的计算机可读存储介质的结构示意图;
图5示出了根据本发明一个实施例的将镜像文件导入Linux系统后返回结果的示意图。
具体实施方式
下面将参照附图更详细地描述本发明的示例性实施例。虽然附图中显示了本发明的示例性实施例,然而应当理解,可以以各种形式实现本发明而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本发明,并且能够将本发明的范围完整的传达给本领域的技术人员。
图1示出了根据本发明一个实施例的Docker容器的镜像文件上传方法的流程示意图;所述方法包括:
步骤S110,在各应用中接收上传请求和需上传到镜像仓库的镜像文件。
本发明为了解决现有Docker容器的一般企业使用人员在上传镜像tar包至镜像仓库比如Harbor镜像仓库甚至是Registry仓库时,面对的操作复杂等问题,提供了一种能够自动上传的中间插件或装置,该插件或装置能够提供统一的接口供使用该Docker服务的各应用程序调用。
在上述上传方法中,首先,上述插件或装置在各应用程序中提供了上传页面或者在其他页面的特定窗口接收上传请求和镜像文件,该上传页面可以为web页面。具体地,可通过提供http协议api接口,各所述应用通过实现multipart/form-data类型的post请求,将上述镜像tar包文件上传到此插件或装置中,例如上述镜像文件可以是caas.tar。
步骤S120,将所述镜像文件导入到所述Docker容器所在的系统。
上述插件或装置在接收到该镜像文件后,需要将该镜像文件导入到Docker环境下,一般为Linux系统,然后通过Linux系统再将在该系统中的镜像文件如caas.tar存储到镜像仓库中。
在具体实现上,可以调用Runtime的exec()方法执行Docker的镜像导命令dockerload-i将镜像文件导入到Linux环境中,导入镜像成功linux系统会返回结果。
步骤S130,若所述镜像文件导入到所述Docker容器所在的系统成功,则登录所述Docker容器的镜像仓库。
在将上述镜像文件caas.tar导入到Linux系统后,为了进一步将镜像文件上传到镜像仓库内,需要首先执行登录镜像仓库的操作。比如,可以通过该插件或装置调用Runtime的exec()方法执行命令docker login登录Harbor镜像仓库,然后解析并匹配返回结果中是否存在Login Succeeded字符串。
步骤S140,若登录所述Docker容器的镜像仓库成功,则将所述镜像文件上传至所述镜像仓库。
在具体实现中,可以通过调用Runtime的exec()方法执行命令docker push将镜像上传到Harbor等私有镜像仓库中,若上传到镜像仓库的操作成功,则返回上传成功的信息至该应用。
由此可知,该实施例公开的技术方案,企业应用程序开发的普通操作人员仅通过应用程序自定义的上传装置或工具就能够将镜像文件上传至镜像仓库,实现了上传的自动化。
在一个实施例中,所述步骤S110包括:通过各应用的上传页面或上传窗口获取所述镜像文件,并重新命名所述镜像文件,使得所述镜像文件的名称包括如下的至少一种信息:镜像仓库名称、镜像名称、版本号。
为了保证上传操作的顺利进行,优选地,在上传操作之前,将需上传的镜像文件进行重新命名,从而便于后续的自动化上传以及回调操作。比如可以将镜像文件的命名方式为《镜像仓库名称#镜像文件名称#版本号.tar》,例如:ultra#caas#2.3.1.tar,其中ultra为镜像仓库名称,caas为镜像文件名称,2.3.1则为版本号信息。
在一个实施例中,所述步骤S110还包括:创建记录各所述应用的上传页面URL的回调文件,若所述镜像文件上传操作失败,则通过所述回调文件通知该应用所述镜像文件上传失败;若所述镜像文件上传成功,通知该应用所述镜像文件上传成功。
为了实现对上传是否成功进行反馈,在该实施例中,创建一个记录各所述应用的上传页面URL的回调文件,比如url.txt文件,该url.txt用以记录该应用的用于结果通知的URL地址,当所述镜像文件上传操作失败,则通过上述回调文件中的URL地址通知该应用所述镜像文件上传失败,否则通知该应用所述镜像文件上传成功。
在一个实施例中,所述步骤S110进一步包括:创建一个以镜像文件的名称命名的文件夹,将所述镜像文件和回调文件保存在所述文件夹下。
在存在多个应用程序的情况下,为了区别各应用程序的上传操作,可以通过特定方式针对各上传操作进行标记。优选地,首先获取需上传的镜像文件的文件名,然后通过File类的mkdir()方法创建一个新的文件夹,并且上述文件名命名该文件夹,将需上传的镜像文件以及回调文件存放到该文件夹中。
在一个实施例中,所述若所述镜像文件上传操作失败,则通过所述回调文件通知该应用所述镜像文件上传失败包括:解析将所述镜像文件导入到所述Docker容器所在的系统的第一返回结果,若从所述第一返回结果中不能解析出镜像文件的信息,则提取所述回调文件中的URL,通知该应用所述镜像文件上传失败。
根据上述方法,上传的镜像文件首先需要进入Linux系统,若导入该系统失败则需要返回上传操作失败的信息。在执行导入操作后,Linux系统会返回结果。所述方法会匹配返回结果中以Loaded image:开头的字符串,截取该字符串后面的内容为镜像文件名称和版本号。参见图5,其中方框内的标注部分,caas:v1为镜像文件名称:版本号。
如果解析不到,则回调url.txt中的url,通知该应用镜像文件上传失败。如果成功解析,进行下一步的登录镜像仓库的操作。
在一个实施例中,所述若所述镜像文件上传操作失败,则通过所述回调文件通知该应用所述镜像文件上传失败包括:解析登录所述镜像仓库的第二返回结果,若从所述第二返回结果中不能解析出登录成功的信息,则提取所述回调文件中的URL,通知该应用所述镜像文件上传失败。
登录镜像仓库后返回的结果为Login Succeeded或LoginFailed字符串,若从登录返回结果中解析不到Login Succeeded字符串,则回调url.txt中的url,通知该应用镜像文件上传失败;如果成功解析,进行下一步的上传操作。
在一个实施例中,所述若所述镜像文件上传操作失败,则通过所述回调文件通知各所述应用所述镜像文件上传失败包括:解析上传镜像仓库的第三返回结果,若从所述第三返回结果中不能解析出上传成功的信息,则提取所述回调文件中的URL,通知该应用所述镜像文件上传失败。
在进行上传镜像文件至镜像仓库之后,通过所述方法解析返回结果是否存在digest:和sha256:字符串,如果解析不到,则回调url.txt中的url,通知该应用镜像文件上传失败。
所述若所述镜像文件上传成功,通知该应用所述镜像文件上传成功包括:若从所述第三返回结果中解析出上传成功的信息,则提取所述回调文件中的URL,通知该应用所述镜像文件上传成功。
即如果从上传操作后的返回结果中成功解析出上述字符串,则回调url.txt中的url,通知应用镜像上传成功。
图2示出了根据本发明一个实施例的Docker容器的镜像文件上传装置的结构示意图;所述装置200包括:
页面上传模块210,适于在各应用中接收上传请求和需上传到镜像仓库的镜像文件。
本发明为了解决现有Docker容器的一般企业使用人员在上传镜像tar包至镜像仓库比如Harbor镜像仓库甚至是Registry仓库时,面对的操作复杂等问题,提供了一种能够自动上传的中间插件或装置,该插件或装置能够提供统一的接口供使用该Docker服务的各应用程序调用。
在上述上传装置中,首先,上述插件或装置在各应用程序中提供了一个上传页面接收上传请求和镜像文件,该上传页面可以为web页面。具体地,可通过提供http协议api接口,各所述应用通过实现multipart/form-data类型的post请求,将上述镜像tar包文件上传到此插件或装置中,例如上述镜像文件可以是caas.tar。
导入模块220,适于将所述镜像文件导入到所述Docker容器所在的系统。
上述插件或装置在接收到该镜像文件后,需要将该镜像文件导入到Docker环境下,一般为Linux系统,然后通过Linux系统再将在该系统中的镜像文件如caas.tar存储到镜像仓库中。
在具体实现上,可以调用Runtime的exec()方法执行Docker的镜像导命令dockerload-i将镜像文件导入到Linux环境中,导入镜像成功linux系统会返回结果。
登录模块230,适于若所述镜像文件导入到所述Docker容器所在的系统成功,则登录所述Docker容器的镜像仓库。
在将上述镜像文件caas.tar导入到Linux系统后,为了进一步将镜像文件上传到镜像仓库内,需要首先执行登录镜像仓库的操作。比如,可以通过该插件或装置调用Runtime的exec()方法执行命令docker login登录Harbor镜像仓库,然后解析并匹配返回结果中是否存在Login Succeeded字符串。
仓库上传模块240,适于若登录所述Docker容器的镜像仓库成功,则将所述镜像文件上传至所述镜像仓库。
在具体实现中,可以通过调用Runtime的exec()方法执行命令docker push将镜像上传到Harbor等私有镜像仓库中,若上传到镜像仓库的操作成功,则返回上传成功的信息至应用的上传页面中。
由此可知,该实施例公开的装置或插件为企业应用docker的镜像仓库提供了一种统一接口,使得普通操作人员仅通过应用程序自定义的上传装置或工具就能够将镜像文件上传至镜像仓库,实现了上传的自动化。
需要说明的是,上述各装置实施例的具体实施方式可以参照前述对应方法实施例的具体实施方式进行,在此不再赘述。
综上所述,本发明公开了一种Docker容器的镜像文件上传的技术方案,所述技术方案包括:在各应用的上传页面中接收上传请求和需上传到镜像仓库的镜像文件;将所述镜像文件导入到所述Docker容器所在的系统;若所述镜像文件导入到所述Docker容器所在的系统成功,则登录所述Docker容器的镜像仓库;若登录所述Docker容器的镜像仓库成功,则将所述镜像文件上传至所述镜像仓库。通过上述轻量级、自动化的镜像文件上传方案,能够将该镜像文件上传至私有的镜像仓库,并能够将是否上传成功的信息通过上传页面通知给相应的操作人员。
需要说明的是:
在此提供的算法和显示不与任何特定计算机、虚拟装置或者其它设备固有相关。各种通用装置也可以与基于在此的示教一起使用。根据上面的描述,构造这类装置所要求的结构是显而易见的。此外,本发明也不针对任何特定编程语言。应当明白,可以利用各种编程语言实现在此描述的本发明的内容,并且上面对特定语言所做的描述是为了披露本发明的最佳实施方式。
在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。
类似地,应当理解,为了精简本发明并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释成反映如下意图:即所要求保护的本发明要求比在每个权利要求中所明确记载的特征更多的特征。更确切地说,如下面的权利要求书所反映的那样,发明方面在于少于前面公开的单个实施例的所有特征。因此,遵循具体实施方式的权利要求书由此明确地并入该具体实施方式,其中每个权利要求本身都作为本发明的单独实施例。
本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组件组合成一个模块或单元或组件,以及此外可以把它们分成多个子模块或子单元或子组件。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书(包括伴随的权利要求、摘要和附图)中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书(包括伴随的权利要求、摘要和附图)中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。
此外,本领域的技术人员能够理解,尽管在此所述的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。例如,在下面的权利要求书中,所要求保护的实施例的任意之一都可以以任意的组合方式来使用。
本发明的各个部件实施例可以以硬件实现,或者以在一个或者多个处理器上运行的软件模块实现,或者以它们的组合实现。本领域的技术人员应当理解,可以在实践中使用微处理器或者数字信号处理器(DSP)来实现根据本发明实施例的Docker容器的镜像文件上传装置中的一些或者全部部件的一些或者全部功能。本发明还可以实现为用于执行这里所描述的方法的一部分或者全部的设备或者装置程序(例如,计算机程序和计算机程序产品)。这样的实现本发明的程序可以存储在计算机可读介质上,或者可以具有一个或者多个信号的形式。这样的信号可以从因特网网站上下载得到,或者在载体信号上提供,或者以任何其他形式提供。
例如,图3示出了根据本发明一个实施例的电子设备的结构示意图。该电子设备300包括处理器310和被安排成存储计算机可执行指令(计算机可读程序代码)的存储器320。存储器320可以是诸如闪存、EEPROM(电可擦除可编程只读存储器)、EPROM、硬盘或者ROM之类的电子存储器。存储器320具有存储用于执行上述方法中的任何方法步骤的计算机可读程序代码331的存储空间330。例如,用于存储计算机可读程序代码的存储空间330可以包括分别用于实现上面的方法中的各种步骤的各个计算机可读程序代码331。计算机可读程序代码331可以从一个或者多个计算机程序产品中读出或者写入到这一个或者多个计算机程序产品中。这些计算机程序产品包括诸如硬盘,紧致盘(CD)、存储卡或者软盘之类的程序代码载体。这样的计算机程序产品通常为例如图4所述的计算机可读存储介质。图4示出了根据本发明一个实施例的一种计算机可读存储介质的结构示意图。该计算机可读存储介质400存储有用于执行根据本发明的方法步骤的计算机可读程序代码331,可以被电子设备300的处理器310读取,当计算机可读程序代码331由电子设备300运行时,导致该电子设备300执行上面所描述的方法中的各个步骤,具体来说,该计算机可读存储介质存储的计算机可读程序代码331可以执行上述任一实施例中示出的方法。计算机可读程序代码331可以以适当形式进行压缩。
应该注意的是上述实施例对本发明进行说明而不是对本发明进行限制,并且本领域技术人员在不脱离所附权利要求的范围的情况下可设计出替换实施例。在权利要求中,不应将位于括号之间的任何参考符号构造成对权利要求的限制。单词“包含”不排除存在未列在权利要求中的元件或步骤。位于元件之前的单词“一”或“一个”不排除存在多个这样的元件。本发明可以借助于包括有若干不同元件的硬件以及借助于适当编程的计算机来实现。在列举了若干装置的单元权利要求中,这些装置中的若干个可以是通过同一个硬件项来具体体现。单词第一、第二、以及第三等的使用不表示任何顺序。可将这些单词解释为名称。

Claims (10)

1.一种Docker容器的镜像文件上传方法,其特征在于,所述方法包括:
通过http协议api接口在各应用中接收上传请求和需上传到镜像仓库的镜像文件;
执行Docker的镜像导入命令docker load-i将所述镜像文件导入到所述Docker容器所在的系统;
若所述镜像文件导入到所述Docker容器所在的系统成功,则登录所述Docker容器的镜像仓库;
若登录所述Docker容器的镜像仓库成功,则将所述镜像文件上传至所述镜像仓库。
2.如权利要求1所述的方法,其特征在于,所述在各应用中接收上传请求和需上传到镜像仓库的镜像文件包括:
通过各所述应用的上传页面获取所述镜像文件,并重新命名所述镜像文件,使得所述镜像文件的名称包括如下的至少一种信息:镜像仓库名称、镜像名称、版本号。
3.如权利要求1所述的方法,其特征在于,所述在各应用中接收上传请求和需上传到镜像仓库的镜像文件还包括:
创建记录各所述应用的上传页面URL的回调文件,若所述镜像文件上传操作失败,则通过所述回调文件通知该应用所述镜像文件上传失败;若所述镜像文件上传成功,通知该应用所述镜像文件上传成功。
4.如权利要求3所述的方法,其特征在于,所述创建记录各所述应用的上传页面URL的回调文件包括:
创建一个以镜像文件的名称命名的文件夹,将所述镜像文件和回调文件保存在所述文件夹下。
5.如权利要求3所述的方法,其特征在于,所述若所述镜像文件上传操作失败,则通过所述回调文件通知该应用所述镜像文件上传失败包括:
解析将所述镜像文件导入到所述Docker容器所在的系统的第一返回结果,若从所述第一返回结果中不能解析出镜像文件的信息,则提取所述回调文件中的URL,通知该应用所述镜像文件上传失败。
6.如权利要求3-5任一项所述的方法,其特征在于,所述若所述镜像文件上传操作失败,则通过所述回调文件通知该应用所述镜像文件上传失败包括:
解析登录所述镜像仓库的第二返回结果,若从所述第二返回结果中不能解析出登录成功的信息,则提取所述回调文件中的URL,通知该应用所述镜像文件上传失败。
7.如权利要求3-5任一项所述的方法,其特征在于,所述若所述镜像文件上传操作失败,则通过所述回调文件通知各所述应用所述镜像文件上传失败包括:
解析上传镜像仓库的第三返回结果,若从所述第三返回结果中不能解析出上传成功的信息,则提取所述回调文件中的URL,通知该应用所述镜像文件上传失败;
所述若所述镜像文件上传成功,通知该应用所述镜像文件上传成功包括:
若从所述第三返回结果中解析出上传成功的信息,则提取所述回调文件中的URL,通知该应用所述镜像文件上传成功。
8.一种Docker容器的镜像文件上传装置,其特征在于,所述装置包括:
页面上传模块,适于通过http协议api接口在各应用中接收上传请求和需上传到镜像仓库的镜像文件;
导入模块,适于执行Docker的镜像导入命令docker load-i将所述镜像文件导入到所述Docker容器所在的系统;
登录模块,适于若所述镜像文件导入到所述Docker容器所在的系统成功,则登录所述Docker容器的镜像仓库;
仓库上传模块,适于若登录所述Docker容器的镜像仓库成功,则将所述镜像文件上传至所述镜像仓库。
9.一种电子设备,其中,该电子设备包括:处理器;以及被安排成存储计算机可执行指令的存储器,所述可执行指令在被执行时使所述处理器执行如权利要求1-7中任一项所述的方法。
10.一种计算机可读存储介质,其中,所述计算机可读存储介质存储一个或多个程序,所述一个或多个程序当被处理器执行时,实现如权利要求1-7中任一项所述的方法。
CN201911203168.1A 2019-11-29 2019-11-29 一种Docker容器的镜像文件上传方法、装置 Active CN112887352B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201911203168.1A CN112887352B (zh) 2019-11-29 2019-11-29 一种Docker容器的镜像文件上传方法、装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201911203168.1A CN112887352B (zh) 2019-11-29 2019-11-29 一种Docker容器的镜像文件上传方法、装置

Publications (2)

Publication Number Publication Date
CN112887352A CN112887352A (zh) 2021-06-01
CN112887352B true CN112887352B (zh) 2023-04-18

Family

ID=76038704

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201911203168.1A Active CN112887352B (zh) 2019-11-29 2019-11-29 一种Docker容器的镜像文件上传方法、装置

Country Status (1)

Country Link
CN (1) CN112887352B (zh)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113918096B (zh) * 2021-10-21 2023-09-22 城云科技(中国)有限公司 一种算法镜像包的上传方法、装置及应用

Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN105589957A (zh) * 2015-12-22 2016-05-18 新浪网技术(中国)有限公司 一种文档转化方法及文档转化系统
CN106775760A (zh) * 2017-01-04 2017-05-31 郑州云海信息技术有限公司 基于源码库上传容器镜像至镜像仓库的方法及系统
CN106776149A (zh) * 2017-01-04 2017-05-31 郑州云海信息技术有限公司 本地容器镜像上传至镜像仓库的方法及系统
CN106843837A (zh) * 2016-12-21 2017-06-13 中电科华云信息技术有限公司 openstack组件容器化的构建方法
CN106899669A (zh) * 2017-02-23 2017-06-27 郑州云海信息技术有限公司 一种基于Registry的企业容器镜像建立方法和装置
CN106936636A (zh) * 2017-03-15 2017-07-07 无锡华云数据技术服务有限公司 一种快速部署容器化的云计算测试平台的实现方法
CN107066310A (zh) * 2017-03-11 2017-08-18 郑州云海信息技术有限公司 一种搭建及使用安全Docker私有仓库的方法及装置
CN109408069A (zh) * 2018-07-19 2019-03-01 中国矿业大学 一种面向云件PaaS平台的云件镜像制作方法与系统
WO2019127973A1 (zh) * 2017-12-29 2019-07-04 平安科技(深圳)有限公司 镜像仓库的权限认证方法、系统、设备及存储介质

Patent Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN105589957A (zh) * 2015-12-22 2016-05-18 新浪网技术(中国)有限公司 一种文档转化方法及文档转化系统
CN106843837A (zh) * 2016-12-21 2017-06-13 中电科华云信息技术有限公司 openstack组件容器化的构建方法
CN106775760A (zh) * 2017-01-04 2017-05-31 郑州云海信息技术有限公司 基于源码库上传容器镜像至镜像仓库的方法及系统
CN106776149A (zh) * 2017-01-04 2017-05-31 郑州云海信息技术有限公司 本地容器镜像上传至镜像仓库的方法及系统
CN106899669A (zh) * 2017-02-23 2017-06-27 郑州云海信息技术有限公司 一种基于Registry的企业容器镜像建立方法和装置
CN107066310A (zh) * 2017-03-11 2017-08-18 郑州云海信息技术有限公司 一种搭建及使用安全Docker私有仓库的方法及装置
CN106936636A (zh) * 2017-03-15 2017-07-07 无锡华云数据技术服务有限公司 一种快速部署容器化的云计算测试平台的实现方法
WO2019127973A1 (zh) * 2017-12-29 2019-07-04 平安科技(深圳)有限公司 镜像仓库的权限认证方法、系统、设备及存储介质
CN109408069A (zh) * 2018-07-19 2019-03-01 中国矿业大学 一种面向云件PaaS平台的云件镜像制作方法与系统

Also Published As

Publication number Publication date
CN112887352A (zh) 2021-06-01

Similar Documents

Publication Publication Date Title
US20190303120A1 (en) Dynamic container deployment with parallel conditional layers
CN108153551B (zh) 一种业务流程页面的展现方法和装置
US9183007B2 (en) Dynamic determination of application server runtime classloading
US9602347B2 (en) Method, system and program for browser to switch IE kernel
US9912747B2 (en) Browser and system for download and download method
US9552214B2 (en) Tool for automated extraction and loading of configuration settings
CN105183760B (zh) 一种网页组件加载方法和装置
CN104036011A (zh) 网页元素的显示方法以及浏览器装置
US9665465B1 (en) Automated determination of application permissions
US10191838B2 (en) Method and device for checking influence of deleting cache file, and mobile terminal
CN107528718B (zh) 获取资源的方法、装置和系统
CN107133165B (zh) 浏览器兼容性检测方法及装置
CN111930382B (zh) 应用页面的接入方法、装置及设备
CN103678487A (zh) 一种网页快照的生成方法和装置
WO2019095667A1 (zh) 数据库数据采集方法、应用服务器及计算机可读存储介质
CN105554137A (zh) 一种备份系统及方法
CN112887352B (zh) 一种Docker容器的镜像文件上传方法、装置
US20170140009A1 (en) Caching linked queries for optimized compliance management
CN114020689A (zh) 数据处理方法、数据处理装置、电子设备及存储介质
CN111124525A (zh) 一种网站功能实现方法和装置
US8615751B2 (en) Seeding product information
CN110661678B (zh) 一种异常监控方法和装置
US20180089221A1 (en) Methods and Apparatus for Managing Access to File Content
CN109683920A (zh) 一种基于unity程序部署方法与系统
CN115982499B (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