面試官:你知道 Docker 有哪些優缺點嘛?

來自:CSDN(作者:肥叔菌)

原文鏈接:

https://blog.csdn.net/asmartkiller/article/details/105983883

Docker解決的問題

由於不同的機器有不同的操作系統,以及不同的庫和組件,在將一個應用部署到多臺機器上需要進行大量的環境配置操作。

Docker 主要解決環境配置問題,它是一種虛擬化技術,對進程進行隔離,被隔離的進程獨立於宿主操作系統和其它隔離的進程。使用 Docker 可以不修改應用程序代碼,不需要開發人員學習特定環境下的技術,就能夠將現有的應用程序部署在其它機器上。

與虛擬機的比較

虛擬機也是一種虛擬化技術,它與 Docker 最大的區別在於它是通過模擬硬件,並在硬件上安裝操作系統來實現。

啓動速度

啓動虛擬機需要先啓動虛擬機的操作系統,再啓動應用,這個過程非常慢;而啓動 Docker 相當於啓動宿主操作系統上的一個進程。

佔用資源

虛擬機是一個完整的操作系統,需要佔用大量的磁盤、內存和 CPU 資源,一臺機器只能開啓幾十個的虛擬機。而 Docker 只是一個進程,只需要將應用以及相關的組件打包,在運行時佔用很少的資源,一臺機器可以開啓成千上萬個 Docker。

鏡像與容器

鏡像是一種靜態的結構,可以看成面向對象裏面的類,而容器是鏡像的一個實例。鏡像包含着容器運行時所需要的代碼以及其它組件,它是一種分層結構,每一層都是隻讀的(read-only layers)。構建鏡像時,會一層一層構建,前一層是後一層的基礎。鏡像的這種分層存儲結構很適合鏡像的複用以及定製。構建容器時,通過在鏡像的基礎上添加一個可寫層(writable layer),用來保存着容器運行過程中的修改。

優缺點

1. 部署方便

你一定還有印象,在我們最開始學習編程的時候,搭建環境這一步往往會耗費我們好幾個小時的時間,而且其中一個小問題可能需要找很久才能夠解決。你還會得到關於環境搭建方面的團隊其他成員的求助。而有了容器之後,這些都變得非常容易,你的開發環境就只是一個或者幾個容器鏡像的地址,最多再需要一個控制部署流程的執行腳本。或者進一步將你的環境鏡像以及鏡像腳本放入一個git項目,發佈到雲端,需要的時候將它拉到本地就可以了。

# git clone https://github.com/my-project

# sh ./my-build-boot.sh

目前我們團隊目前基本都是用這種方案搭建本地開發環境,而且整理成內部技術文檔,慢慢沉澱成團隊的財富了。

2. 部署安全

當我們收到一個bug反饋的時候,很多時候心裏面的第一反應一定是“我本地是好的啊”!這種情況的發生就在於環境的不一致,我們在開發過程中的調試往往不能保證其他環境的問題,但是我們卻要爲此買單,這真是一件令人苦惱的事情。有了容器之後,這將很少發生。我們可以通過容器技術將開發環境和測試環境以及生產環境保持版本和依賴上的統一,保證代碼在一個高度統一的環境上執行。而測試環境的統一,也同樣能解決CI流程對環境的要求。

分佈式技術和擴容需求日益增長的今天,如果運維能夠使用容器技術來進行環境的部署,不僅僅在部署時間上節省不少,也能把很多因爲人工配置環境產生的失誤降到最低。

3. 隔離性好

不管是開發還是生產,往往我們一臺機器上可能需要跑多個服務,而服務各自需要的依賴配置不盡相同,假如說兩個應用需要使用同一個依賴,或者兩個應用需要的依賴之間會有一些衝突,這個時候就很容易出現問題了。所以同一臺服務器上不同應用提供的不同服務,最好還是將其隔離起來。而容器在這方面有天生的優勢,每一個容器就是一個隔離的環境,你對容器內部提供服務的要求,容器可以自依賴的全部提供。這種高內聚的表現可以實現快速的分離有問題的服務,在一些複雜系統中能實現快速排錯和及時處理。(當然需要說明的是,這個隔離性只是相對於服務器比較的,虛機技術要擁有更好的隔離性)

4. 快速回滾

容器之前的回滾機制,一般需要基於上個版本的應用重新部署,且替換掉目前的問題版本。在最初的時代,可能是一套完整的開發到部署的流程,而執行這一套流程往往需要很長的時間。在基於git的環境中,可能是回退某個歷史提交,然後重新部署。這些跟容器技術相比都不夠快,而且可能會引起新的問題(因爲是基於新版本的修改)。而容器技術天生帶有回滾屬性,因爲每個歷史容器或者鏡像都會有保存,而替換一個容器或者某個歷史鏡像是非常快速和簡單的。

5. 成本低

這可能是一個最明顯和有用的優點了,在容器出現之前,我們往往構築一個應用就需要一臺新的服務器或者一臺虛機。服務器的購置成本和運維成本都很高,而虛機需要佔用很多不必要的資源。相比之下,容器技術就小巧輕便的多,只需要給一個容器內部構建應用需要的依賴就可以了,這也是容器技術發展迅速的最主要原因。

6. 管理成本更低

隨着容器技術的不斷普及和發展,隨之而來的容器管理和編排技術也同樣得到發展。諸如Docker Swarm,Kubernetes, Mesos等編排工具也在不斷的迭代更新,這讓容器技術在生產環境中擁有了更多的可能性和更大的發揮空間。而隨着大環境的發展,docker等容器的使用和學習的成本也是愈發降低,成爲更多開發者和企業的選擇。

說了這麼多的優點,容器也有一些問題是沒有解決的。上一代方案基本就是基於虛機技術的雲方案,能有效增加服務器的使用效率,達到節省成本的目的,而容器技術在此基礎上更進一步地優化了資源的使用率。但是仍然有一些問題,是我們在選擇服務資源架構場景中需要考慮的:

1.隔離性

基於 hypervisor 的虛機技術,在隔離性上比容器技術要更好,它們的系統硬件資源完全是虛擬化的,當一臺虛機出現系統級別的問題,往往不會蔓延到同一宿主機上的其他虛機。但是容器就不一樣了,容器之間共享同一個操作系統內核以及其他組件,所以在收到攻擊之類的情況發生時,更容易通過底層操作系統影響到其他容器。當然,這個問題可以通過在虛機中部署容器來解決,可是這樣又會引出新的問題,比如成本的增加以及下面要提到的問題:性能。

2. 性能

不管是虛機還是容器,都是運用不同的技術,對應用本身進行了一定程度的封裝和隔離,在降低應用和應用之間以及應用和環境之間的耦合性上做了很多努力,但是隨機而來的,就會產生更多的網絡連接轉發以及數據交互,這在低併發系統上表現不會太明顯,而且往往不會成爲一個應用的瓶頸(可能會分散於不同的虛機或者服務器上),但是當同一虛機或者服務器下面的容器需要更高併發量支撐的時候,也就是併發問題成爲應用瓶頸的時候,容器會將這個問題放大,所以,並不是所有的應用場景都是適用於容器技術的。

3. 存儲方案

容器的誕生並不是爲OS抽象服務的,這是它和虛機最大的區別,這樣的基因意味着容器天生是爲應用環境做更多的努力,容器的伸縮也是基於容器的這一disposable特性,而與之相對的,需要持久化存儲方案恰恰相反。這一點docker容器提供的解決方案是利用volume接口形成數據的映射和轉移,以實現數據持久化的目的。但是這樣同樣也會造成一部分資源的浪費和更多交互的發生,不管是映射到宿主機上還是到網絡磁盤,都是退而求其次的解決方案。

隨着硬件技術和網絡技術的迭代發展,容器技術的缺點會變得越來越不那麼明顯,而且隨着容器技術的發展和普及,對應的解決方案也會越來越多。所以總體來看,docker等容器技術會朝着更加普及的趨勢走近我們技術領域。也希望每一位熱愛技術的小夥伴們能更加了解這些新技術,讓它們能夠更好的爲我們服務。

推薦閱讀:

喜歡我可以給我設爲星標哦

好文章,我 在看 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章