【Linux】【docker】docker私服安装

前言

系统环境:Centos7、jdk1.8

docker私服:可以把项目通过dockerfile文件build成docker镜像,供其他环境拉取。部署在本地,私有化。

安装

dockerHUB私服

1. 搭建registry

 1 #拉取registry镜像
 2 [root@localhost home]# docker pull registry
 3 Using default tag: latest
 4 latest: Pulling from library/registry
 5 c87736221ed0: Pull complete 
 6 1cc8e0bb44df: Pull complete 
 7 54d33bcb37f5: Pull complete 
 8 e8afc091c171: Pull complete 
 9 b4541f6d3db6: Pull complete 
10 Digest: sha256:8004747f1e8cd820a148fb7499d71a76d45ff66bac6a29129bfdbfdc0154d146
11 Status: Downloaded newer image for registry:latest
12 
13 #查看镜像
14 [root@localhost home]# docker images
15 REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
16 registry            latest              f32a97de94e1        6 months ago        25.8MB
17 
18 #启动容器
19 [root@localhost home]# docker run -d -v /data/registry:/var/lib/registry -p 5000:5000 --restart=always --name qdockerhub registry:latest
20 67b0ac40561688b8bb874fa9674e44eb069cc6ee443127ba80b140ea51947af7
21 
22 #测试/v2/_catalog接口
23 [root@localhost home]# curl http://127.0.0.1:5000/v2/_catalog
24 {"repositories":[]}
25 [root@localhost home]# 

2. 提交镜像

 1 #拉取tomcat测试提交
 2 [root@localhost home]# docker pull tomcat
 3 Using default tag: latest
 4 latest: Pulling from library/tomcat
 5 092586df9206: Pull complete 
 6 ef599477fae0: Pull complete 
 7 4530c6472b5d: Pull complete 
 8 d34d61487075: Pull complete 
 9 272f46008219: Pull complete 
10 12ff6ccfe7a6: Pull complete 
11 f26b99e1adb1: Pull complete 
12 21bec9c8ea28: Pull complete 
13 e2f6023231f2: Pull complete 
14 c47eb491a5e3: Pull complete 
15 Digest: sha256:74e52cc6d27dacb079b273c129d6bf32df6ba328d6508b81ef65f41675ae9570
16 Status: Downloaded newer image for tomcat:latest
17 
18 #查看镜像
19 [root@localhost home]# docker images
20 REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
21 tomcat              latest              365b0a528e2e        4 days ago          506MB
22 registry            latest              f32a97de94e1        6 months ago        25.8MB
23 
24 #给镜像重命名,ip:端口/镜像名称
25 [root@localhost home]# docker tag tomcat:latest 127.0.0.1:5000/testtomcat
26 
27 #再次查看镜像
28 [root@localhost home]# docker images
29 REPOSITORY                  TAG                 IMAGE ID            CREATED             SIZE
30 127.0.0.1:5000/testtomcat   latest              365b0a528e2e        4 days ago          506MB
31 tomcat                      latest              365b0a528e2e        4 days ago          506MB
32 registry                    latest              f32a97de94e1        6 months ago        25.8MB
33 
34 #提交镜像到到docker私服
35 [root@localhost home]# docker push 127.0.0.1:5000/testtomcat
36 The push refers to repository [127.0.0.1:5000/testtomcat]
37 4a3ccf95eef9: Pushed 
38 4437177a7bda: Pushed 
39 5161954b2663: Pushed 
40 57e6a3d20ce9: Pushed 
41 1690af51cb08: Pushed 
42 5a30999619d7: Pushed 
43 2e669e0134f5: Pushed 
44 8bacec4e3446: Pushed 
45 26b1991f37bd: Pushed 
46 55e6b89812f3: Pushed 
47 latest: digest: sha256:416e93b104aa4bceff6005ec6cc4e073196f98d8e3aa4564c3f7d6ad3591d767 size: 2422
48 
49 #curl验证
50 [root@localhost home]# curl http://127.0.0.1:5000/v2/_catalog
51 {"repositories":["testtomcat"]}

3. 拉取镜像

 1 #查看镜像
 2 [root@localhost home]# docker images
 3 REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
 4 registry            latest              f32a97de94e1        6 months ago        25.8MB
 5 
 6 #拉取docker私服镜像
 7 [root@localhost home]# docker pull 127.0.0.1:5000/testtomcat
 8 Using default tag: latest
 9 latest: Pulling from testtomcat
10 092586df9206: Pull complete 
11 ef599477fae0: Pull complete 
12 4530c6472b5d: Pull complete 
13 d34d61487075: Pull complete 
14 272f46008219: Pull complete 
15 12ff6ccfe7a6: Pull complete 
16 f26b99e1adb1: Pull complete 
17 21bec9c8ea28: Pull complete 
18 e2f6023231f2: Pull complete 
19 c47eb491a5e3: Pull complete 
20 Digest: sha256:416e93b104aa4bceff6005ec6cc4e073196f98d8e3aa4564c3f7d6ad3591d767
21 Status: Downloaded newer image for 127.0.0.1:5000/testtomcat:latest
22 
23 #再次查看镜像
24 [root@localhost home]# docker images
25 REPOSITORY                  TAG                 IMAGE ID            CREATED             SIZE
26 127.0.0.1:5000/testtomcat   latest              365b0a528e2e        4 days ago          506MB
27 registry                    latest              f32a97de94e1        6 months ago        25.8MB

4.删除私服镜像

 1 # 查看当前docker私服中的镜像
 2 [root@localhost ~]# curl http://127.0.0.1:5000/v2/_catalog
 3 {"repositories":["mingbytesiteweb"]}
 4 
 5 # 查看docker私服容器,重点是 CONTAINER ID
 6 [root@localhost ~]# docker ps
 7 CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                    NAMES
 8 67b0ac405616        registry:latest     "/entrypoint.sh /etc…"   44 hours ago        Up 44 hours         0.0.0.0:5000->5000/tcp   qdockerhub
 9 
10 # 删除docker私服中的“mingbytesiteweb”镜像
11 # 其中67b0ac405616 为docker私服容器id
12 [root@localhost ~]# docker exec 67b0ac405616 rm -rf /var/lib/registry/docker/registry/v2/repositories/mingbytesiteweb
13 
14 # 清除掉blob 
15 # 67b0为docker私服容器id
16 [root@localhost ~]# docker exec 67b0 bin/registry garbage-collect /etc/docker/registry/config.yml
17 
18 0 blobs marked, 9 blobs and 0 manifests eligible for deletion
19 blob eligible for deletion: sha256:a381f92f36de52ade5b5610ef1b354713f21902b2ef32abf8f5101daf686e6b4
20 blob eligible for deletion: sha256:cce6b5d4a535e729c30f1f9140a61e5fe408250c442ad69569612094970f8035
21 blob eligible for deletion: sha256:d5c237920c394bda8bf1ef31b00bbde458f6978c159303e00d712a95c3f32a40
22 time="2019-09-20T02:53:41.576433178Z" level=info msg="Deleting blob: /docker/registry/v2/blobs/sha256/a3/a381f92f36de52ade5b5610ef1b354713f21902b2ef32abf8f5101daf686e6b4" go.version=go1.11.2 instance.id=ded69299-53f9-4ffe-9309-a707264a7549 service=registry 
23 time="2019-09-20T02:53:41.576740825Z" level=info msg="Deleting blob: /docker/registry/v2/blobs/sha256/cc/cce6b5d4a535e729c30f1f9140a61e5fe408250c442ad69569612094970f8035" go.version=go1.11.2 instance.id=ded69299-53f9-4ffe-9309-a707264a7549 service=registry 
24 time="2019-09-20T02:53:41.577819834Z" level=info msg="Deleting blob: /docker/registry/v2/blobs/sha256/d5/d5c237920c394bda8bf1ef31b00bbde458f6978c159303e00d712a95c3f32a40" go.version=go1.11.2 instance.id=ded69299-53f9-4ffe-9309-a707264a7549 service=registry 
25 blob eligible for deletion: sha256:f17d81b4b692f7e0d6c1176c86b81d9f2cb5ac5349703adca51c61debcfe413c
26 blob eligible for deletion: sha256:01fe0503c7f786c0613596ab151412f7fd68874d80c43289e5c32725ef1c52ff
27 blob eligible for deletion: sha256:082bd21a11cbf8765d11f10147dc59639118b0700c43a6eef427059faa99e939
28 blob eligible for deletion: sha256:396a68a9a5c5ed3ab7b570199a9daee6b468b5cacd4e2a6d0040e3ea7c9bb891
29 blob eligible for deletion: sha256:3ba74338e49429d19a7e6609eee9f16faa369aa30cdcc295b5382999afa3143a
30 blob eligible for deletion: sha256:5ed7726b81ebb228b250e4ef703ec976b56f8db47d5d9f82ce93ebb026fc6e5f
31 time="2019-09-20T02:53:41.58367518Z" level=info msg="Deleting blob: /docker/registry/v2/blobs/sha256/f1/f17d81b4b692f7e0d6c1176c86b81d9f2cb5ac5349703adca51c61debcfe413c" go.version=go1.11.2 instance.id=ded69299-53f9-4ffe-9309-a707264a7549 service=registry 
32 time="2019-09-20T02:53:41.58874132Z" level=info msg="Deleting blob: /docker/registry/v2/blobs/sha256/01/01fe0503c7f786c0613596ab151412f7fd68874d80c43289e5c32725ef1c52ff" go.version=go1.11.2 instance.id=ded69299-53f9-4ffe-9309-a707264a7549 service=registry 
33 time="2019-09-20T02:53:41.589391384Z" level=info msg="Deleting blob: /docker/registry/v2/blobs/sha256/08/082bd21a11cbf8765d11f10147dc59639118b0700c43a6eef427059faa99e939" go.version=go1.11.2 instance.id=ded69299-53f9-4ffe-9309-a707264a7549 service=registry 
34 time="2019-09-20T02:53:41.589628015Z" level=info msg="Deleting blob: /docker/registry/v2/blobs/sha256/39/396a68a9a5c5ed3ab7b570199a9daee6b468b5cacd4e2a6d0040e3ea7c9bb891" go.version=go1.11.2 instance.id=ded69299-53f9-4ffe-9309-a707264a7549 service=registry 
35 time="2019-09-20T02:53:41.589939086Z" level=info msg="Deleting blob: /docker/registry/v2/blobs/sha256/3b/3ba74338e49429d19a7e6609eee9f16faa369aa30cdcc295b5382999afa3143a" go.version=go1.11.2 instance.id=ded69299-53f9-4ffe-9309-a707264a7549 service=registry 
36 time="2019-09-20T02:53:41.590973494Z" level=info msg="Deleting blob: /docker/registry/v2/blobs/sha256/5e/5ed7726b81ebb228b250e4ef703ec976b56f8db47d5d9f82ce93ebb026fc6e5f" go.version=go1.11.2 instance.id=ded69299-53f9-4ffe-9309-a707264a7549 service=registry 
  # 删除完成
37 [root@localhost ~]# curl http://127.0.0.1:5000/v2/_catalog 38 {"repositories":[]}

错误集合

a. 运行错误1

错误提示: [root@izj6c0zsm04q86s2tu4e12z /]# docker run -it docker.io/ubuntu:latest /bin/bash
/usr/bin/docker-current: Error response from daemon: oci runtime error: container_linux.go:235: starting container process caused "process_linux.go:258: applying cgroup configuration for process caused "Cannot set property TasksAccounting, or unknown property."".

解决办法: yum update

b. 私有仓库push错误(改配置后一定要重启docker)

  • docker私有仓库的5000端口是否在防火墙中打开

  • daemon.json文件中提交镜像的地址是否修改为私有docker仓库的地址

  • 添加镜像仓库地址insecure-registries参数,内容修改如下:

vim /etc/docker/daemon.json
{
    "registry-mirrors":["https://registry.docker-cn.com"],
     "insecure-registries":["47.240.32.247:5000"]
}       

[root@localhost bin]# systemctl daemon-reload
[root@localhost bin]# systemctl restart docker

 
原文地址:https://www.cnblogs.com/jxd283465/p/11542206.html