1. 程式人生 > >三文搞懂學會Docker容器技術(上)

三文搞懂學會Docker容器技術(上)

1,Docker簡介

  1.1 Docker是什麼?

Docker官網: https://www.docker.com/

Docker 是一個開源的應用容器引擎,基於 Go 語言 並遵從Apache2.0協議開源。
Docker 可以讓開發者打包他們的應用以及依賴包到一個輕量級、可移植的容器中,然後釋出到任何流行的 Linux 機器上,也可以實現虛擬化。
容器是完全使用沙箱機制,相互之間不會有任何介面(類似 iPhone 的 app),更重要的是容器效能開銷極低。
Docker 從 17.03 版本之後分為 CE(Community Edition: 社群版) 和 EE(Enterprise Edition: 企業版),我們用社群版就可以了。

  1.2 Docker架構原理?

 

Docker三要素,映象,容器,倉庫

1.映象

Docker 映象(Image)就是一個只讀的模板,它可以是一個可執行軟體(tomcat,mysql),也可以是一個系統(centos)。映象可以用來建立 Docker 容器,一個映象可以建立很多容器。

2.容器

Docker 利用容器(Container)獨立執行的一個或一組應用。容器是用映象建立的執行例項。它可以被啟動、開始、停止、刪除。每個容器都是相互隔離的、保證安全的平臺。可以把容器看做是一個簡易版的 Linux 環境(包括root使用者許可權、程序空間、使用者空間和網路空間等)和執行在其中的應用程式。容器的定義和映象幾乎一模一樣,也是一堆層的統一視角,唯一區別在於容器的最上面那一層是可讀可寫的。

3.倉庫

倉庫(Repository)是集中存放映象檔案的場所,類似GitHub存放專案程式碼一樣,只不過Docker Hub是由來存映象(image)的。倉庫(Repository)和倉庫註冊伺服器(Registry)是有區別的。倉庫註冊伺服器上往往存放著多個倉庫,每個倉庫中又包含了多個映象,每個映象有不同的標籤(tag,類似版本號)。

倉庫分為公開倉庫(Public)和私有倉庫(Private)兩種形式。

最大的公開倉庫是 Docker Hub(https://hub.docker.com/),存放了數量龐大的映象供使用者下載。國內的公開倉庫包括阿里雲 、網易雲 等。

 

容器與映象的關係類似於面向物件程式設計中的物件與類。

Docker 面向物件
容器 物件
映象

  1.3 Docker有什麼用?

    1,簡化環境搭建,提高開發生命週期效率;

    2,大大簡化運維工作量;

    3,微服務利器;

  1.4 Docker容器與虛擬機器區別?

Docker是一種輕量級的虛擬化技術,比傳統的虛擬機器效能更好。

下圖是虛擬機器的體系結構:

 

  • server - 表示真實電腦。
  • Host OS - 真實電腦的作業系統,例如:Windows,Linux
  • Hypervisor - 虛擬機器平臺,模擬硬體,如VMWare,VirtualBox
  • Guest OS - 虛擬機器平臺上安裝的作業系統,例如CentOS Linux
  • App - 虛擬機器作業系統上的應用,例如nginx

 

下圖是Docker的體系結構:

  • server - 表示真實電腦。
  • Host OS - 真實電腦的作業系統,例如:Windows,Linux
  • Docker Engine - 新一代虛擬化技術,不需要包含單獨的作業系統。
  • App - 所有的應用程式現在都作為Docker容器執行。

 

這種體系結構的明顯優勢是,不需要為虛擬機器作業系統提供硬體模擬。所有應用程式都作為Docker容器工作,效能更好。

  Docker容器 虛擬機器(VM)
作業系統 與宿主機共享OS 宿主機OS上執行宿主機OS
儲存大小 映象小,便於儲存與傳輸 映象龐大(vmdk等)
執行效能 幾乎無額外效能損失 作業系統額外的cpu、記憶體消耗
移植性 輕便、靈活、適用於Linux 笨重、與虛擬化技術耦合度高
硬體親和性  面向軟體開發者 面向硬體運維者

 

Docker優點:輕量級,速度快,執行應用隔離,方便維護...

2,Docker安裝

  2.1 Docker版本介紹

Docker從1.13版本之後採用時間線的方式作為版本號,分為社群版CE和企業版EE。

社群版是免費提供給個人開發者和小型團體使用的,企業版會提供額外的收費服務,比如經過官方測試認證過的基礎設施、容器、外掛等。

社群版按照stable和edge兩種方式釋出,每個季度更新stable版本,如17.06,17.09;每個月份更新edge版本,如17.09,17.10。

我們平時用社群版就足夠了。所以我們安裝社群版;

  2.2 Docker安裝官方文件

我們主要參考:https://docs.docker.com/install/linux/docker-ce/centos/  來安裝;

  2.3 工具準備

前置課程:Centos課程  http://www.java1234.com/javaxuexiluxiantu.html

打包下載: http://pan.baidu.com/s/1i55jJAt

虛擬機器 VMware

centos7安裝下虛擬機器VM上;

連線工具 才用 FinalShell  官方地址:http://www.hostbuf.com/

  2.4 Docker安裝步驟

我們切換到root使用者

1、Docker 要求 CentOS 系統的核心版本高於 3.10 ,檢視本頁面的前提條件來驗證你的CentOS 版本是否支援 Docker 。

通過 uname -r 命令檢視你當前的核心版本

 $ uname -r

2、使用 root 許可權登入 Centos。確保 yum 包更新到最新。

$ yum update

3、解除安裝舊版本(如果安裝過舊版本的話)

$ yum remove docker  docker-common docker-selinux docker-engine

4、安裝需要的軟體包, yum-util 提供yum-config-manager功能,另外兩個是devicemapper驅動依賴的

$ yum install -y yum-utils device-mapper-persistent-data lvm2

5、設定yum源

$ yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo

6,安裝最新版本的Docker

$ yum install docker-ce docker-ce-cli containerd.io

7,啟動Docker並設定開機啟動

$ systemctl start docker

$ systemctl enable docker

8,驗證Docker

$ docker version

 

說明安裝OK;

9,Docker HelloWorld測試;

$ docker run hello-world

 

因為本地沒有這個映象,所以從遠端官方倉庫去拉取,下載;

然後我們再執行一次;

 

OK了

  2.5 Docker配置阿里雲映象倉庫

Docker預設遠端倉庫是 https://hub.docker.com/

比如我們下載一個大點的東西,龜速

 

由於是國外主機,類似Maven倉庫,慢得一腿,經常延遲,破損;

所以我們一般都是配置國內映象,比如阿里雲,網易雲等;推薦阿里雲,穩定點;

配置步驟如下:

1,登入進入阿里雲映象服務中心,獲取映象地址

進入阿里雲容器映象服務地址:點這裡快速進入

使用你的淘寶賬號密碼登入

 

這裡我們獲取映象地址;

2,在/etc/docker目錄下找到在daemon.json檔案(沒有就新建),將下面內容寫入

{

 "registry-mirrors": ["https://xxxxxxx.mirror.aliyuncs.com"]

}

3,重啟daemon

systemctl daemon-reload

4,重啟docker服務

systemctl restart docker

5,測試

由於速度太快,截圖都難;

 

3,HelloWorld執行原理

執行  docker run hello-world

本地倉庫未能找到該映象,然後去遠端倉庫尋找以及下載該映象;

然後我們再執行該命令:

出來了 Hellowold。我們具體來分析下 執行原理和過程;

從左到右 client客戶端,Docker執行主機,遠端倉庫;

docker build ,pull,run分別是 構建,拉取,執行命令,後面再細講;

中間Docker主機裡有 Docker daemon主執行執行緒,以及Containers容器,容器裡可以執行很多例項,(例項是從右側Images映象例項化出來的)Images是儲存再本地的映象檔案,比如 Redis,Tomat這些映象檔案;

右側是Registry映象倉庫,預設遠端映象倉庫 https://hub.docker.com/  不過是國外主機,下載很慢,不穩定,所以我們後面要配置成阿里雲倉庫映象地址,穩定快捷;

執行 docker run hello-world的過程看如下圖例:

 

 

 

4,Docker基本命令

   4.1 啟動Docker

           systemctl start docker

  4.2 停止Docker

         systemctl stop docker

  4.3 重啟Docker

       systemctl restart docker

  4.4 開機啟動Docker

     systemctl enable docker

  4.5 檢視Docker概要資訊

   docker info

  4.6 檢視Docker幫助文件

   docker --help

  4.7 檢視Docker版本資訊

     docker version

5,Docker映象

  5.1 docker images 列出本機所有映象

 

REPOSITORY 映象的倉庫源
TAG 映象的標籤(版本)同一個倉庫有多個TAG的映象,多個版本;我們用REPOSITORY:TAG來定義不同的映象;
IMAGE ID 映象ID,映象的唯一標識
CREATE 映象建立時間
SIZE 映象大小

OPTIONS 可選引數:

-a 顯示所有映象(包括中間層)
-q 只顯示映象ID
-qa 可以組合
--digests 顯示映象的摘要資訊
--no-trunc 顯示完整的映象資訊 

 

  5.2 docker search 搜尋映象

和 https://hub.docker.com/ 這裡的搜尋效果一樣;

OPTIONS可選引數:

--no-trunc 顯示完整的映象描述
-s 列出收藏數不小於指定值的映象
--automated 只列出Docker Hub自動構建型別的映象

 

 

 

  5.3 docker pull 下載映象

docker pull 映象名稱:[TAG]

注意:不加TAG,預設下載最新版本latest

  5.4 docker rmi 刪除映象

1,刪除單個:docker rmi 映象名稱:[TAG]

如果不寫TAG,預設刪除最新版本latest

有映象生成的容器再執行時候,會報錯,刪除失敗;

我們需要加 -f 強制刪除

2,刪除多個:docker rmi -f 映象名稱1:[TAG] 映象名稱2:[TAG]

中間空格隔開

3,刪除全部:docker rmi -f $(docker images -qa)

 

 

------------------------------------------------------------------------------------------------------------------------------

作者: java1234_小鋒

出處:https://www.cnblogs.com/java688/p/13132444.html

版權:本站使用「CC BY 4.0」創作共享協議,轉載請在文章明顯位置註明作者及出處。

------------------------------------------------------------------------------------------------------------------------------

&n