您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關docekr鏡像相關的操作有哪些,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
##獲取鏡像
我們使用__docker pull__指令獲取鏡像。鏡像的獲取源有三種:Docker官方倉庫,第三方Docker倉庫,本地私有倉庫。
###Docker官方倉庫
下面的例子將從Docker Hub下載一個Ubuntu12.04操作系統鏡像
$ docker pull ubuntu:12.04 Pulling repository ubuntu ab8e2728644c: Pulling dependent layers 511136ea3c5a: Download complete 5f0ffaa9455e: Download complete a300658979be: Download complete 904483ae0c30: Download complete ffdaafd1ca50: Download complete d047ae21eeaf: Download complete
Docker pull工具會輸出每一層的獲取信息,包括當前獲取內容的大小,傳輸的速度,傳輸狀態。
上面的__docker pull ubuntu:12.04__實際上執行了
$ sudo docker pull registry.hub.docker.com/ubuntu:12.04
其中__registry.hub.docker.com__是倉庫注冊服務器,ubuntu是指倉庫,12.04是指tag。即從注冊服務器 registry.hub.docker.com 中的 ubuntu 倉庫來下載標記為 12.04 的鏡像。
有時候從官方倉庫下載比較慢,這是我們可以使用第三方倉庫加快我們的下載速度。
###第三方Docker倉庫
明白了上面pull完整選項含義之后我們就非常容易理解下面這條從第三方倉庫下載鏡像的指令
docker pull dl.dockerpool.com:5000/ubuntu:12.04 Pulling dl.dockerpool.com:5000/ubuntu ab8e2728644c: Pulling dependent layers 511136ea3c5a: Download complete 5f0ffaa9455e: Download complete a300658979be: Download complete 904483ae0c30: Download complete ffdaafd1ca50: Download complete d047ae21eeaf: Download complete
從注冊服務器 dl.dockerpool.com:5000 中的 ubuntu 倉庫來下載標記為 12.04 的鏡像。
###私有倉庫
好吧,這塊我自己還不太懂,有機會搭建一個私有倉庫,再來補充
##管理本地鏡像
###初次使用鏡像
鏡像下載完成之后,就可以使用該鏡像了,使用__docker run__啟動一個容器來使用鏡像。
docker run -t -i ubuntu:12.04 /bin/bash
如果成功啟動了,接著會進入bash
root@fe7fc4bd8fc9:/#
###列出本地鏡像
要想查看本地鏡像,使用__docker images__
docker images REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE ubuntu 12.04 74fe38d11401 4 weeks ago 209.6 MB ubuntu precise 74fe38d11401 4 weeks ago 209.6 MB ubuntu 14.04 99ec81b80c55 4 weeks ago 266 MB ubuntu latest 99ec81b80c55 4 weeks ago 266 MB ubuntu trusty 99ec81b80c55 4 weeks ago 266 MB ...
讓我們來看看列出的字段各自的含義:
REPOSITORY: 倉庫名稱
TAG: 鏡像的標記
IMAGE ID: 鏡像ID號(唯一)
CREATED: 創建時間
VIRTUAL SIZE: 鏡像大小
注:鏡像的ID是鏡像的唯一標示,上面出現了ubuntu:14.0與ubuntu:trusty ID號相同的情況,這說明,他們是同一個鏡像。
###創建鏡像
創建鏡像的方式有很多種:
修改已有的鏡像
利用Dockerfile創建鏡像
從本地文件系統導入
上傳鏡像
####修改已有的鏡像
通過修改已有鏡像的方式創建鏡像我們首先需要在已有鏡像中做修改,然后提交修改(更新)后的鏡像。
啟動需要修改的鏡像:
$ sudo docker run -t -i ubuntu:12.04 /bin/bash root@0b2616b0e5a8:/#
暫時記住容器的ID,即:0b2616b0e5a8,稍后會用到。
在容器中添加 json 和 gem 兩個應用:
# gem install json
當結束后,我們使用 exit 來退出,現在我們的容器已經被我們改變了,使用 docker commit 命令來提交更新后的副本。
$ docker commit -m "Added json gem" -a "Docker Newbee" 0b2616b0e5a8 ouruser/sinatra:v2 4f177bd27a9ff0f6dc2a830403925b5360bfe0b93d476f7fc3231110e7f71b1c
其中,-m 指定提交的說明信息,跟我們使用的版本控制工具類似;-a 指定更新的用戶信息;后面是鏡像的 ID ,倉庫名以及tag標簽。最后創建成功后回返回這個鏡像的 ID 信息。
然后,我們用 docekr images 來查看我們修改后的鏡像。
$ docker images REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE training/sinatra latest 5bc342fa0b91 10 hours ago 446.7 MB ouruser/sinatra v2 3c59e02ddd1a 10 hours ago 446.7 MB ouruser/sinatra latest 5db5f8471261 10 hours ago 446.7 M
之后,就可以使用新的鏡像來創建容器。
$ sudo docker run -t -i ouruser/sinatra:v2 /bin/bash root@78e82f680994:/#
####利用Dockerfile創建鏡像
使用修改現有鏡像的方式創建鏡像很簡單快速,但是這種方式不便于在團隊中分享。我們可以使用__docker build__來創建鏡像,使用__docker build__創建鏡像,需要首先寫好__Dockerfile__配置文件。Dockerfile中正是包含了一步步創建鏡像所需要的指令。
新建一個目錄和dockerfile文件:
$ mkdir sinatra $ cd sinatra $ touch Dockerfile
接下來,我們往Dockerfile中寫內容:
#This is a comment FROM ubuntu:12.04 MAINTAINER Docker Newbee <newbee@docker.com> RUN apt-get -qq update RUN apt-get -qqy install ruby ruby-dev RUN gem install sinatr
先看看上面這些內容如何理解:
#用來注釋
FROM 指令告訴 Docker 使用哪個鏡像作為基礎
接著是維護者的信息
RUN開頭的指令會在創建中運行,比如安裝一個軟件包,在這里使用 apt-get 來安裝了一些軟件
Dockerfile 中每一條指令都創建鏡像的一層。
編寫完Dockerfile之后,我們就可以使用docker build來生成鏡像。
$ docker build -t="ouruser/sinatra:v2" . Uploading context 2.56 kB Uploading context Step 0 : FROM ubuntu:14.04 ---> 99ec81b80c55 Step 1 : MAINTAINER Newbee <newbee@docker.com> ---> Running in 7c5664a8a0c1 ---> 2fa8ca4e2a13 Removing intermediate container 7c5664a8a0c1 Step 2 : RUN apt-get -qq update ---> Running in b07cc3fb4256 ---> 50d21070ec0c Removing intermediate container b07cc3fb4256 Step 3 : RUN apt-get -qqy install ruby ruby-dev ---> Running in a5b038dd127e Selecting previously unselected package libasan0:amd64. (Reading database ... 11518 files and directories currently installed.) Preparing to unpack .../libasan0_4.8.2-19ubuntu1_amd64.deb ... Setting up ruby (1:1.9.3.4) ... Setting up ruby1.9.1 (1.9.3.484-2ubuntu1) ... Processing triggers for libc-bin (2.19-0ubuntu6) ... ---> 2acb20f17878 Removing intermediate container a5b038dd127e Step 4 : RUN gem install sinatra ---> Running in 5e9d0065c1f7 . . . Successfully installed rack-protection-1.5.3 Successfully installed sinatra-1.4.5 4 gems installed ---> 324104cde6ad Removing intermediate container 5e9d0065c1f7 Successfully built 324104cde6ad
-t 是用來添加tag標記,指定新的鏡像的用戶信息,“.”是Dockerfile所在的路徑(當前目錄),也可以替換為一個具體的 Dockerfile 的路徑。
可以看到 build 進程在執行操作。它要做的第一件事情就是上傳這個 Dockerfile 內容,因為所有的操作都要依據 Dockerfile 來進行。 然后,Dockfile 中的指令被一條一條的執行。每一步都創建了一個新的容器,在容器中執行指令并提交修改(就跟之前介紹過的 docker commit 一樣)。當所有的指令都執行完畢之后,返回了最終的鏡像 id。所有的中間步驟所產生的容器都被刪除和清理了。
注意一個鏡像不能超過 127 層
關于dockerfile更詳細的語法,后面會有一片博文坐專門的講解。
####從本地文件系統導入
要從本地文件系統導入一個鏡像,可以使用openvz(容器虛擬化的先鋒技術)的模板來創建:openvz 的模板下載地址為 templates 。
比如,先下載了一個 ubuntu-14.04 的鏡像,之后使用以下命令導入:
cat ubuntu-14.04-x86_64-minimal.tar.gz |docker import - ubuntu:14.04
然后查看新導入的鏡像。
docker images REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE ubuntu 14.04 05ac7c0b9383 17 seconds ago 215.5 MB
####上傳鏡像
用戶可以通過 docker push 命令,把自己創建的鏡像上傳到倉庫中來共享。例如,用戶在 Docker Hub 上完成注冊后,可以推送自己的鏡像到倉庫中。
$ sudo docker push ouruser/sinatra The push refers to a repository [ouruser/sinatra] (len: 1) Sending image list Pushing repository ouruser/sinatra (3 tags)
###導出與導入鏡像
####到處鏡像
要想將鏡像到處到本地,使用docker save命令:
docker images $ docker images REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE ubuntu 14.04 c4ff7513909d 5 weeks ago 225.4 MB ... $ docker save -o ubuntu_14.04.tar ubuntu:14.04
####導入鏡像
可以使用 docker load 從導出的本地文件中再導入到本地鏡像庫,例如
$ docker load --input ubuntu_14.04.tar
或
$ docker load < ubuntu_14.04.tar
這將導入鏡像以及其相關的元數據信息(包括標簽等)。
###移除本地鏡像
如果要移除本地的鏡像,可以使用 docker rmi 命令。注意 docker rm 命令是移除容器。
$ docker rmi training/sinatra Untagged: training/sinatra:latest Deleted: 5bc342fa0b91cabf65246837015197eecfa24b2213ed6a51a8974ae250fedd8d Deleted: ed0fffdcdae5eb2c3a55549857a8be7fc8bc4241fb19ad714364cbfd7a56b22f Deleted: 5c58979d73ae448df5af1d8142436d81116187a7633082650549c52c3a2418f0
注意:在刪除鏡像之前要先用 docker rm 刪掉依賴于這個鏡像的所有容器。
##鏡像的實現原理
Docker 鏡像是怎么實現增量的修改和維護的? 每個鏡像都由很多層次構成,Docker 使用 Union FS 將這些不同的層結合到一個鏡像中去。
通常 Union FS 有兩個用途, 一方面可以實現不借助 LVM、RAID 將多個 disk 掛到同一個目錄下,另一個更常用的就是將一個只讀的分支和一個可寫的分支聯合在一起,Live CD 正是基于此方法可以允許在鏡像不變的基礎上允許用戶在其上進行一些寫操作。 Docker 在 AUFS 上構建的容器也是利用了類似的原理。
關于“docekr鏡像相關的操作有哪些”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。