[發明專利]一種創建DOCKER容器的方法、裝置和系統有效
| 申請號: | 201710800252.6 | 申請日: | 2017-09-07 |
| 公開(公告)號: | CN107590033B | 公開(公告)日: | 2021-06-22 |
| 發明(設計)人: | 許鵬耀;陳進賢 | 申請(專利權)人: | 網宿科技股份有限公司 |
| 主分類號: | G06F11/20 | 分類號: | G06F11/20 |
| 代理公司: | 北京華智則銘知識產權代理有限公司 11573 | 代理人: | 田建濤 |
| 地址: | 200030 上海市徐匯區*** | 國省代碼: | 上海;31 |
| 權利要求書: | 查看更多 | 說明書: | 查看更多 |
| 摘要: | |||
| 搜索關鍵詞: | 一種 創建 docker 容器 方法 裝置 系統 | ||
1.一種創建DOCKER容器的方法,其特征在于,所述方法包括:
當檢測到目標DOCKER容器出現故障時,確定所述目標DOCKER容器對應的目標RBD,其中,所述目標RBD存儲有所述目標DOCKER容器的讀寫層數據;
按照預設的調度算法選擇目標節點;
將所述目標DOCKER容器的容器標識和所述目標RBD的RBD標識發送給所述目標節點,以使所述目標節點:
根據所述容器標識判斷本地是否存儲有所述目標DOCKER容器的只讀層鏡像,若存在,則從本地獲取所述目標DOCKER容器的只讀層鏡像,若不存在,則從DOCKER鏡像庫中獲取所述目標DOCKER容器的只讀層鏡像,并根據所述RBD標識從RBD存儲集群中查找所述目標RBD,其中,所述只讀層鏡像為創建一個DOCKER容器所需的初始系統文件,對DOCKER容器的修改操作均存儲在DOCKER容器對應的RBD中;
根據所述目標DOCKER容器的只讀層鏡像和所述目標RBD,在本地創建新的DOCKER容器,將所述目標RBD作為所述新的DOCKER容器的讀寫層。
2.根據權利要求1所述的方法,其特征在于,所述方法還包括:
當檢測到所述目標DOCKER容器的創建觸發事件時,確定所述目標DOCKER容器對應的待部署節點;
生成所述目標DOCKER容器的配置文件,所述配置文件至少包括所述目標DOCKER容器的鏡像標識、網絡配置信息和內存占用量;
將所述目標DOCKER容器的配置文件發送至所述待部署節點,以使所述待部署節點根據所述配置文件創建所述目標DOCKER容器。
3.根據權利要求2所述的方法,其特征在于,所述生成所述目標DOCKER容器的配置文件之后,還包括:
如果所述目標DOCKER容器滿足RBD創建需求,則在RBD存儲集群中創建所述目標RBD,并將所述目標RBD的RBD標識寫入所述配置文件。
4.一種創建DOCKER容器的方法,其特征在于,所述方法包括:
接收調度設備發送的目標DOCKER容器的容器標識和目標RBD的RBD標識;
根據所述容器標識判斷本地是否存儲有所述目標DOCKER容器的只讀層鏡像,若存在,則從本地獲取所述目標DOCKER容器的只讀層鏡像,若不存在,則從DOCKER鏡像庫中獲取所述目標DOCKER容器的只讀層鏡像,并根據所述RBD標識從RBD存儲集群中查找所述目標RBD,其中,所述目標RBD存儲有所述目標DOCKER容器的讀寫層數據,所述只讀層鏡像為創建一個DOCKER容器所需的初始系統文件,對DOCKER容器的修改操作均存儲在DOCKER容器對應的RBD中;
根據所述目標DOCKER容器的只讀層鏡像和所述目標RBD,在本地創建新的DOCKER容器,將所述目標RBD作為所述新的DOCKER容器的讀寫層。
5.根據權利要求4所述的方法,其特征在于,所述根據所述目標DOCKER容器的只讀層鏡像和所述目標RBD,在本地創建新的DOCKER容器,包括:
創建目標掛載目錄,將所述目標DOCKER容器的只讀層鏡像掛載至所述目標掛載目錄;
創建讀寫層目錄,并將所述讀寫層目錄掛載至所述目標掛載目錄;
將所述目標RBD映射至本地,生成RBD設備目錄,將所述RBD設備目錄掛載至所述目標掛載目錄;
基于進行掛載處理后的目標掛載目錄,在本地創建新的DOCKER容器。
6.根據權利要求4所述的方法,其特征在于,所述方法還包括:
如果所述目標RBD的RBD標識為空,或者所述目標RBD不存在,則根據所述目標DOCKER容器的只讀層鏡像,在本地創建新的DOCKER容器。
該專利技術資料僅供研究查看技術是否侵權等信息,商用須獲得專利權人授權。該專利全部權利屬于網宿科技股份有限公司,未經網宿科技股份有限公司許可,擅自商用是侵權行為。如果您想購買此專利、獲得商業授權和技術合作,請聯系【客服】
本文鏈接:http://www.szxzyx.cn/pat/books/201710800252.6/1.html,轉載請聲明來源鉆瓜專利網。





