CN105847045A - 一种基于Docker容器的应用封装系统及管理方法 - Google Patents
一种基于Docker容器的应用封装系统及管理方法 Download PDFInfo
- Publication number
- CN105847045A CN105847045A CN201610162692.9A CN201610162692A CN105847045A CN 105847045 A CN105847045 A CN 105847045A CN 201610162692 A CN201610162692 A CN 201610162692A CN 105847045 A CN105847045 A CN 105847045A
- Authority
- CN
- China
- Prior art keywords
- container
- application
- module
- configuration
- user
- 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.)
- Granted
Links
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/50—Network service management, e.g. ensuring proper service fulfilment according to agreements
- H04L41/5041—Network service management, e.g. ensuring proper service fulfilment according to agreements characterised by the time relationship between creation and deployment of a service
- H04L41/5048—Automatic or semi-automatic definitions, e.g. definition templates
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Stored Programmes (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本发明的基于Docker容器的应用封装系统及管理方法实现了容器应用在生命周期的管理过程中对构建应用流程的简化,降低了构建应用的复杂度,实现“所见即所得”的方式构建应用。用户只需要根据类别选择具体的容器应用,点击即可构建成功,并且能够直接访问使用。传统的容器应用构建过程中配置参数的流程需要用户干预设置,本发明意在根据不同类型的应用对应不同的资源参数配置,通过本发明来实现容器应用完全自动的设置合理配置参数,整个过程完全不需要用户干预,用户只需要选择所需构建的应用,稍加等待,容器应用即可构建成功,并成功运行访问。
Description
技术领域
本发明涉及容器应用虚拟化技术相关领域,尤其涉及一种基于Docker容器的应用封装系统及管理方法。
背景技术
Container(容器)的出现,实现了对传统应用,特别是基于网络的B/S(浏览器/服务器)应用更为灵活的部署和管理方式,同时也实现了资源的隔离和限制,满足了快速部署和应用多样化的需求。基于Docker容器技术的应用虚拟化,能够以极快的方式封装和部署应用。Docker主要使用基于Linux操作系统的LXC轻量虚拟化和Cgroup资源隔离技术,并通过镜像封装的方式实现极小的精简环境满足不同容器的系统环境依赖。
传统的Docker的应用编排机制,如图1所示,使用Docker File模块构建镜像,或者通过Registry模块直接获取镜像,Docker Engine使用构建或已获取的镜像启动一个或多个Container(容器)来提供基于容器的应用交付。
基于Docker容器的应用目前没有统一的标准去合理的统一管理应用容器的生命周期,包括创建和销毁(删除)以及分配应用所属用户的机制。
目前现有的一些管理平台也只是针对自身平台的机制,管理平台内所创建的应用容器,而且在创建过程中需要最终用户干预创建的过程,如设置一些参数等,并且不同的平台之间的容器应用无法统一管理,用户构建一个容器的应用仍然需要一个繁琐的流程。现有的常见的管理平台容器的应用封装和生命周期的管理方法需要用户过多的干预容器创建过程,存在以下问题:
容器应用封装对象层面直接基于容器镜像,缺乏更为简洁直观的抽象方式来展示应用;在容器应用的生命周期管理过程中,构建过程需要用户干预设置参数,不够简洁直观,有一定的技术门槛,要求用户需要掌握一定的专业技术知识,增加了用户使用的难度和复杂程度。
发明内容
为了解决上述问题,本发明提供一种能够实现容器应用一体化封装的基于Docker容器的应用封装系统及管理方法。
本发明的一种基于Docker容器的应用封装系统,包括与用户进行应用交互供用户选择容器应用类别的应用交互模块、提供与所述用户选择的容器应用对应的基本容器镜像的基本容器镜像模块、根据用户选择的容器应用类别自动配置容器参数的统一配置模块;所述统一配置模块包括配置基本资源配额的资源配额配置模块、对所述资源配额配置模块配置的资源进行子序列定义的资源配额子序列定义模块、定义容器应用用户访问权限的用户访问权限配置模块、为容器配置网络和域名的网络/域名配置模块、区分所述容器用户选择的容器应用所属的节点序列的所属节点序列模块、为容器应用配置索引序列号的索引序列配置模块。
其中,所述资源配额子序列定义模块包括定义容器存储的存储定义模块、定义容器存储容量的存储容量定义模块、定义容器网络速率的网络速率定义模块、定义容器CPU负载的CPU负载定义模块、定义容器内存占用的内存占用定义模块。且所述统一配置模块为每一容器应用配置对应的索引序列号,每一索引序列号对应一容器参数。
本发明的一种基于Docker容器的应用封装管理方法,其特征在于,所述基于Docker容器的应用封装管理方法通过基于Docker容器的应用封装系统将基本容器镜像与具体应用类别、应用名称及具体参数配置打包封装,包括如下步骤:
s1、通过所述基于Docker容器的应用封装系统向用户以“类别”+“名称”的方式展示容器应用类别可选项,用户选择具体需要的容器应用类别;
s2、为每一具体容器应用类别配置专属的索引序列号;
s3、为每一索引序列号配置具体的参数;
s4、在用户选择了具体容器应用类别后根据其专属的索引序列号对应的配置参数自动进行容器初始化并自动生成应用名称;
s5、将经过初始化之后的容器应用提供给用户。
其中,为每一索引序列号配置的参数包括网络/域名参数、用户访问权限配置参数、资源配额配置参数。所述资源配额配置参数包括存储参数、存储容量参数、网路速率参数、CPU参数、内存占用参数。
本发明的基于Docker容器的应用封装系统及管理方法实现了容器应用在生命周期的管理过程中对构建应用流程的简化,降低了构建应用的复杂度,实现“所见即所得”的方式构建应用。用户只需要根据类别选择具体的容器应用,点击即可构建成功,并且能够直接访问使用。传统的容器应用构建过程中配置参数的流程需要用户干预设置,本发明意在根据不同类型的应用对应不同的资源参数配置,通过本发明来实现容器应用完全自动的设置合理配置参数,整个过程完全不需要用户干预,用户只需要选择所需构建的应用,稍加等待,容器应用即可构建成功,并成功运行访问。
当应用构建成功后可看到网络和域名等基本信息,如果需要查看更多的信息,可以使用高级功能查看具体的配置信息,同时也支持配置的修改,提交修改即可完成。
附图说明
图1是现有技术下容器应用编排机制示意图;
图2是本发明的基于Docker容易的应用封装系统示意图;
图3是图2中基于Docker容易的应用封装系统的资源配额子序列定义模块组成框图示意图。
具体实施方式
如图2和3所示,本发明的一种基于Docker容器的应用封装系统,包括与用户进行应用交互供用户选择容器应用类别的应用交互模块、提供与所述用户选择的容器应用对应的基本容器镜像的基本容器镜像模块、根据用户选择的容器应用类别自动配置容器参数的统一配置模块;所述统一配置模块包括配置基本资源配额的资源配额配置模块、对所述资源配额配置模块配置的资源进行子序列定义的资源配额子序列定义模块、定义容器应用用户访问权限的用户访问权限配置模块、为容器配置网络和域名的网络/域名配置模块、区分所述容器用户选择的容器应用所属的节点序列的所属节点序列模块、为容器应用配置索引序列号的索引序列配置模块。其中,所述资源配额子序列定义模块包括定义容器存储的存储定义模块、定义容器存储容量的存储容量定义模块、定义容器网络速率的网络速率定义模块、定义容器CPU负载的CPU负载定义模块、定义容器内存占用的内存占用定义模块。且所述统一配置模块为每一容器应用配置对应的索引序列号,每一索引序列号对应一容器参数。
本发明的一种基于Docker容器的应用封装管理方法,其特征在于,所述基于Docker容器的应用封装管理方法通过基于Docker容器的应用封装系统将基本容器镜像与具体应用类别、应用名称及具体参数配置打包封装,包括如下步骤:
s1、通过所述基于Docker容器的应用封装系统向用户以“类别”+“名称”的方式展示容器应用类别可选项,用户选择具体需要的容器应用类别;
s2、为每一具体容器应用类别配置专属的索引序列号;
s3、为每一索引序列号配置具体的参数;
s4、在用户选择了具体容器应用类别后根据其专属的索引序列号对应的配置参数自动进行容器初始化并自动生成应用名称;
s5、将经过初始化之后的容器应用提供给用户。
其中,为每一索引序列号配置的参数包括网络/域名参数、用户访问权限配置参数、资源配额配置参数。所述资源配额配置参数包括存储参数、存储容量参数、网路速率参数、CPU参数、内存占用参数。
本发明的基于Docker容器的应用封装系统不再直接使用镜像的方式提供给用户自行构建容器应用,直接以“类别”+“名称”的方式提供给用户选择,如“Web”+”博客”的方式呈现给用户选择,具体展示方式可以是“类别”+“名称”的方式展示给用户,也可以用分类列表或目录的方式提供给用户选择,如“类别”分类列表或目录下,展示名称让用户选择。
本发明的基于Docker容器的应用封装系统及管理方法实现了容器应用在生命周期的管理过程中对构建应用流程的简化,降低了构建应用的复杂度,实现“所见即所得”的方式构建应用。用户只需要根据类别选择具体的容器应用,点击即可构建成功,并且能够直接访问使用。传统的容器应用构建过程中配置参数的流程需要用户干预设置,本发明意在根据不同类型的应用对应不同的资源参数配置,通过本发明来实现容器应用完全自动的设置合理配置参数,整个过程完全不需要用户干预,用户只需要选择所需构建的应用,稍加等待,容器应用即可构建成功,并成功运行访问。
当应用构建成功后可看到网络和域名等基本信息,如果需要查看更多的信息,可以使用高级功能查看具体的配置信息,同时也支持配置的修改,提交修改即可完成。
以上所述,仅为本发明较佳的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明披露的技术范围内,根据本发明的技术方案及其发明构思加以等同替换或改变,都应涵盖在本发明的保护范围之内。
Claims (6)
1.一种基于Docker容器的应用封装系统,其特征在于,所述基于docker容器的应用封装系统包括与用户进行应用交互供用户选择容器应用类别的应用交互模块、提供与所述用户选择的容器应用对应的基本容器镜像的基本容器镜像模块、根据用户选择的容器应用类别自动配置容器参数的统一配置模块;
所述统一配置模块包括配置基本资源配额的资源配额配置模块、对所述资源配额配置模块配置的资源进行子序列定义的资源配额子序列定义模块、定义容器应用用户访问权限的用户访问权限配置模块、为容器配置网络和域名的网络/域名配置模块、区分所述容器用户选择的容器应用所属的节点序列的所属节点序列模块、为容器应用配置索引序列号的索引序列配置模块。
2.根据权利要求1所述的基于Docker容器的应用封装系统,其特征在于,所述资源配额子序列定义模块包括定义容器存储的存储定义模块、定义容器存储容量的存储容量定义模块、定义容器网络速率的网络速率定义模块、定义容器CPU负载的CPU负载定义模块、定义容器内存占用的内存占用定义模块。
3.根据权利要求2所述的基于Docker容器的应用封装系统,其特征在于,所述统一配置模块为每一容器应用配置对应的索引序列号,每一索引序列号对应一容器参数。
4.一种基于Docker容器的应用封装管理方法,其特征在于,所述基于Docker容器的应用封装管理方法通过基于Docker容器的应用封装系统将基本容器镜像与具体应用类别、应用名称及具体参数配置打包封装,包括如下步骤:
s1、通过所述基于Docker容器的应用封装系统向用户以“类别”+“名称”的方式展示容器应用类别可选项,用户选择具体需要的容器应用类别;
s2、为每一具体容器应用类别配置专属的索引序列号;
s3、为每一索引序列号配置具体的参数;
s4、在用户选择了具体容器应用类别后根据其专属的索引序列号对应的配置参数自动进行容器初始化并自动生成应用名称;
s5、将经过初始化之后的容器应用提供给用户。
5.根据权利要求4所述的基于Docker容器的应用封装管理方法,其特征在于,为每一索引序列号配置的参数包括网络/域名参数、用户访问权限配置参数、资源配额配置参数。
6.根据权利要求5所述的基于Docker容器的应用封装管理方法,其特征在于,所述资源配额配置参数包括存储参数、存储容量参数、网路速率参数、CPU参数、内存占用参数。
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN2016100061663 | 2016-01-04 | ||
CN201610006166 | 2016-01-04 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN105847045A true CN105847045A (zh) | 2016-08-10 |
CN105847045B CN105847045B (zh) | 2019-06-18 |
Family
ID=56587892
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201610162692.9A Active CN105847045B (zh) | 2016-01-04 | 2016-03-21 | 一种基于Docker容器的应用封装系统及管理方法 |
CN201610238098.3A Active CN105915378B (zh) | 2016-01-04 | 2016-04-15 | 一种基于容器应用的跨平台统一管理系统 |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201610238098.3A Active CN105915378B (zh) | 2016-01-04 | 2016-04-15 | 一种基于容器应用的跨平台统一管理系统 |
Country Status (1)
Country | Link |
---|---|
CN (2) | CN105847045B (zh) |
Cited By (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106302728A (zh) * | 2016-08-15 | 2017-01-04 | 中国联合网络通信集团有限公司 | 家庭设备远程控制方法及装置 |
CN107493344A (zh) * | 2017-08-29 | 2017-12-19 | 郑州云海信息技术有限公司 | 一种Web访问Docker容器的方法及系统 |
CN107577538A (zh) * | 2017-10-23 | 2018-01-12 | 中国联合网络通信集团有限公司 | 容器资源管理方法及系统 |
CN107819802A (zh) * | 2016-09-13 | 2018-03-20 | 华为软件技术有限公司 | 一种在节点集群中的镜像获取方法、节点设备及服务器 |
CN108664290A (zh) * | 2018-05-17 | 2018-10-16 | 中国平安人寿保险股份有限公司 | 一种应用程序配置方法、装置、电子设备及存储介质 |
CN109828830A (zh) * | 2019-01-18 | 2019-05-31 | 北京百度网讯科技有限公司 | 用于管理容器的方法和装置 |
US10324708B2 (en) | 2017-11-14 | 2019-06-18 | Red Hat, Inc. | Managing updates to container images |
WO2019128984A1 (zh) * | 2017-12-29 | 2019-07-04 | 华为技术有限公司 | 容器的安全策略的处理方法和相关装置 |
CN111273965A (zh) * | 2020-02-17 | 2020-06-12 | 支付宝(杭州)信息技术有限公司 | 一种容器应用启动方法、系统、装置及电子设备 |
US11748153B2 (en) | 2020-11-25 | 2023-09-05 | International Business Machines Corporation | Anticipated containerized infrastructure used in performing cloud migration |
US11922181B2 (en) | 2021-09-14 | 2024-03-05 | International Business Machines Corporation | Configuration discovery of computer applications |
Families Citing this family (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107797845B (zh) | 2016-09-07 | 2021-06-15 | 华为技术有限公司 | 用于访问容器的方法和装置 |
CN108268299A (zh) * | 2016-12-29 | 2018-07-10 | 航天信息股份有限公司 | 一种基于OpenStack云平台的Docker共享存储解决方法 |
CN108196843B (zh) * | 2018-01-09 | 2021-03-26 | 成都睿码科技有限责任公司 | 可视化Docker容器自动编译部署的运维方法 |
CN109344032A (zh) * | 2018-09-27 | 2019-02-15 | 郑州云海信息技术有限公司 | 一种监控方法和装置 |
CN110310512B (zh) * | 2019-07-10 | 2021-02-19 | 中国联合网络通信集团有限公司 | 一种基于5g物联网容器技术的停车场定置管理方法及系统 |
CN112241293A (zh) * | 2019-07-19 | 2021-01-19 | 北京东土科技股份有限公司 | 工业互联网云平台的应用管理方法、装置、设备及介质 |
US11165810B2 (en) | 2019-08-27 | 2021-11-02 | International Business Machines Corporation | Password/sensitive data management in a container based eco system |
CN110515602B (zh) * | 2019-09-17 | 2023-08-18 | 成都源动数据科技有限公司 | 一种在线交互式编程开放实验系统 |
CN111813497A (zh) * | 2020-06-30 | 2020-10-23 | 绿盟科技集团股份有限公司 | 一种容器环境异常检测的方法、装置、介质及计算机设备 |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104601580A (zh) * | 2015-01-20 | 2015-05-06 | 浪潮电子信息产业股份有限公司 | 一种基于强制访问控制的策略容器设计方法 |
US20150256481A1 (en) * | 2014-03-06 | 2015-09-10 | Jisto Inc. | Elastic Compute Cloud Based On Underutilized Server Resources Using A Distributed Container System |
CN105138765A (zh) * | 2015-08-21 | 2015-12-09 | 中国科学院自动化研究所 | 基于Docker的人工交通系统大规模计算实验方法 |
Family Cites Families (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101815024B (zh) * | 2010-03-24 | 2014-10-22 | 中兴通讯股份有限公司 | 以太业务互通方法及装置 |
CN102946425B (zh) * | 2012-11-05 | 2015-10-28 | 西安工程大学 | 基于OSGi的统一通信平台服务集成框架 |
CN104158721A (zh) * | 2014-07-15 | 2014-11-19 | 神州数码融信软件有限公司 | 一种基础信息交互的系统 |
-
2016
- 2016-03-21 CN CN201610162692.9A patent/CN105847045B/zh active Active
- 2016-04-15 CN CN201610238098.3A patent/CN105915378B/zh active Active
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20150256481A1 (en) * | 2014-03-06 | 2015-09-10 | Jisto Inc. | Elastic Compute Cloud Based On Underutilized Server Resources Using A Distributed Container System |
CN104601580A (zh) * | 2015-01-20 | 2015-05-06 | 浪潮电子信息产业股份有限公司 | 一种基于强制访问控制的策略容器设计方法 |
CN105138765A (zh) * | 2015-08-21 | 2015-12-09 | 中国科学院自动化研究所 | 基于Docker的人工交通系统大规模计算实验方法 |
Cited By (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106302728B (zh) * | 2016-08-15 | 2019-12-03 | 中国联合网络通信集团有限公司 | 家庭设备远程控制方法及装置 |
CN106302728A (zh) * | 2016-08-15 | 2017-01-04 | 中国联合网络通信集团有限公司 | 家庭设备远程控制方法及装置 |
CN107819802A (zh) * | 2016-09-13 | 2018-03-20 | 华为软件技术有限公司 | 一种在节点集群中的镜像获取方法、节点设备及服务器 |
CN107493344A (zh) * | 2017-08-29 | 2017-12-19 | 郑州云海信息技术有限公司 | 一种Web访问Docker容器的方法及系统 |
CN107577538A (zh) * | 2017-10-23 | 2018-01-12 | 中国联合网络通信集团有限公司 | 容器资源管理方法及系统 |
CN107577538B (zh) * | 2017-10-23 | 2020-03-31 | 中国联合网络通信集团有限公司 | 容器资源管理方法及系统 |
US10324708B2 (en) | 2017-11-14 | 2019-06-18 | Red Hat, Inc. | Managing updates to container images |
WO2019128984A1 (zh) * | 2017-12-29 | 2019-07-04 | 华为技术有限公司 | 容器的安全策略的处理方法和相关装置 |
CN109992956A (zh) * | 2017-12-29 | 2019-07-09 | 华为技术有限公司 | 容器的安全策略的处理方法和相关装置 |
CN108664290A (zh) * | 2018-05-17 | 2018-10-16 | 中国平安人寿保险股份有限公司 | 一种应用程序配置方法、装置、电子设备及存储介质 |
CN108664290B (zh) * | 2018-05-17 | 2024-02-02 | 中国平安人寿保险股份有限公司 | 一种应用程序配置方法、装置、电子设备及存储介质 |
CN109828830A (zh) * | 2019-01-18 | 2019-05-31 | 北京百度网讯科技有限公司 | 用于管理容器的方法和装置 |
CN109828830B (zh) * | 2019-01-18 | 2021-07-16 | 北京百度网讯科技有限公司 | 用于管理容器的方法和装置 |
CN111273965A (zh) * | 2020-02-17 | 2020-06-12 | 支付宝(杭州)信息技术有限公司 | 一种容器应用启动方法、系统、装置及电子设备 |
CN111273965B (zh) * | 2020-02-17 | 2021-10-29 | 支付宝(杭州)信息技术有限公司 | 一种容器应用启动方法、系统、装置及电子设备 |
US11748153B2 (en) | 2020-11-25 | 2023-09-05 | International Business Machines Corporation | Anticipated containerized infrastructure used in performing cloud migration |
US11922181B2 (en) | 2021-09-14 | 2024-03-05 | International Business Machines Corporation | Configuration discovery of computer applications |
Also Published As
Publication number | Publication date |
---|---|
CN105847045B (zh) | 2019-06-18 |
CN105915378A (zh) | 2016-08-31 |
CN105915378B (zh) | 2019-03-29 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN105847045A (zh) | 一种基于Docker容器的应用封装系统及管理方法 | |
AU2017203762B2 (en) | System architecture for cloud-platform infrastructure layouts | |
CN104618433B (zh) | 一种基于eca规则的服务组合方法 | |
US10304348B2 (en) | System, method and computer program product for packing | |
US20220191168A1 (en) | Cloud infrastructure resource information scanning | |
CN106487912A (zh) | 多服务应用的管理与发布方法及装置 | |
CN107579931A (zh) | 一种基于Kubernetes的区块链即服务资源适配方法 | |
CN108255497A (zh) | 一种应用的部署方法及装置 | |
CN107209686A (zh) | 网络功能虚拟化管理和编排方法、设备和程序 | |
CN107395762A (zh) | 一种基于Docker容器的应用服务访问系统及方法 | |
CN111427677B (zh) | 人工智能产品的生成方法、装置和服务器 | |
CN101005681A (zh) | 界面自动生成方法和界面自动生成系统 | |
WO2008033394A2 (en) | Complexity management tool | |
CN104281441B (zh) | 基于mvc的数据提取方法及装置 | |
Moscato et al. | An Ontology for the Cloud in mOSAIC | |
CN111427631A (zh) | 一种多样化移动应用功能模块的动态配置方法 | |
CN109343858A (zh) | 一种基于服务端渲染的自动建站容器部署系统及其工作方法 | |
CA2902454C (en) | Workflow generation for cloud-platform infrastructure layouts | |
CN104714825A (zh) | 统一策略配置的方法 | |
CN105913198A (zh) | 用于智能港的物理实体类模型构建模块、智能港及智能网 | |
CN108459842A (zh) | 一种模型配置方法、装置及电子设备 | |
CN107632783A (zh) | 将分布式存储系统接入容器的方法、装置、可读存储介质 | |
US9189544B2 (en) | Graphically representing tags in a networked computing environment | |
Zhang et al. | Process platform representation based on unified modelling language | |
CN109542879A (zh) | 一种基于动态数据模板管理数据的方法与装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | 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 |