您好,登錄后才能下訂單哦!
這篇文章主要介紹了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è)資訊頻道。
免責(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)容。