三文搞懂學會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