一文了解Docker

本文轉(zhuǎn)自楊奇龍老師的公眾號(hào)(yangyidba),他長(zhǎng)期關(guān)注于數(shù)據(jù)庫(kù)技術(shù)以及性能優(yōu)化俭嘁,故障案例分析吓著,數(shù)據(jù)庫(kù)運(yùn)維技術(shù)知識(shí)分享,個(gè)人成長(zhǎng)和自我管理等主題

假期把之前買(mǎi)的幾本docker的書(shū)籍閱讀一遍歉井,本文是docker的學(xué)習(xí)筆記柿祈,了解docker的核心概念。

一 docker 是什么

Docker是dotCloud公司(后更名為Docker)基于go語(yǔ)言開(kāi)發(fā)的容器項(xiàng)目,2013年開(kāi)源躏嚎。該項(xiàng)目后來(lái)加入Linux基金會(huì)蜜自,遵從了Apache 2.0協(xié)議,項(xiàng)目代碼在GitHub上進(jìn)行維護(hù)卢佣。

二 為什么要使用Docker

Docker項(xiàng)目的目標(biāo)是實(shí)現(xiàn)輕量級(jí)的操作系統(tǒng)虛擬化解決方案重荠。用戶操作Docker的容器就像操作一個(gè)快速輕量級(jí)的虛擬機(jī)一樣簡(jiǎn)單。Docker 提出 構(gòu)建一次虚茶,到處運(yùn)行

Build once,Run anywhere,Configure once,Run anything

對(duì)比虛擬機(jī)戈鲁,Docker具有以下優(yōu)點(diǎn)

快速的部署和交付:開(kāi)發(fā)者可以使用一個(gè)標(biāo)準(zhǔn)的鏡像來(lái)構(gòu)建一套容器,開(kāi)發(fā)完成之后嘹叫,運(yùn)維人員可以直接使用這個(gè)容器來(lái)部署代碼婆殿。解決開(kāi)發(fā)環(huán)境和生產(chǎn)環(huán)境不一致帶來(lái)的一系列問(wèn)題,讓開(kāi)發(fā)人員和運(yùn)維人員可以更加和諧相處罩扇。

啟動(dòng)速度更快:秒級(jí)啟動(dòng)婆芦。

更高效的虛擬化:它是內(nèi)核級(jí)的虛擬化,因此可以實(shí)現(xiàn)更高的性能和效率喂饥。

高效的遷移:Docker可以運(yùn)行在不同的平臺(tái)消约,用戶可以輕松的將一個(gè)應(yīng)用從一個(gè)平臺(tái)遷移到另一個(gè)平臺(tái)。PS 大部分都是在Linux環(huán)境下運(yùn)行员帮,估計(jì)很少有人從linux遷移到windows平臺(tái)或粮。

節(jié)約成本:Docker容器除了運(yùn)行其中應(yīng)用外,基本不消耗額外的系統(tǒng)資源捞高,一臺(tái)設(shè)備可以運(yùn)行上千個(gè)容器氯材。

三 Docker的核心概念

Docker 是一個(gè)C/S架構(gòu)的程序,Docker客戶端向Docker的服務(wù)端(Docker daemon) 發(fā)出請(qǐng)求,服務(wù)端處理完請(qǐng)求并返回結(jié)果棠枉。

image

從上面的架構(gòu)圖上我們可以了解

Docker daemon: 運(yùn)行在宿主機(jī)上浓体,Docker的守護(hù)進(jìn)程,用戶通過(guò) docker 命令與Docker daemon交互辈讶。

Docker client: Docker命令行工具命浴,是用戶管理運(yùn)維Docker的主要方式,Docker client向Docker daemon發(fā)出請(qǐng)求贱除,Docker daemon將結(jié)果返回給用戶生闲,Docker client也可以通過(guò)socket或者RESTful api訪問(wèn)Docker daemon。

image:鏡像本質(zhì)上是一個(gè)文件系統(tǒng)及其參數(shù)配置的組合月幌。Docker 會(huì)把應(yīng)用程序及依賴打包進(jìn)鏡像里碍讯,提供了容器運(yùn)行時(shí)所需的程序、庫(kù)扯躺、資源捉兴、配置等文件外蝎困,還包含了一些為運(yùn)行時(shí)準(zhǔn)備的一些配置參數(shù)(如匿名卷、環(huán)境變量倍啥、用戶等)禾乘,通過(guò)這個(gè)鏡像文件可生成 Docker 容器。一個(gè)鏡像可以運(yùn)行一個(gè)或者多個(gè)容器虽缕,鏡像可以通過(guò)Dockerfile創(chuàng)建始藕,也可以從Docker hub/registry上下載。

container:容器是從鏡像創(chuàng)建的應(yīng)用運(yùn)行實(shí)例,啟動(dòng)一個(gè)鏡像就是一個(gè)容器氮趋,多個(gè)容器之間不會(huì)相互影響伍派,保證容器中的程序運(yùn)行在一個(gè)相對(duì)安全的環(huán)境中。

registry: 倉(cāng)庫(kù),共享和管理Docker鏡像的地方剩胁,用戶可以上傳或者下載上面的鏡像诉植,官方地址為 https://registry.hub.docker.com/,各個(gè)公司也可以搭建私有Docker registry摧冀。

鏡像就相當(dāng)于打包好的代碼倍踪,鏡像啟動(dòng)之后運(yùn)行在容器中系宫,倉(cāng)庫(kù)就是裝存儲(chǔ)鏡像的地方索昂。

從官方網(wǎng)站上拷貝另一種圖,介紹Docker Engine 緯度的架構(gòu)扩借。清晰的介紹server/client交互椒惨,容器和鏡像、數(shù)據(jù)之間的一些聯(lián)系潮罪。

image

四 動(dòng)手實(shí)踐

省略如何在系統(tǒng)上安裝docker康谆,不會(huì)的自行谷歌。

我們通過(guò)一個(gè)案例來(lái)在mac 上運(yùn)行一個(gè)redis的容器嫉到。因?yàn)楸镜貨](méi)有redis鏡像沃暗,docker會(huì)從官網(wǎng)的倉(cāng)庫(kù)拉取最新的redis鏡像下載到本地。

? ~ docker pull redis

Using  default tag: latest
latest:  Pulling  from library/redis
bc51dd8edc1b:  Pull complete
37d80eb324ee:  Pull complete
392b7748dfaf:  Pull complete
48df82c3534d:  Pull complete
2ec2bb0b4b0e:  Pull complete
1302bce0b2cb:  Pull complete
Digest: sha256:7b84b346c01e5a8d204a5bb30d4521bcc3a8535bbf90c660b8595fad248eae82
Status:  Downloaded newer image for redis:latest

查看鏡像

? ~ docker images

REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
redis               latest 44d36d2c2374  13 days ago 98.2 MB

基于下載的 redis 鏡像啟動(dòng)一個(gè)名稱為 myredis的容器實(shí)例何恶。其中 -d 表示以后臺(tái)方式啟動(dòng)孽锥, -p 端口映射 host_port:docker_port, 訪問(wèn)本機(jī)6379端口的請(qǐng)求可以發(fā)送到docker實(shí)例中的端口6379 。

?  ~ docker run --name  myredis -d -p 6379:6379 redis
85ab24b0be6894401039e51919eed653ecdd2d066cdaef1983b9660b79a09e7a
?  ~ docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                    NAMES
85ab24b0be68 redis "docker-entrypoint..."  18 hours ago Up  7 seconds 0.0.0.0:6379->6379/tcp   myredis

通過(guò)交互命令行進(jìn)入docker中细层,訪問(wèn)redis實(shí)例惜辑。

image
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市疫赎,隨后出現(xiàn)的幾起案子盛撑,更是在濱河造成了極大的恐慌,老刑警劉巖捧搞,帶你破解...
    沈念sama閱讀 211,639評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件抵卫,死亡現(xiàn)場(chǎng)離奇詭異狮荔,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)介粘,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,277評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)轴合,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人碗短,你說(shuō)我怎么就攤上這事受葛。” “怎么了偎谁?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,221評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵总滩,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我巡雨,道長(zhǎng)闰渔,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,474評(píng)論 1 283
  • 正文 為了忘掉前任铐望,我火速辦了婚禮冈涧,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘正蛙。我一直安慰自己督弓,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,570評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布乒验。 她就那樣靜靜地躺著愚隧,像睡著了一般。 火紅的嫁衣襯著肌膚如雪锻全。 梳的紋絲不亂的頭發(fā)上狂塘,一...
    開(kāi)封第一講書(shū)人閱讀 49,816評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音鳄厌,去河邊找鬼荞胡。 笑死,一個(gè)胖子當(dāng)著我的面吹牛了嚎,可吹牛的內(nèi)容都是我干的泪漂。 我是一名探鬼主播,決...
    沈念sama閱讀 38,957評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼新思,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼窖梁!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起夹囚,我...
    開(kāi)封第一講書(shū)人閱讀 37,718評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤纵刘,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后荸哟,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體假哎,經(jīng)...
    沈念sama閱讀 44,176評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡瞬捕,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,511評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了舵抹。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片肪虎。...
    茶點(diǎn)故事閱讀 38,646評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖惧蛹,靈堂內(nèi)的尸體忽然破棺而出扇救,到底是詐尸還是另有隱情,我是刑警寧澤香嗓,帶...
    沈念sama閱讀 34,322評(píng)論 4 330
  • 正文 年R本政府宣布迅腔,位于F島的核電站,受9級(jí)特大地震影響靠娱,放射性物質(zhì)發(fā)生泄漏沧烈。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,934評(píng)論 3 313
  • 文/蒙蒙 一像云、第九天 我趴在偏房一處隱蔽的房頂上張望锌雀。 院中可真熱鬧,春花似錦迅诬、人聲如沸腋逆。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,755評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)闲礼。三九已至牍汹,卻和暖如春铐维,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背慎菲。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,987評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工嫁蛇, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人露该。 一個(gè)月前我還...
    沈念sama閱讀 46,358評(píng)論 2 360
  • 正文 我出身青樓睬棚,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親解幼。 傳聞我的和親對(duì)象是個(gè)殘疾皇子抑党,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,514評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • 1. 摘要 本文是輝哥Docker入門(mén)的一些摘要和資源分享底靠,涉及DOCKER入門(mén),框架原理,鏡像制作和資源列表等內(nèi)...
    筆名輝哥閱讀 4,557評(píng)論 0 74
  • 一特铝、Docker 簡(jiǎn)介 Docker 兩個(gè)主要部件:Docker: 開(kāi)源的容器虛擬化平臺(tái)Docker Hub: 用...
    R_X閱讀 4,382評(píng)論 0 27
  • 特別說(shuō)明: 本人平時(shí)混跡于 B 站暑中,不咋回復(fù)這里的評(píng)論壹瘟,有問(wèn)題可以到 B 站視頻評(píng)論區(qū)留言找我視頻地址: http...
    擼帝閱讀 865評(píng)論 1 3
  • 1.Docker簡(jiǎn)介 1.1 什么是虛擬化 在計(jì)算機(jī)中,虛擬化(英語(yǔ):Virtualization)是一種資源管理...
    EdwinGates閱讀 1,756評(píng)論 0 0
  • 在一階進(jìn)入6.0踐行時(shí)鳄逾,我特意做了斷舍離稻轨,理由是我必須專心致志地走三階的踐行90天。這是踐行易效能兩年以來(lái)最認(rèn)真投...
    turnningF閱讀 901評(píng)論 0 10