本篇內(nèi)容介紹了“Docker能干什么”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!
創(chuàng)新互聯(lián)服務(wù)項目包括什邡網(wǎng)站建設(shè)、什邡網(wǎng)站制作、什邡網(wǎng)頁制作以及什邡網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,什邡網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到什邡省份的部分城市,未來相信會繼續(xù)擴大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
打開翻譯君輸入Docker 結(jié)果顯示碼頭工人,沒錯!碼頭工人搬運的是集裝箱,那么今天要講的Docker其操作的也是集裝箱,這個集裝箱就靜態(tài)而言就是一個應(yīng)用鏡像文件,就動態(tài)而言,就是一個容器。蒙了吧?好吧,上圖解釋。
Docker從狹義上來講就是一個進程,從廣義上來講是一個虛擬容器,其實更專業(yè)的叫法是應(yīng)用容器( Application Container ),Docker進程和普通的進程沒有任何區(qū)別,它就是一個普通的應(yīng)用進程。不過是用來操作鏡像文件的。所以Docker進程+構(gòu)建的應(yīng)用鏡像文件就等于Docker容器。本文所有講的Docker都是指Docker容器哦。
再繼續(xù)下文之前我們首先要明確幾個docker重要的基本概念吧,鏡像,容器,倉庫。
鏡像Docker images,就類似于VM虛擬機里面的快照,但是可比快照輕量化多了??煺詹欢磕强梢园裪mages直接理解成一個文件夾。我們可以通過ID或者易識別的名字+tag來確認唯一的目標鏡像。ImagesID是一個64位的字符,但是一般我們都是使用前面12位就足夠區(qū)別了。
容器Docker containers,你可以從鏡像中創(chuàng)建容器,這如同從快照中創(chuàng)建虛擬機,不過更輕量,啟動更快,秒啟。應(yīng)用是在容器中運行的,打個比方,你首先下載了一個Ubuntu的鏡像,然后又安裝MySQL和Django應(yīng)用及其依賴,來完成對它Ubutun鏡像的修改,一個個人覺得非常完美應(yīng)用鏡像生成了!就把這個鏡像分享給大家使用,大家通過這個鏡像就生成一個容器。容器啟動之后就會運行Django服務(wù)了。
倉庫Docker registeries,docker倉庫和存放集裝箱的倉庫是一樣的,不過docker使用來存放鏡像的。倉庫存在公有和私有之分,公有倉庫docker hub提供了非常多的鏡像文件,這些鏡像直接拉取下來就可以運行了,你也可以上傳自己的鏡像到docker hub上面。同時也可以自己搭建私有倉庫用于團隊項目管理。
結(jié)合前面介紹的基本概念,我們可以將docker的幾個概念使用大致串起來,他們之間是如何運作的,也就是Docker的生命周期??聪聢D,主要是三步走。
我們來看一下二者的區(qū)別,因為 VM 的 Hypervisor 需要實現(xiàn)對硬件的虛擬化,并且還要搭載自己的操作系統(tǒng),其中虛擬機操作系統(tǒng)占用內(nèi)存是比較大的,一個操作系統(tǒng)有好幾個G,自然在啟動速度和資源利用率以及性能上有非常大的開銷,如果在本地,或者個人電腦,那么影響還不是那么大,但是在云端就是一個非常大的資源浪費。
咱們很多時候做事情的時候不會考慮與事情本身無關(guān)的問題,比如造飛機的不會考慮飛機是否要潛水,對于我們目前很多移動互聯(lián)網(wǎng)的應(yīng)用來說,很少會涉及到對操作系統(tǒng)的部分,其實我們主要關(guān)心的是應(yīng)用的本身,而VM虛擬機的上層是運行的運行時庫和應(yīng)用,整個虛擬機的空間是非常的龐大,但是容器化技術(shù)Docker技術(shù)的出現(xiàn)后,省去了操作系統(tǒng)這一層,多個容器之間相互隔離且共用了宿主操作系統(tǒng)和運行時庫。
所以Docker 應(yīng)用容器相對于 VM 有以下幾個優(yōu)點:
啟動速度快,容器啟動本質(zhì)就是一個開啟一個進程而已,因此都是秒啟,而 VM 通常要更久。
資源利用率高,一臺普通 PC 可以跑成百上千個容器,你跑十個 VM 試試。
性能開銷小, VM 通常需要額外的 CPU 和內(nèi)存來完成 OS 的功能,這一部分占據(jù)了額外的資源。
所以很多移動互聯(lián)網(wǎng)的應(yīng)用或者云計算的后端節(jié)點都可以用docker來替換物理機器或者虛擬機。比如騰訊地圖的很多后臺服務(wù)基本上都遷移docker部署了。
前面說了那么多,始終還是霧里看花。下面就詳細介紹一下技術(shù)架構(gòu),底層又是用的啥技術(shù)來實現(xiàn)上述那么多優(yōu)點的?
Docker技術(shù)架構(gòu)圖:
通過腳本的方式安裝docker,非常簡單。
nicktang@nicktang-virtual-machine:~$ wget -qO- https://get.docker.com/ | sh
能夠看見版本號,說明docker的安裝成功。簡單吧!至此就差一個鏡像了。自己制作還是從公共倉庫拉取就隨你啦。
root@nicktang-virtual-machine:/data # sudo service docker stop #關(guān)閉守護進程
Docker的使用,我們主要從【增刪查】幾方面來說說怎么使用docker,為什么沒有【改】呢,因為在我看來docker容器一旦出現(xiàn)問題了,根本沒有修復(fù)的必要,直接把容器停止并刪除,再啟動,這樣來得快。所以我們只需要掌握幾個基本命令即可,具體如下。
【查】查看本地已有的鏡像 Docker images
再用docker images查看的時候本地就增加了centos鏡像。
第一個字段就是已經(jīng)啟動的容器ID,第二個字段就是這個容器是根據(jù)哪個鏡像生成的。但是上面這個命令只是臨時啟動一下容器,上面圖中的status 是exited(0),表示容器是退出狀態(tài)。如果想容器在后臺運行,所以我們需要啟動守護式容器才可以,只要在啟動命令中添加一個 -d參數(shù),即docker run -d centos就可以了。
【查】查看鏡像/容器的具體信息 docker inspect鏡像ID(鏡像名)/容器ID(容器名) docker inspect centos
這個命令是返回一個鏡像或者容器詳細信息的json串。其中包括ID,ip,版本,容器的主程序等非常多的信息,根據(jù)這些信息我們可以進行二次開發(fā)。在這個命令的基礎(chǔ)之上增加一個-f參數(shù)我們可以指定獲取自己需要的信息,比如獲取redis容器的IP地址,內(nèi)存信息,CPU使用情況。docker inspect -f '{{.NetworkSettings.IPAddress}}' [ID /Name]
查看容器目錄結(jié)構(gòu),發(fā)現(xiàn)和物理機器的目錄結(jié)構(gòu)完全一致,這就是為什么有的人稱docker容器也稱之為虛擬機的原因啦。Exit可以退出容器終端。
這年頭見面不聊點自動化什么的,持續(xù)什么的,都不好意思。所以,咱們也要了解一下持續(xù)集成,自動交付,自動部署。但是上面說了這么多,沒發(fā)現(xiàn)Docker有那三樣功能啊,是的,Docker是沒有這個功能,但是你在完成上述三樣自動化的步驟都是依賴Docker的。Docker是這些流程實現(xiàn)的基礎(chǔ),就如同軟件開發(fā),軟件代碼才是根本,開發(fā)工具是輔助。所有搭建一個完整的自動化流程還需要github+jenkins+ registry三樣幫助。
持續(xù)集成和自動部署的原理如下圖所示:
RD推送代碼到git 倉庫或者svn等代碼服務(wù)器上面,git服務(wù)器就會通過hook通知jenkins。
jenkine 克隆git代碼到本地,并通過dockerFile文件進行編譯 。
打包生成一個新版本的鏡像并推送到倉庫 ,刪除當前容器 ,通過新版本鏡像重新運行。
而在整個過程中 RD只需要敲入三個命令Git add * ;Git commit –m “”;Git push即可完成持續(xù)集成、自動交付、自動部署。后面通過案例實際演示這個過程的神奇!
Docker還可以很方便的自動擴容哦,一般的自動擴容的兩種方式,一種就是docker容量擴大,另一種就是docker節(jié)點數(shù)擴充。第一種就修改配置文件即可,第二種通過簡單的拷貝,運行就完成了節(jié)點的擴容。
“Docker能干什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!