久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

docker中pull和push的性能有什么不同

196次閱讀
沒有評論

共計 9369 個字符,預計需要花費 24 分鐘才能閱讀完成。

這篇文章主要介紹了 docker 中 pull 和 push 的性能有什么不同,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓丸趣 TV 小編帶著大家一起了解一下。

0. 測試環境

基本架構:沒有 docker index,所有操作發生在 daemon 和 registry 之間

鏡像:

# docker images --tree 
Warning:  --tree  is deprecated, it will be removed soon. See usage.
├─9247a3750813 Virtual Size: 85.1 MB
│ └─a92b1d9f0ca5 Virtual Size: 1.078 GB Tags: 10.180.156.6:5000/bigtest2:latest

網絡環境:docker daemon 和 registry 之間為千兆網絡,帶寬足夠大。

1. docker push 日志分析及 registry put 對比測試

在客戶端做一次 docker push 的時候,觀察 registry 端日志,刨去無關的一些日志后,如下:

10.180.156.11 - - [02/Apr/2015:03:25:55 +0000]  GET /v2/ HTTP/1.1  404 233  -   Go 1.1 package http 
10.180.156.11 - - [02/Apr/2015:03:25:55 +0000]  GET /v1/_ping HTTP/1.1  200 2  -   Go 1.1 package http 
02/Apr/2015:03:25:55 +0000 DEBUG: args = {namespace :  library ,  repository : u bigtest2}
02/Apr/2015:03:25:55 +0000 ERROR:  ?xml version= 1.0  encoding= UTF-8 ? 
10.180.156.11 - - [02/Apr/2015:03:25:55 +0000]  PUT /v1/repositories/bigtest2/ HTTP/1.1  200 2  -   docker/1.5.0 go/go1.4.1 git-commit/a8a31ef kernel/3.13.0-32-generic os/linux arch/amd64 
02/Apr/2015:03:25:55 +0000 DEBUG: args = {image_id : u 9247a37508136a5fe916f4f87bfa2aa47f2edf8fc1a1ce787445b606d8fdbf9f}
02/Apr/2015:03:25:55 +0000 DEBUG: args = {image_id : u a92b1d9f0ca59cefd024a5f2f2d23e2d617b3e67cc2363c94998006fa87e60e5}
02/Apr/2015:03:25:55 +0000 DEBUG: api_error: Image not found
10.180.156.11 - - [02/Apr/2015:03:25:55 +0000]  GET /v1/images/9247a37508136a5fe916f4f87bfa2aa47f2edf8fc1a1ce787445b606d8fdbf9f/json HTTP/1.1  404 28  -   docker/1.5.0 go/go1.4.1 git-commit/a8a31ef kernel/3.13.0-32-generic os/linux arch/amd64 
02/Apr/2015:03:25:55 +0000 DEBUG: api_error: Image not found
10.180.156.11 - - [02/Apr/2015:03:25:55 +0000]  GET /v1/images/a92b1d9f0ca59cefd024a5f2f2d23e2d617b3e67cc2363c94998006fa87e60e5/json HTTP/1.1  404 28  -   docker/1.5.0 go/go1.4.1 git-commit/a8a31ef kernel/3.13.0-32-generic os/linux arch/amd64 
02/Apr/2015:03:25:55 +0000 DEBUG: args = {image_id : u 9247a37508136a5fe916f4f87bfa2aa47f2edf8fc1a1ce787445b606d8fdbf9f}
10.180.156.11 - - [02/Apr/2015:03:25:56 +0000]  PUT /v1/images/9247a37508136a5fe916f4f87bfa2aa47f2edf8fc1a1ce787445b606d8fdbf9f/json HTTP/1.1  200 4  -   docker/1.5.0 go/go1.4.1 git-commit/a8a31ef kernel/3.13.0-32-generic os/linux arch/amd64 
=== 3 秒 ===
02/Apr/2015:03:25:57 +0000 DEBUG: args = {image_id : u 9247a37508136a5fe916f4f87bfa2aa47f2edf8fc1a1ce787445b606d8fdbf9f}
===34 秒 ===
10.180.156.11 - - [02/Apr/2015:03:26:31 +0000]  PUT /v1/images/9247a37508136a5fe916f4f87bfa2aa47f2edf8fc1a1ce787445b606d8fdbf9f/layer HTTP/1.1  200 4  -   docker/1.5.0 go/go1.4.1 git-commit/a8a31ef kernel/3.13.0-32-generic os/linux arch/amd64 
02/Apr/2015:03:26:31 +0000 DEBUG: args = {image_id : u 9247a37508136a5fe916f4f87bfa2aa47f2edf8fc1a1ce787445b606d8fdbf9f}
10.180.156.11 - - [02/Apr/2015:03:26:31 +0000]  PUT /v1/images/9247a37508136a5fe916f4f87bfa2aa47f2edf8fc1a1ce787445b606d8fdbf9f/checksum HTTP/1.1  200 4  -   docker/1.5.0 go/go1.4.1 git-commit/a8a31ef kernel/3.13.0-32-generic os/linux arch/amd64 
02/Apr/2015:03:26:31 +0000 DEBUG: args = {image_id : u a92b1d9f0ca59cefd024a5f2f2d23e2d617b3e67cc2363c94998006fa87e60e5}
10.180.156.11 - - [02/Apr/2015:03:26:32 +0000]  PUT /v1/images/a92b1d9f0ca59cefd024a5f2f2d23e2d617b3e67cc2363c94998006fa87e60e5/json HTTP/1.1  200 4  -   docker/1.5.0 go/go1.4.1 git-commit/a8a31ef kernel/3.13.0-32-generic os/linux arch/amd64 
=== 6 秒 ===
02/Apr/2015:03:26:37 +0000 DEBUG: args = {image_id : u a92b1d9f0ca59cefd024a5f2f2d23e2d617b3e67cc2363c94998006fa87e60e5}
===325 秒 ===
10.180.156.11 - - [02/Apr/2015:03:32:02 +0000]  PUT /v1/images/a92b1d9f0ca59cefd024a5f2f2d23e2d617b3e67cc2363c94998006fa87e60e5/layer HTTP/1.1  200 4  -   docker/1.5.0 go/go1.4.1 git-commit/a8a31ef kernel/3.13.0-32-generic os/linux arch/amd64 
02/Apr/2015:03:32:02 +0000 DEBUG: args = {image_id : u a92b1d9f0ca59cefd024a5f2f2d23e2d617b3e67cc2363c94998006fa87e60e5}
10.180.156.11 - - [02/Apr/2015:03:32:03 +0000]  PUT /v1/images/a92b1d9f0ca59cefd024a5f2f2d23e2d617b3e67cc2363c94998006fa87e60e5/checksum HTTP/1.1  200 4  -   docker/1.5.0 go/go1.4.1 git-commit/a8a31ef kernel/3.13.0-32-generic os/linux arch/amd64 
02/Apr/2015:03:32:03 +0000 DEBUG: args = {tag : u latest ,  namespace :  library ,  repository : u bigtest2}
02/Apr/2015:03:32:03 +0000 DEBUG: [put_tag] namespace=library; repository=bigtest2; tag=latest
10.180.156.11 - - [02/Apr/2015:03:32:03 +0000]  PUT /v1/repositories/bigtest2/tags/latest HTTP/1.1  200 4  -   docker/1.5.0 go/go1.4.1 git-commit/a8a31ef kernel/3.13.0-32-generic os/linux arch/amd64 
02/Apr/2015:03:32:03 +0000 DEBUG: args = {images : True,  namespace :  library ,  repository : u bigtest2}
10.180.156.11 - - [02/Apr/2015:03:32:03 +0000]  PUT /v1/repositories/bigtest2/images HTTP/1.1  204 -  -   docker/1.5.0 go/go1.4.1 git-commit/a8a31ef kernel/3.13.0-32-generic os/linux arch/amd64

可以發現,對于一個 2 層的鏡像,整個 push 的時間可以分成幾段

操作耗時百分比 put json13s0.8%put layer134s9.2%put json26s1.6%put layer2325s87.6% 總耗時 371s100%

也就是說,在做 put layer1 和 put layer2 時消耗了 96.8% 的時間。那么,純的對 registry 服務做同樣文件的 PUT 操作,會消耗多少時間呢?

# time curl -X PUT -H  Transfer-Encoding: chunked  --data-binary @layer-a92b1  http://10.180.156.6:5000/v1/images/a92b1d9f0ca59cefd024a5f2f2d23e2d617b3e67cc2363c94998006fa87e60e5/layer 
real 0m44.571s
user 0m0.302s
sys 0m1.341s
# time curl -X PUT -H  Transfer-Encoding: chunked  --data-binary @layer-9247a  http://10.180.156.6:5000/v1/images/9247a37508136a5fe916f4f87bfa2aa47f2edf8fc1a1ce787445b606d8fdbf9f/layer 
real 0m4.277s
user 0m0.029s
sys 0m0.130s

2. docker pull 日志分析及 registry get 對比測試

類似上個節,繼續做 pull 的日志分析

10.180.156.11 - - [02/Apr/2015:08:54:16 +0000]  GET /v2/ HTTP/1.1  404 233  -   Go 1.1 package http 
10.180.156.11 - - [02/Apr/2015:08:54:16 +0000]  GET /v1/_ping HTTP/1.1  200 2  -   Go 1.1 package http 
02/Apr/2015:08:54:16 +0000 DEBUG: args = {namespace :  library ,  repository : u bigtest2}
10.180.156.11 - - [02/Apr/2015:08:54:16 +0000]  GET /v1/repositories/bigtest2/images HTTP/1.1  200 152  -   docker/1.5.0 go/go1.4.1 git-commit/a8a31ef kernel/3.13.0-32-generic os/linux arch/amd64 
02/Apr/2015:08:54:16 +0000 DEBUG: args = {namespace : u library ,  repository : u bigtest2}
02/Apr/2015:08:54:16 +0000 DEBUG: [get_tags] namespace=library; repository=bigtest2
10.180.156.11 - - [02/Apr/2015:08:54:16 +0000]  GET /v1/repositories/library/bigtest2/tags HTTP/1.1  200 78  -   docker/1.5.0 go/go1.4.1 git-commit/a8a31ef kernel/3.13.0-32-generic os/linux arch/amd64 
02/Apr/2015:08:54:16 +0000 DEBUG: args = {image_id : u a92b1d9f0ca59cefd024a5f2f2d23e2d617b3e67cc2363c94998006fa87e60e5}
10.180.156.11 - - [02/Apr/2015:08:54:16 +0000]  GET /v1/images/a92b1d9f0ca59cefd024a5f2f2d23e2d617b3e67cc2363c94998006fa87e60e5/ancestry HTTP/1.1  200 136  -   docker/1.5.0 go/go1.4.1 git-commit/a8a31ef kernel/3.13.0-32-generic os/linux arch/amd64 
02/Apr/2015:08:54:16 +0000 DEBUG: args = {image_id : u 9247a37508136a5fe916f4f87bfa2aa47f2edf8fc1a1ce787445b606d8fdbf9f}
10.180.156.11 - - [02/Apr/2015:08:54:17 +0000]  GET /v1/images/9247a37508136a5fe916f4f87bfa2aa47f2edf8fc1a1ce787445b606d8fdbf9f/json HTTP/1.1  200 619  -   docker/1.5.0 go/go1.4.1 git-commit/a8a31ef kernel/3.13.0-32-generic os/linux arch/amd64 
02/Apr/2015:08:54:17 +0000 DEBUG: args = {image_id : u 9247a37508136a5fe916f4f87bfa2aa47f2edf8fc1a1ce787445b606d8fdbf9f}
=== 6 秒 ===
10.180.156.11 - - [02/Apr/2015:08:54:23 +0000]  GET /v1/images/9247a37508136a5fe916f4f87bfa2aa47f2edf8fc1a1ce787445b606d8fdbf9f/layer HTTP/1.1  200 37124367  -   docker/1.5.0 go/go1.4.1 git-commit/a8a31ef kernel/3.13.0-32-generic os/linux arch/amd64 
02/Apr/2015:08:54:24 +0000 DEBUG: args = {image_id : u a92b1d9f0ca59cefd024a5f2f2d23e2d617b3e67cc2363c94998006fa87e60e5}
===42 秒 ===
02/Apr/2015:08:55:06 +0000 DEBUG: api_error: Image not found
10.180.156.11 - - [02/Apr/2015:08:55:06 +0000]  GET /v1/images/a92b1d9f0ca59cefd024a5f2f2d23e2d617b3e67cc2363c94998006fa87e60e5/json HTTP/1.1  404 28  -   docker/1.5.0 go/go1.4.1 git-commit/a8a31ef kernel/3.13.0-32-generic os/linux arch/amd64 
02/Apr/2015:08:55:06 +0000 DEBUG: args = {image_id : u a92b1d9f0ca59cefd024a5f2f2d23e2d617b3e67cc2363c94998006fa87e60e5}
10.180.156.11 - - [02/Apr/2015:08:55:06 +0000]  GET /v1/images/a92b1d9f0ca59cefd024a5f2f2d23e2d617b3e67cc2363c94998006fa87e60e5/json HTTP/1.1  200 1172  -   docker/1.5.0 go/go1.4.1 git-commit/a8a31ef kernel/3.13.0-32-generic os/linux arch/amd64 
02/Apr/2015:08:55:07 +0000 DEBUG: args = {image_id : u a92b1d9f0ca59cefd024a5f2f2d23e2d617b3e67cc2363c94998006fa87e60e5}
=== 2 秒 ===
10.180.156.11 - - [02/Apr/2015:08:56:08 +0000]  GET /v1/images/a92b1d9f0ca59cefd024a5f2f2d23e2d617b3e67cc2363c94998006fa87e60e5/layer HTTP/1.1  200 420084375  -   docker/1.5.0 go/go1.4.1 git-commit/a8a31ef kernel/3.13.0-32-generic os/linux arch/amd64

可以發現,對于一個 2 層的鏡像,整個 pull 的時間可以分成幾段

操作耗時百分比 get json16s5.1%get layer142s36.2%get json20s0%get layer22s1.7% 總耗時 116s100%

對比直接從 registry 上 get 測試

# time curl -X GET -H  Transfer-Encoding: chunked  -o layer-9247a-down  http://10.180.156.6:5000/v1/images/9247a37508136a5fe916f4f87bfa2aa47f2edf8fc1a1ce787445b606d8fdbf9f/layer 
 % Total % Received % Xferd Average Speed Time Time Time Current
 Dload Upload Total Spent Left Speed
100 35.4M 100 35.4M 0 0 25.3M 0 0:00:01 0:00:01 --:--:-- 25.3M
real 0m1.409s
user 0m0.036s
sys 0m0.233s
# time curl -X GET -H  Transfer-Encoding: chunked  -o layer-a92b1-down  http://10.180.156.6:5000/v1/images/a92b1d9f0ca59cefd024a5f2f2d23e2d617b3e67cc2363c94998006fa87e60e5/layer 
 % Total % Received % Xferd Average Speed Time Time Time Current
 Dload Upload Total Spent Left Speed
100 400M 100 400M 0 0 19.2M 0 0:00:20 0:00:20 --:--:-- 24.5M
real 0m20.771s
user 0m0.381s
sys 0m2.501s

感謝你能夠認真閱讀完這篇文章,希望丸趣 TV 小編分享的“docker 中 pull 和 push 的性能有什么不同”這篇文章對大家有幫助,同時也希望大家多多支持丸趣 TV,關注丸趣 TV 行業資訊頻道,更多相關知識等著你來學習!

正文完
 
丸趣
版權聲明:本站原創文章,由 丸趣 2023-08-16發表,共計9369字。
轉載說明:除特殊說明外本站除技術相關以外文章皆由網絡搜集發布,轉載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 台中县| 兴国县| 台东县| 顺义区| 朝阳市| 铅山县| 九江市| 山东省| 若尔盖县| 潮安县| 石棉县| 双峰县| 乌兰察布市| 康马县| 锡林郭勒盟| 承德市| 栖霞市| 壤塘县| 阿瓦提县| 镇平县| 三亚市| 左权县| 犍为县| 吴堡县| 呼和浩特市| 衡东县| 太谷县| 辉南县| 兰溪市| 竹山县| 平和县| 保德县| 定日县| 沙坪坝区| 定结县| 东乡县| 高尔夫| 双流县| 库尔勒市| 崇仁县| 鹤壁市|