溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Docker v1.13新功能有哪些

發(fā)布時(shí)間:2022-05-26 15:09:53 來源:億速云 閱讀:291 作者:iii 欄目:大數(shù)據(jù)

這篇文章主要介紹了Docker v1.13新功能有哪些的相關(guān)知識,內(nèi)容詳細(xì)易懂,操作簡單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇Docker v1.13新功能有哪些文章都會有所收獲,下面我們一起來看看吧。

新增哪些功能

從國內(nèi)幾家科技媒體的文章都是從這里粘貼復(fù)制的:

該版本更新內(nèi)容較多,涉及到網(wǎng)絡(luò)、插件、移除掉的 api & 客戶端、運(yùn)行時(shí)、安全性以及依賴等。

docker 1.13有一千四百多個(gè)issue/pull request,五千多個(gè)commits,是docker歷史上最高的發(fā)布版本。這并不是一個(gè)簡單的小版本變化,里面有大量的更新。

top 10 新增功能

  • 正式支持服務(wù)棧:docker stack

  • 正式支持插件:docker plugin

  • 添加在swarm集群環(huán)境下對密碼、密鑰管理的 secret 管理服務(wù):docker secret

  • 增加命令:docker system

  • 可以直接使用 docker-compose.yml 進(jìn)行服務(wù)部署

  • 添加 docker service 滾動(dòng)升級出故障后回滾的功能

  • 增加強(qiáng)制再發(fā)布選項(xiàng) docker service update –force

  • 允許 docker service create 映射宿主端口,而不是邊界負(fù)載均衡網(wǎng)絡(luò)端口

  • 允許 docker run 連入指定的 swarm mode 的 overlay 網(wǎng)絡(luò)

  • 解決中國 gfw 墻掉 docker-engine apt/yum 源的問題

好了,逐一看看這新功能咯。

構(gòu)建緩存

第一件事就是構(gòu)建緩存,終于來了。這個(gè)功能在持續(xù)構(gòu)建過程中太有用了,以前docker只能自己自動(dòng)利用本地構(gòu)建緩存,現(xiàn)在可以指定構(gòu)建緩存了,不過使用緩存的前提條件是曾經(jīng)在本地構(gòu)建過這個(gè)鏡像。

例如,在合并請求中看到的例子:

docker pull myimage:v1.0
docker build --cache-from myimage:v1.0 -t myimage:v1.1 .

ps:另外發(fā)現(xiàn)docker這個(gè)版本對鏡像標(biāo)簽命名也做了限制,必須是“用戶/倉庫”的格式。

壓扁 (squash) 鏡像

這個(gè)怎么翻譯?算了,跟風(fēng)保留“壓扁”。這個(gè)對我個(gè)人來說效果不是很明顯,因?yàn)槲铱偸前讶縭un指令寫到一起,以此減少鏡像體積。

但也總有人喜歡一句命令一個(gè)run指令,這樣這個(gè)功能就很有用了。(話說這個(gè)寫法真是不作不死。)

正確的做法當(dāng)然是遵循 dockerfile 最佳實(shí)踐,應(yīng)該把多個(gè)命令合并為一個(gè) run,每一個(gè) run 要精心設(shè)計(jì),確保安裝構(gòu)建最后進(jìn)行清理。這樣才可以降低鏡像體積,以及最大化的利用構(gòu)建緩存。

不過docker這么人性化,當(dāng)然得為這些“一行一個(gè)run”的用戶添加點(diǎn)功能,以此減少他們構(gòu)建鏡像的體積。

同樣是 docker build 的參數(shù):--squash,你可以理解為docker自動(dòng)把多個(gè)run在同一文件層執(zhí)行了,不過保留了每一個(gè)run的構(gòu)建歷史。

要是這個(gè)功能完善之后,我也要轉(zhuǎn)投“一行一個(gè)run”,畢竟省事很多啊。這個(gè)功能還在試驗(yàn)階段。

構(gòu)建鏡像時(shí)指定網(wǎng)絡(luò)

這個(gè)我很少遇到過啊,一般都是直接改/etc/hosts文件,反正也不復(fù)雜,不過要是在分布網(wǎng)絡(luò)里就麻煩了點(diǎn)。

docker build --network指定網(wǎng)絡(luò)就好,還是蠻有用的。

--build-arg問題修復(fù)

這個(gè)我也不怎么遇到,畢竟我很少有項(xiàng)目需要持續(xù)構(gòu)建啊。以前的設(shè)定是--build-arg后面的變量一定要在構(gòu)建過程中用到,現(xiàn)在即使制定了不用也可以,不會構(gòu)建失敗。

這樣改的好處就是,在一些公司中持續(xù)構(gòu)建過程中,不同dockerfile使用不同的--build-arg參數(shù),而持續(xù)構(gòu)建中使用同一條構(gòu)建指令(或者腳本)構(gòu)建,1.12版本時(shí)是會報(bào)錯(cuò)的,1.13降為警告級別。

對于我這種一般用戶而言直接寫進(jìn) dockerfile 里好了。

安裝過程可以使用--mirror參數(shù)

這個(gè)是“專門”為天朝添加的功能,笑。

curl -ssl https://get.docker.com/ | sh -s -- --mirror azurechinacloud

上面的例子中安裝docker時(shí)會使用微軟中國的鏡像,至于安裝后會不會自動(dòng)添加倉庫鏡像源,我不知道啊。

docker run 直接加入集群

以前swarm集群網(wǎng)絡(luò)是不允許容器這樣加入網(wǎng)絡(luò)中的,因?yàn)橛锌赡軙茐募壕W(wǎng)絡(luò)結(jié)構(gòu)。

然后大伙又有這種需求,于是一種折中的辦法就是添加一個(gè)--attachable參數(shù)。

$ docker network create -d overlay --attachable test_attach

老實(shí)說這樣不太好的感覺,新加入的容器很容易就玩壞整個(gè)集群吶,壞笑。在服務(wù)設(shè)計(jì)時(shí)多考慮一下就好了啊,安全為上。

service create --publish格式變化

--publish protocol=tcp,mode=ingress,published=8080,target=80

我沒有試過嘍,-p已經(jīng)滿足我了。

network inspect顯示連接節(jié)點(diǎn)

這個(gè)大大的好,以前只能靠第三方工具或者拐彎抹角地查看,現(xiàn)在直接在管理節(jié)點(diǎn)就可以看到了。

插件來了

1.12的這個(gè)實(shí)驗(yàn)特性真是蠻讓人期待的。然而我暫時(shí)不想看,笑。

checkpoint

檢查點(diǎn),有點(diǎn)像賽車,跑到中途一個(gè)檢查點(diǎn),備份記錄一下當(dāng)時(shí)的狀態(tài),然后繼續(xù)前進(jìn),需要時(shí)可以從某個(gè)檢查點(diǎn)的狀態(tài)恢復(fù)。這么一看挺像快照的功能,要是進(jìn)入正式版,估計(jì)eclipse che那里的快照命名會有改進(jìn)。

docker stats顯示容器名

這個(gè)反人類的設(shè)計(jì)終于有了人性化的改進(jìn),以前查看容器狀態(tài)還得看容器id,現(xiàn)在可以顯示容器名了。

注意是可以,默認(rèn)還是不顯示的,需要定制輸出格式:

復(fù)制代碼 代碼如下:


docker stats --format 'table {{.name}}\t{{.cpuperc}}\t{{.memusage}}\t{{.memperc}}\t{{.netio}}\t{{.blockio}}\t{{.pids}}'

is-task過濾器

docker ps 的一個(gè)參數(shù),可以顯示哪些容器是集群服務(wù)的容器,哪些是直接運(yùn)行起來容器。還是有用的功能,不過我自己對容器命名都蠻嚴(yán)格的,不會亂到不認(rèn)識,笑。

docker ps -f 'is-task=true'

inspect升級

這個(gè)命令已經(jīng)可以查看任何docker對象了,是任何哦。
邪惡的我試了一下,同時(shí)存在名為nginx鏡像、容器、網(wǎng)絡(luò)、服務(wù)的情況下,inspect會優(yōu)先查看名為nginx容器的信息,查看其它同名對象的信息就需要使用id了。

直接啟用實(shí)驗(yàn)功能

dockerd --experimental就可以直接啟用實(shí)驗(yàn)功能了,簡直測試實(shí)驗(yàn)功能的利器,不需要重裝docker了。

增加 docker system 命令

很多人在以前搞不懂自己的鏡像到底占了多少空間、容器占了多少空間,卷占了多少空間。怎么刪除不用的東西以釋放資源。從 1.13 開始,docker 提供了一組 system 命令來幫助系統(tǒng)管理上的問題。

docker system df
type        total        active       size        reclaimable
images       21         3          10.3 gb       8.564 gb (83%)
containers     3          3          2 b         0 b (0%)
local volumes    1          1          0 b         0 b

那個(gè)reclaimable居然那么大,嚇我一跳,后來一想我電腦在家就運(yùn)行兩個(gè)容器,所以其他鏡像都被識別為可回收的了。

還有那個(gè)數(shù)據(jù)卷,我數(shù)據(jù)卷少說也有幾百mb,不知道這里的結(jié)果是怎么計(jì)算出來的。

上面顯示的列表中列出了鏡像、容器、本地卷所占用的磁盤空間,以及可能回收的磁盤空間。比如,我們看到鏡像有 123mb 的空間可以回收,從 1.13 開始,docker 提供了一組 prune 命令,分別是:

  • docker image prune:刪除無用的鏡像

  • docker container prune:刪除無用的容器

  • docker volume prune:刪除無用的卷

  • docker network prune:刪除無用的網(wǎng)絡(luò)

  • docker system prune:刪除無用的鏡像、容器、卷、網(wǎng)絡(luò)

一個(gè)值得提醒的是,這個(gè)版本的命令有了很多調(diào)整,雖然保留了1.12時(shí)候的風(fēng)格,但是docker已經(jīng)開始更加合理地分配子命令。

之前默認(rèn)的 docker info,docker ps,docker rm,docker run 都開始?xì)w類于對應(yīng)的 docker image, docker container, docker system 下了。

之前的命令依舊可以使用,會繼續(xù)保持一段時(shí)間。但是從 1.13 開始,推薦使用各個(gè)子命令的版本了。

關(guān)于“Docker v1.13新功能有哪些”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對“Docker v1.13新功能有哪些”知識都有一定的了解,大家如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI