日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Docker 拉取鏡像及標簽操作 pull | tag

瀏覽:24日期:2024-11-12 15:23:08

重翻Fabric項目的源碼,發現Docker部分內容,有很多不盡理解的地方,看著看著,就看到使用docker pull拉取Fabric鏡像及使用docker tag為鏡像重命名,稍作思慮,發現雖然使用過,卻未求甚解,得過且過,如今已經忘了如何運用……

1. docker pull

從鏡像源拉取鏡像,一般來說是從Docker Hub拉取鏡像(image)

docker pull [OPTIONS] NAME[:TAG|@DIGEST]

選項,簡寫 默認 描述 ?all-tags , -a 從鏡像庫拉取所有tag標簽名的鏡像 ?disable-content-trust true 忽略鏡像校驗

比如:

$ docker pull hyperledger/fabric-$IMAGES:$FABRIC_TAGOptions:# -a 拉取所有不同標簽的鏡像 -a, --all-tags Download all tagged images in the repository# 忽略鏡像校驗,默認項 --disable-content-trust Skip image verification (default true)

我們實際操作一下看看,操作環境是常用的Ubuntu16.04

1.1 普通拉取

實際上我們可以直接拉取該鏡像的最新版,默認拉取tag為latest的鏡像

比如:

#拉取了java的鏡像,tag為latest$ docker pull javaUsing default tag: latestlatest: Pulling from library/java5040bd298390: Pull complete fce5728aad85: Pull complete 76610ec20bf5: Pull complete 60170fec2151: Pull complete e98f73de8f0d: Pull complete 11f7af24ed9c: Pull complete 49e2d6393f32: Pull complete bb9cdec9c7f3: Pull complete Digest: sha256:c1ff613e8ba25833d2e1940da0940c3824f03f802c449f3d1815a66b7f8c0e9dStatus: Downloaded newer image for java:latest

拉取完成,我們可以查看已經擁有的鏡像

$ docker imagesREPOSITORY TAG IMAGE ID CREATED SIZEjava latest d23bdf5b1b1b 20 months ago 643MB

1.2 tag標簽名拉取

從上述輸出內容,我們可以發現,雖然只拉取了一個java鏡像,但是拉取過程中,卻有多個Pull complete,5040bd298390和fce5728aad85等8個,這是因為鏡像可以由多“層”(layers)組成,而這種“層”可以被其他的鏡像復用(有點像前端的組件或模塊),從而組成新鏡像。

如果拉取另一個鏡像,其中某些“層”已經下載過,那么docker pull則只會拉取元數據,而不會重復拉取“層”。

Docker的鏡像庫使用了內容尋址儲存功能,而鏡像ID是由SHA256作為摘要代表了其中包含的配置及“層”,下面我們來證明一下,因為我拉取的是java:latest,即tag名為latest的鏡像,所以我需要找到和latest同版不同tag名的鏡像(本質上是一個鏡像,只是標簽名不一樣),在Docker Hub上搜到如下結果:

Docker 拉取鏡像及標簽操作 pull | tag

拉取tag名為8-jdk的鏡像:

$ docker pull java:8-jdk8-jdk: Pulling from library/javaDigest: sha256:c1ff613e8ba25833d2e1940da0940c3824f03f802c449f3d1815a66b7f8c0e9dStatus: Downloaded newer image for java:8-jdk

很明顯,此處的拉取沒有看到“層”的信息,且摘要的sha256值也與tag名為latest的鏡像完全一樣,本質上這是完全相同的兩個鏡像,由相同的“層”組成,所以不需要再次拉取了。

此時,你們也許會和我產生相同的疑問,“完全相同?”,那是不是代表他們在操作環境中只存在一個?那么又用誰的tag名來命名呢?我們來看如下輸出:

$ docker imagesREPOSITORY TAG IMAGE ID CREATED SIZEjava 8-jdk d23bdf5b1b1b 20 months ago 643MBjava latest d23bdf5b1b1b 20 months ago 643MB

我們可以清楚的看到,此時查看所有鏡像,有tag名分別為8-jdk和latest的鏡像羅列其上,java:8-jdk和 java:latest擁有相同的image ID,因為本質上他們確實是 同一鏡像 ,只是由 不同標簽 所標記。

由于鏡像完全相同,則他們的“層”只儲存一次,且不會消耗額外的磁盤空間,即操作環境中只存在一個java鏡像,也可以用不同的tag標記這個鏡像。

更多關于鏡像,“層”,內容尋址存儲庫的信息,請移步還未開的新坑深度解析Docker鏡像,“層”和存儲驅動

1.3 摘要拉取

通過上述兩種拉取鏡像的方式,我們獲得了一個sha256

sha256:c1ff613e8ba25833d2e1940da0940c3824f03f802c449f3d1815a66b7f8c0e9d

我們下面嘗試摘要拉取鏡像的方法:

$ docker pull java@sha256:c1ff613e8ba25833d2e1940da0940c3824f03f802c449f3d1815a66b7f8c0e9dsha256:c1ff613e8ba25833d2e1940da0940c3824f03f802c449f3d1815a66b7f8c0e9d: Pulling from library/javaDigest: sha256:c1ff613e8ba25833d2e1940da0940c3824f03f802c449f3d1815a66b7f8c0e9dStatus: Image is up to date for java@sha256:c1ff613e8ba25833d2e1940da0940c3824f03f802c449f3d1815a66b7f8c0e9d

該摘要的鏡像,已經是最新,不需要拉取。

$ docker imagesREPOSITORY TAG IMAGE ID CREATED SIZEjava 8-jdk d23bdf5b1b1b 20 months ago 643MBjava latest d23bdf5b1b1b 20 months ago 643MB

鏡像列表毫無變動。

這里需要提及一個知識點,摘要可以在Dockerfile中配合FROM使用:

FROM java@sha256:c1ff613e8ba25833d2e1940da0940c3824f03f802c449f3d1815a66b7f8c0e9d

MAINTAINER some maintainer <maintainer@example.com>

這種引用方式,由于特定摘要,會將鏡像固定為特定的版本,且不會更新,如需要使用其他版本,則需要變更摘要內容

1.4 從其他注冊中心拉取

重申,默認情況下,docker pull從Docker Hub拉取鏡像。當然,我們可以設置從其他注冊中心拉取鏡像:

$ docker pull localregistry.example:6666/testing/test-image

此處需要注意,注冊中心的URL前不需要加http://或https://

1.5 從同一鏡像庫,一次拉取多個鏡像

使用docker pull -a 則可以拉取同一鏡像庫中所有鏡像。

1.6 取消拉取

取消拉取動作可以殺死拉取進程,直接在操作界面CTRL+c。

2. docker tag

給源鏡像創建一個新的tag

docker tag SOURCE_IMAGE[:TAG] TARGET_IMAGE[:TAG]

鏡像名,是由斜杠分割的每一個name組成部分構成的,如library/java。

用冒號分割name和tag,如library/java:8-jdk。

我們還可以在鏡像名前加一些前綴,表示鏡像來源是其他注冊中心或私有注冊中心,如

localregistry.example:6666/library/java:8-jdk

2.1 給Name引用的鏡像加標簽

$ docker tag java java:byname

讀者們可以自行嘗試docker tag java java:byname和docker tag java lib/java:byname有何異同

2.2 給ID引用的鏡像加標簽

$ docker tag d23bdf5b1b1b java:byid

2.3 給Name和Tag引用的鏡像加標簽

$ docker tag java:8-jdk java:bynameandid

2.4 給私有注冊中心的鏡像加標簽

為了將鏡像上傳到私有注冊中心,需要給鏡像重命名,規則為:

$ docker tag java:8-jdk localregistry.example:6666/library/java:8-jdk-v1

docker pull和 docker tag是使用頻率頗高的命令,使用方法簡單,卻有很多技巧,讀者們可以自行練習、嘗試。

后記

其實接觸docker也很久了,怎么想到寫這部分的內容呢?

下筆的初衷,是為求知識的沉淀,一直以來,上級領導對我的要求是快速應用技術,產生價值,那么理論研究,底層原理,甚至基礎的命令,可能都不知真意,僅僅是能用,會用。

就像駕校教會學員駕駛技術(也可能沒教會),卻未曾教授汽車的組成(架構),運作機制(底層原理)。手會掛擋轉方向盤,腳會踩離合油門剎車,是不是也就夠了,會開車了。

那么為什么要沉淀?

其一,當有人問你,一些命令,一些原理的時候,你支支吾吾無法作答,因為你只是通過指尖的肌肉記憶了命令的使用方法,更遑論原理或底層;

其二,觸類旁通,從最初的前端菜鳥,到后來的使用Spring Boot架構寫Java應用,再到現在學習使用Linux命令(shell)、Docker、Go來應用區塊鏈框架 HyperLedger Fabric 做生產,看似有些跨度,然而還是一個相同的領域,人與機器之間的交流。我學會的是用不同的語種去和會各種機器語言的機器去交流,就像一個活在機器國度的異族,會讀,會寫。在機器世界的踐行之路上,與一開始的HTML,CSS,JavaScript,我的啟蒙,漸行漸遠。正值國慶前夕,暫且寫在這里,感覺自己就是一顆過度吸水和接受充分光照的豆芽,越長越高,然而越高的地方越是纖細,根部不夠繁茂,頸部不夠粗壯,越是易彎易折。應當時刻鞭策自己,不棄初心,不忘本職,汲取前端更有營養的內容,強壯己身。

以上這篇Docker 拉取鏡像及標簽操作 pull | tag就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Docker
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
一区福利视频| 精品九九在线| 欧美日韩一区二区综合| 亚洲天堂av影院| 日韩精品电影| 999久久久免费精品国产| 人人香蕉久久| 国产真实久久| 狠狠色综合网| 亚洲日产av中文字幕| 日韩精品亚洲专区| 亚洲精品婷婷| 国产精品久久久久av蜜臀| 国产精久久久| 天堂а√在线最新版中文在线| 夜鲁夜鲁夜鲁视频在线播放| 91精品国产自产在线观看永久∴| 国产在线日韩| 老司机精品久久| 欧美一区二区三区免费看| 国产九一精品| se01亚洲视频| 首页国产欧美日韩丝袜| 国产亚洲高清一区| 日韩综合在线| 最新亚洲激情| 青青草精品视频| 国产成人精选| av不卡免费看| 国产精品.xx视频.xxtv| 日韩在线免费| 蜜桃91丨九色丨蝌蚪91桃色| 久久不卡日韩美女| 亚洲国产专区| 日本色综合中文字幕| 91亚洲一区| 亚洲欧美不卡| 久久精品国产999大香线蕉| 亚洲成人av观看| 中文字幕av亚洲精品一部二部| 久久中文精品| 亚洲福利一区| 日本不卡高清| 91精品韩国| 欧美在线观看天堂一区二区三区| 97精品国产| 亚洲婷婷丁香| 91嫩草亚洲精品| 亚洲精品亚洲人成在线观看| 国产成人1区| 免费不卡在线视频| 国产一区二区三区黄网站| 国产精品婷婷| 国产一区精品福利| 免费看欧美美女黄的网站| 精品九九久久| 一区二区自拍| 国产在线不卡一区二区三区 | 亚洲2区在线| 国产va在线视频| 午夜亚洲福利| 日韩免费一区| 日本成人在线不卡视频| 久久久久美女| 国产精品二区影院| 石原莉奈在线亚洲二区| а√天堂8资源在线| 日韩精品视频一区二区三区| 99久久激情| 久久99久久久精品欧美| 欧美.日韩.国产.一区.二区 | 美女视频网站久久| 免费视频一区三区| 国产成人精品一区二区三区视频 | 美女视频黄免费的久久| 巨乳诱惑日韩免费av| 国产传媒av在线| 国产亚洲观看| 一级欧美视频| 蜜臀av免费一区二区三区| 久久97视频| 日本va欧美va瓶| 亚洲一卡久久| 亚洲午夜黄色| 国产成人77亚洲精品www| 日韩一区精品| 亚洲欧洲午夜| 久久精品在线| 美女久久久精品| 亚洲综合五月| 午夜国产精品视频| 成人看片网站| 不卡专区在线| 精品视频97| 国产精品网在线观看| 天堂俺去俺来也www久久婷婷| 中文亚洲欧美| 91成人精品| 欧洲在线一区| 精品三级久久| 欧美一级鲁丝片| 国产一区二区三区日韩精品| 国产精品中文字幕亚洲欧美| 日韩在线麻豆| 久久大逼视频| 五月天综合网站| 精品一区免费| 国产v综合v| 日韩欧美另类一区二区| 日本一二区不卡| 精品国产18久久久久久二百| 国产精东传媒成人av电影| 久久激情五月激情| 国产精品亚洲人成在99www| 91精品啪在线观看国产爱臀| 色婷婷成人网| 日韩不卡手机在线v区| 婷婷视频一区二区三区| 日韩一区二区三区精品| 综合国产视频| 日韩精品免费一区二区夜夜嗨 | 最新国产拍偷乱拍精品| 亚洲精品1区| 美女久久网站| 在线观看视频免费一区二区三区| 午夜一区在线| 亚洲精品影院在线观看| 四虎成人精品一区二区免费网站| 亚洲男人在线| 欧美日韩一区二区三区四区在线观看| 亚洲精品免费观看| 日韩一区二区三免费高清在线观看| 亚洲毛片一区| 国产欧美久久一区二区三区| 老司机精品在线| 麻豆国产在线| 91精品综合| 亚洲一区日本| 日本视频在线一区| 国产精品极品在线观看| 国产精品毛片久久| 久久久久国产精品一区三寸| 一区二区自拍| 日本电影久久久| 欧美激情aⅴ一区二区三区 | 国产精品一区二区av日韩在线| 乱一区二区av| 秋霞国产精品| 99re国产精品| 日韩精品一区二区三区中文在线| 国产精品亚洲欧美日韩一区在线 | 精品资源在线| 青青久久av| 蜜臀va亚洲va欧美va天堂| 日韩精品免费视频一区二区三区| 国产欧美69| 免费福利视频一区二区三区| 成人av二区| 亚洲精品三级| 色乱码一区二区三区网站| 欧美亚洲激情| 日韩国产欧美一区二区三区| 老司机免费视频一区二区| 亚洲不卡系列| 亚洲欧美久久精品| 精品五月天堂| 欧美特黄视频| 国产精品亚洲二区| 欧美色图一区| 日韩高清欧美激情| 美女av在线免费看| 在线视频日韩| 久久这里只有| 亚洲欧美久久久| 欧美激情精品| 欧美日韩国产精品一区二区亚洲| 91麻豆精品激情在线观看最新| 国产乱码午夜在线视频| 日韩专区一卡二卡| 福利精品一区| 丝袜美腿亚洲色图| 麻豆久久久久久| 亚洲主播在线| 国际精品欧美精品| 美女国产精品| 国产一区二区三区免费在线| 每日更新成人在线视频| 精品国产欧美| 亚洲欧美在线综合| 日韩电影免费在线观看| 美女尤物久久精品| 成人福利av| 欧美偷窥清纯综合图区| 亚洲先锋成人| 精品一区91| 亚洲日产av中文字幕| 亚洲不卡av不卡一区二区| 国产日韩一区二区三免费高清| 日韩视频免费| 日韩av在线播放网址|