91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

容器和虛擬機(jī)具有相似的資源隔離和分配方式

Q4MP_gh_c472c21 ? 來(lái)源:華為云社區(qū) ? 作者:yixiaoer ? 2020-11-16 15:36 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

容器技術(shù)起源于Linux,是一種內(nèi)核虛擬化技術(shù),提供輕量級(jí)的虛擬化,以便隔離進(jìn)程和資源。盡管容器技術(shù)已經(jīng)出現(xiàn)很久,卻是隨著Docker的出現(xiàn)而變得廣為人知。Docker是第一個(gè)使容器能在不同機(jī)器之間移植的系統(tǒng)。它不僅簡(jiǎn)化了打包應(yīng)用的流程,也簡(jiǎn)化了打包應(yīng)用的庫(kù)和依賴,甚至整個(gè)操作系統(tǒng)的文件系統(tǒng)能被打包成一個(gè)簡(jiǎn)單的可移植的包,這個(gè)包可以被用來(lái)在任何其他運(yùn)行Docker的機(jī)器上使用。

容器和虛擬機(jī)具有相似的資源隔離和分配方式,容器虛擬化了操作系統(tǒng)而不是硬件,更加便攜和高效。

圖1 容器 vs 虛擬機(jī)

相比于使用虛擬機(jī),容器有如下優(yōu)點(diǎn):

更高效的利用系統(tǒng)資源

由于容器不需要進(jìn)行硬件虛擬以及運(yùn)行完整操作系統(tǒng)等額外開銷,容器對(duì)系統(tǒng)資源的利用率更高。無(wú)論是應(yīng)用執(zhí)行速度、內(nèi)存損耗或者文件存儲(chǔ)速度,都要比傳統(tǒng)虛擬機(jī)技術(shù)更高效。因此,相比虛擬機(jī)技術(shù),一個(gè)相同配置的主機(jī),往往可以運(yùn)行更多數(shù)量的應(yīng)用。

更快速的啟動(dòng)時(shí)間

傳統(tǒng)的虛擬機(jī)技術(shù)啟動(dòng)應(yīng)用服務(wù)往往需要數(shù)分鐘,而Docker容器應(yīng)用,由于直接運(yùn)行于宿主內(nèi)核,無(wú)需啟動(dòng)完整的操作系統(tǒng),因此可以做到秒級(jí)、甚至毫秒級(jí)的啟動(dòng)時(shí)間,大大節(jié)約了開發(fā)、測(cè)試、部署的時(shí)間。

一致的運(yùn)行環(huán)境

開發(fā)過程中一個(gè)常見的問題是環(huán)境一致性問題。由于開發(fā)環(huán)境、測(cè)試環(huán)境、生產(chǎn)環(huán)境不一致,導(dǎo)致有些問題并未在開發(fā)過程中被發(fā)現(xiàn)。而Docker的鏡像提供了除內(nèi)核外完整的運(yùn)行時(shí)環(huán)境,確保了應(yīng)用運(yùn)行環(huán)境一致性。

更輕松的遷移

由于Docker確保了執(zhí)行環(huán)境的一致性,使得應(yīng)用的遷移更加容易。Docker可以在很多平臺(tái)上運(yùn)行,無(wú)論是物理機(jī)、虛擬機(jī),其運(yùn)行結(jié)果是一致的。因此可以很輕易的將在一個(gè)平臺(tái)上運(yùn)行的應(yīng)用,遷移到另一個(gè)平臺(tái)上,而不用擔(dān)心運(yùn)行環(huán)境的變化導(dǎo)致應(yīng)用無(wú)法正常運(yùn)行的情況。

更輕松的維護(hù)和擴(kuò)展

Docker使用的分層存儲(chǔ)以及鏡像的技術(shù),使得應(yīng)用重復(fù)部分的復(fù)用更為容易,也使得應(yīng)用的維護(hù)更新更加簡(jiǎn)單,基于基礎(chǔ)鏡像進(jìn)一步擴(kuò)展鏡像也變得非常簡(jiǎn)單。此外,Docker團(tuán)隊(duì)同各個(gè)開源項(xiàng)目團(tuán)隊(duì)一起維護(hù)了大批高質(zhì)量的官方鏡像,既可以直接在生產(chǎn)環(huán)境使用,又可以作為基礎(chǔ)進(jìn)一步定制,大大的降低了應(yīng)用服務(wù)的鏡像制作成本。

Docker容器典型使用流程…

Docker容器有如下三個(gè)主要概念:

鏡像:

Docker鏡像里包含了已打包的應(yīng)用程序及其所依賴的環(huán)境。它包含應(yīng)用程序可用的文件系統(tǒng)和其他元數(shù)據(jù),如鏡像運(yùn)行時(shí)的可執(zhí)行文件路徑。

鏡像倉(cāng)庫(kù):

Docker鏡像倉(cāng)庫(kù)用于存放Docker鏡像,以及促進(jìn)不同人和不同電腦之間共享這些鏡像。當(dāng)編譯鏡像時(shí),要么可以在編譯它的電腦上運(yùn)行,要么可以先上傳鏡像到一個(gè)鏡像倉(cāng)庫(kù),然后下載到另外一臺(tái)電腦上并運(yùn)行它。某些倉(cāng)庫(kù)是公開的,允許所有人從中拉取鏡像,同時(shí)也有一些是私有的,僅部分人和機(jī)器可接入。

容器:

Docker容器通常是一個(gè)Linux容器,它基于Docker鏡像被創(chuàng)建。一個(gè)運(yùn)行中的容器是一個(gè)運(yùn)行在Docker主機(jī)上的進(jìn)程,但它和主機(jī),以及所有運(yùn)行在主機(jī)上的其他進(jìn)程都是隔離的。這個(gè)進(jìn)程也是資源受限的,意味著它只能訪問和使用分配給它的資源(CPU、內(nèi)存等)。

典型的使用流程如圖2所示:

圖2 Docker容器典型使用流程

(1)首先開發(fā)者在開發(fā)環(huán)境機(jī)器上開發(fā)應(yīng)用并制作鏡像。

Docker執(zhí)行命令,構(gòu)建鏡像并存儲(chǔ)在機(jī)器上。

(2)開發(fā)者發(fā)送上傳鏡像命令。

Docker收到命令后,將本地鏡像上傳到鏡像倉(cāng)庫(kù)。

(3)開發(fā)者向生產(chǎn)環(huán)境機(jī)器發(fā)送運(yùn)行鏡像命令。

生產(chǎn)環(huán)境機(jī)器收到命令后,Docker會(huì)從鏡像倉(cāng)庫(kù)拉取鏡像到機(jī)器上,然后基于鏡像運(yùn)行容器。

使用示例…

下面使用Docker將基于Nginx鏡像打包一個(gè)容器鏡像,并基于容器鏡像運(yùn)行應(yīng)用,然后推送到容器鏡像倉(cāng)庫(kù)。

安裝Docker

Docker幾乎支持在所有操作系統(tǒng)上安裝,用戶可以根據(jù)需要選擇要安裝的Docker版本。在Linux操作系統(tǒng)下,可以使用如下命令快速安裝Docker。

curl -fsSL get.docker.com -o get-docker.shsh get-docker.sh

說(shuō)明:CentOS 8.0操作系統(tǒng)使用上述腳本安裝Docker會(huì)出現(xiàn)問題,建議使用如下命令安裝較低版本Docker。

wget -O /etc/yum.repos.d/docker-ce.repo https://repo.huaweicloud.com/docker-ce/linux/centos/docker-ce.repo sudosed -i 's+download.docker.com+repo.huaweicloud.com/docker-ce+' /etc/yum.repos.d/docker-ce.repoyum install docker-ce-18.06.3.ce -ysystemctl restart docker

Docker打包鏡像…

Docker提供了一種便捷的描述應(yīng)用打包的方式,叫做Dockerfile,如下所示:

# 使用官方提供的Nginx鏡像作為基礎(chǔ)鏡像FROM nginx:alpine# 執(zhí)行一條命令修改Nginx鏡像index.html的內(nèi)容RUN echo "hello world" > /usr/share/nginx/html/index.html# 允許外界訪問容器的80端口EXPOSE 80

執(zhí)行docker build命令打包鏡像。

docker build -t hello .其中-t表示給鏡像加一個(gè)標(biāo)簽,也就是給鏡像取名,這里鏡像名為hello。. 表示在當(dāng)前目錄下執(zhí)行該打包命令。

執(zhí)行docker images命令查看鏡像,可以看到hello鏡像已經(jīng)創(chuàng)建成功。您還可以看到一個(gè)Nginx鏡像,這個(gè)鏡像是從鏡像倉(cāng)庫(kù)下載下來(lái)的,作為hello鏡像的基礎(chǔ)鏡像使用。

# docker imagesREPOSITORY TAG IMAGE ID CREATED SIZEhello latest d120ec16dcea 17 minutes ago 158MBnginx alpine eeb27ee6b893 2 months ago 148MB

本地運(yùn)行容器鏡像…

有了鏡像后,您可以在本地執(zhí)行docker run命令運(yùn)行容器鏡像。

# docker run -p 8080:80 hellodocker run命令會(huì)啟動(dòng)一個(gè)容器,命令中-p是將本地機(jī)器的8080端口映射到容器的80端口,即本地機(jī)器的8080端口的流量會(huì)映射到容器的80端口,當(dāng)您在本地機(jī)器訪問 http://127.0.0.1:8080時(shí),就會(huì)訪問到容器中,此時(shí)瀏覽器中返回的內(nèi)容應(yīng)該就是“hello world”。

把鏡像推送到鏡像倉(cāng)庫(kù)

華為云提供了容器鏡像服務(wù)SWR,您也可以將鏡像上傳到SWR,下面我們以華為云為例,演示如何將鏡像推送到SWR。

首先登錄SWR控制臺(tái),在左側(cè)選擇“我的鏡像”,然后單擊右側(cè)“客戶端上傳鏡像”,在彈出的窗口中單擊“生成臨時(shí)登錄指令”,然后復(fù)制該指令在本地機(jī)器上執(zhí)行,登錄到SWR鏡像倉(cāng)庫(kù)。

上傳鏡像前需要給鏡像取一個(gè)完整的名稱,如下所示:

# docker tag hello swr.cn-east-3.myhuaweicloud.com/container/hello:v1

詳細(xì)解析如下:

swr.cn-east-3.myhuaweicloud.com是倉(cāng)庫(kù)地址,每個(gè)華為云區(qū)域的地址不同。

container是組織名,組織一般在SWR中創(chuàng)建,如果沒有創(chuàng)建則首次上傳的時(shí)候會(huì)自動(dòng)創(chuàng)建,組織名在單個(gè)區(qū)域內(nèi)全局唯一,需要選擇合適的組織名稱。

v1則是hello鏡像分配的版本號(hào)。

然后執(zhí)行docker push命令就可以將鏡像上傳到SWR。

# docker push swr.cn-east-3.myhuaweicloud.com/container/hello:v1當(dāng)需要使用該鏡像時(shí),使用docker pull命令拉?。ㄏ螺d)該命令即可。

# docker pull swr.cn-east-3.myhuaweicloud.com/container/hello:v1

責(zé)任編輯:lq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 容器
    +關(guān)注

    關(guān)注

    0

    文章

    532

    瀏覽量

    22972
  • 虛擬機(jī)
    +關(guān)注

    關(guān)注

    1

    文章

    972

    瀏覽量

    30509
  • Docker
    +關(guān)注

    關(guān)注

    0

    文章

    532

    瀏覽量

    14270

原文標(biāo)題:容器、Docker、虛擬機(jī),別再傻傻分不清!(建議收藏)

文章出處:【微信號(hào):gh_c472c2199c88,微信公眾號(hào):嵌入式微處理器】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    企業(yè)級(jí)KVM虛擬化平臺(tái)搭建實(shí)戰(zhàn)

    的出現(xiàn)徹底改變了這一局面,通過在單臺(tái)物理機(jī)上運(yùn)行多個(gè)虛擬機(jī),將資源利用率提升至60%以上,同時(shí)實(shí)現(xiàn)了分鐘級(jí)的虛擬機(jī)創(chuàng)建和彈性伸縮。
    的頭像 發(fā)表于 03-11 09:38 ?253次閱讀

    【米爾全志T153開發(fā)板評(píng)測(cè)】虛擬機(jī)資料下載與安裝

    【前言】 米爾全志開發(fā)板在資料中提供了虛擬機(jī)的環(huán)境,這使得開發(fā)容易,這里講一下,下載好虛擬機(jī)包報(bào)進(jìn)行較驗(yàn)的經(jīng)驗(yàn)。 【緣由】 在米爾開發(fā)者中心下載到Tools后,解壓,在解壓時(shí)提示頭部有問題,因此需要
    發(fā)表于 03-10 12:29

    虛擬機(jī)數(shù)據(jù)恢復(fù)—虛擬機(jī)vmdk文件被刪除的數(shù)據(jù)恢復(fù)案例

    xxx-flat.vmdk磁盤文件和xxx-000001-delta.vmdk快照文件還在。管理員嘗試恢復(fù)時(shí),刪除了原虛擬機(jī)內(nèi)的xxx-flat.vmdk,新建了一個(gè)虛擬機(jī)分配了200GB精簡(jiǎn)模式和160GB快照數(shù)據(jù)盤,然而原
    的頭像 發(fā)表于 02-10 17:05 ?246次閱讀
    <b class='flag-5'>虛擬機(jī)</b>數(shù)據(jù)恢復(fù)—<b class='flag-5'>虛擬機(jī)</b>vmdk文件被刪除的數(shù)據(jù)恢復(fù)案例

    Arm架構(gòu)助力Azure Cobalt 100虛擬機(jī)工作負(fù)載性能提升

    自從微軟推出基于 Arm 架構(gòu)的 Azure Cobalt 100 虛擬機(jī) (VM) 以來(lái),已有眾多客戶選擇這款新實(shí)例運(yùn)行各類用例。目前,Cobalt 100 虛擬機(jī)已在全球微軟 Azure 云
    的頭像 發(fā)表于 12-15 14:42 ?675次閱讀
    Arm架構(gòu)助力Azure Cobalt 100<b class='flag-5'>虛擬機(jī)</b>工作負(fù)載性能提升

    虛擬機(jī)數(shù)據(jù)恢復(fù)—異常斷電致ESXI存儲(chǔ)失聯(lián)?這份實(shí)戰(zhàn)數(shù)據(jù)恢復(fù)案例請(qǐng)收好

    服務(wù)器存儲(chǔ)數(shù)據(jù)恢復(fù)環(huán)境: 一臺(tái)服務(wù)器上部署esxi虛擬化平臺(tái)。上層采用通過FreeNAS構(gòu)建的iSCSI方式FCSAN功能,F(xiàn)reeNAS層采用UFS2文件系統(tǒng)。 esxi虛擬化系統(tǒng)有3臺(tái)
    的頭像 發(fā)表于 11-11 14:11 ?273次閱讀

    蜂鳥e203在虛擬機(jī)unbuntu上面驗(yàn)證時(shí)報(bào)錯(cuò)的可能原因及解決措施

    內(nèi)容:蜂鳥e203在虛擬機(jī)unbuntu上面驗(yàn)證時(shí)報(bào)錯(cuò)的可能原因 現(xiàn)象: 解決措施: 蜂鳥e203在虛擬機(jī)unbuntu上面驗(yàn)證時(shí)不要重復(fù)輸入命令: make install make compile SIM=iverilog 只需輸入一遍
    發(fā)表于 10-24 08:27

    搭建自己的ubuntu系統(tǒng)之創(chuàng)建ubuntu虛擬機(jī)

    打開VMware軟件,點(diǎn)擊創(chuàng)建新的虛擬機(jī)。進(jìn)入以下界面:選擇自定義,點(diǎn)擊“下一步”。選擇對(duì)應(yīng)VMware版本的兼容性,版本可在幫助-&gt;關(guān)于VMware Workstation中
    發(fā)表于 09-25 09:39

    干貨分享 | RK3588 Ubuntu系統(tǒng)Docker容器使用指南

    前言:在瑞芯微RK3588高性能AIoT平臺(tái)上運(yùn)行Ubuntu系統(tǒng)時(shí),Docker容器技術(shù)能極大提升開發(fā)部署效率。通過輕量級(jí)虛擬化實(shí)現(xiàn)環(huán)境隔離與快速遷移,本文將從零開始詳解RK3588平臺(tái)
    的頭像 發(fā)表于 06-27 12:01 ?3912次閱讀
    干貨分享 | RK3588 Ubuntu系統(tǒng)Docker<b class='flag-5'>容器</b>使用指南

    中軟國(guó)際鴻云虛擬機(jī)安裝指南

    鴻蒙電腦作為新一代分布式計(jì)算平臺(tái),憑借其卓越的多端協(xié)同能力和智能化特性,為高效辦公提供了新選擇。針對(duì)專業(yè)軟件兼容性這一核心痛點(diǎn),中軟國(guó)際的鴻云虛擬機(jī)解決方案提供了務(wù)實(shí)的技術(shù)路徑。作為專為鴻蒙生態(tài)打造
    的頭像 發(fā)表于 06-23 16:31 ?4299次閱讀

    TECS OpenStack資源虛擬機(jī)網(wǎng)絡(luò)二層地址無(wú)法互通的問題處理

    某運(yùn)營(yíng)商TECS OpenStack使用主機(jī)overlay SDN方案組網(wǎng),運(yùn)維人員在創(chuàng)建虛擬機(jī)測(cè)試虛擬機(jī)網(wǎng)絡(luò)狀態(tài)時(shí)發(fā)現(xiàn)問題:在其中一臺(tái)主機(jī)上創(chuàng)建兩臺(tái)同網(wǎng)段虛擬機(jī),虛擬機(jī)之間二層地址無(wú)
    的頭像 發(fā)表于 06-12 09:28 ?907次閱讀
    TECS OpenStack<b class='flag-5'>資源</b>池<b class='flag-5'>虛擬機(jī)</b>網(wǎng)絡(luò)二層地址無(wú)法互通的問題處理

    LTM2893/LTM2893-1 100MHz隔離型ADC串行接口技術(shù)手冊(cè)

    :LTC2338 和相似的器件系列) 而優(yōu)化,并能夠與大多數(shù)通用型 ADC 對(duì)接。 LTM2893-1 專為隔離需要把配置設(shè)定值寫入 ADC 的 LTC2348 和相似的同時(shí)采樣 ADC 系列而優(yōu)化。 LTM2893 可
    的頭像 發(fā)表于 06-03 14:42 ?1170次閱讀
    LTM2893/LTM2893-1 100MHz<b class='flag-5'>隔離</b>型ADC串行接口技術(shù)手冊(cè)

    云電競(jìng)服務(wù)器 工作原理

    云電競(jìng)服務(wù)器工作原理詳解 一、核心架構(gòu)原理 虛擬資源池? 通過 ?KVM/VMware? 等虛擬化技術(shù)將物理服務(wù)器(含NVIDIA GPU集群)抽象為可動(dòng)態(tài)分配的算力
    的頭像 發(fā)表于 05-14 07:44 ?630次閱讀
    云電競(jìng)服務(wù)器 工作原理

    如何在Centos系統(tǒng)中部署KVM虛擬化平臺(tái)

    KVM 通過將 Linux 內(nèi)核轉(zhuǎn)換為一個(gè)裸機(jī)(bare-metal)管理程序(hypervisor),使得用戶可以在單一物理主機(jī)上運(yùn)行多個(gè)虛擬機(jī)(VM),每個(gè)虛擬機(jī)都擁有獨(dú)立的操作系統(tǒng)和資源。這樣的架構(gòu)不僅提高了硬件
    的頭像 發(fā)表于 05-09 13:40 ?939次閱讀
    如何在Centos系統(tǒng)中部署KVM<b class='flag-5'>虛擬</b>化平臺(tái)

    分布式存儲(chǔ)數(shù)據(jù)恢復(fù)—虛擬機(jī)上hbase和hive數(shù)據(jù)庫(kù)數(shù)據(jù)恢復(fù)案例

    分布式存儲(chǔ)數(shù)據(jù)恢復(fù)環(huán)境: 16臺(tái)某品牌R730xd服務(wù)器節(jié)點(diǎn),每臺(tái)服務(wù)器節(jié)點(diǎn)上有數(shù)臺(tái)虛擬機(jī)虛擬機(jī)上部署Hbase和Hive數(shù)據(jù)庫(kù)。 分布式存儲(chǔ)故障: 數(shù)據(jù)庫(kù)底層文件被誤刪除,數(shù)據(jù)庫(kù)不能使用。要求恢復(fù)hbase和hive數(shù)據(jù)庫(kù)。
    的頭像 發(fā)表于 04-17 11:05 ?741次閱讀

    Linux內(nèi)核編譯失敗?移動(dòng)硬盤和虛擬機(jī)的那些事兒

    Linux開發(fā)中,編譯內(nèi)核是一項(xiàng)常見任務(wù),但不少開發(fā)者在移動(dòng)硬盤或虛擬機(jī)環(huán)境下嘗試時(shí)會(huì)遭遇失敗。本文將簡(jiǎn)要探討這些問題的成因,并介紹一些虛擬機(jī)使用技巧,幫助大家更好地應(yīng)對(duì)相關(guān)問題。在移動(dòng)硬盤里編譯
    的頭像 發(fā)表于 04-11 11:36 ?1022次閱讀
    Linux內(nèi)核編譯失?。恳苿?dòng)硬盤和<b class='flag-5'>虛擬機(jī)</b>的那些事兒