
我们在上一章中生成了自己的镜像:myubuntu,这章分别将它发布到阿里云和私有仓库
- docker images
-
- REPOSITORY TAG IMAGE ID CREATED SIZE
- myubuntu 1.0 938b4fc0baf5 20 minutes ago 179MB
首先登录该网站->控制台->云服务器ECS->容器镜像服务->创建个人实例 ->创建命名空间->创建个人仓库->查看脚本及示例
开放云原生应用-云原生(Cloud Native)-云原生介绍 - 阿里云




接下来推送本地的镜像
- docker images
- #REPOSITORY TAG IMAGE ID CREATED SIZE
- #myubuntu 1.0 938b4fc0baf5 20 minutes ago 179MB
-
- docker login --username=aliyun1314127743 registry.cn-chengdu.aliyuncs.com
- #Password:
- #Login Succeeded
-
- docker tag 938b4fc0baf5 registry.cn-chengdu.aliyuncs.com/wz_study/docker_study:1.0
- docker push registry.cn-chengdu.aliyuncs.com/wz_study/docker_study:1.0
-
- #The push refers to repository [registry.cn-chengdu.aliyuncs.com/wz_study/docker_study]
- #aaf7dceefb7e: Pushed
- #9f54eef41275: Pushed
- #1.0: digest: sha256:270b01b377a1a7f0a3daac0a33ca389deeb373c53f66d76600335c4109c64864 size: 741
从远程库拉取镜像
- docker images
- #REPOSITORY TAG IMAGE ID CREATED SIZE
- #redis latest 7614ae9453d1 8 months ago 113MB
- #ubuntu latest ba6acccedd29 10 months ago 72.8MB
- #hello-world latest feb5d9fea6a5 11 months ago 13.3kB
- docker pull registry.cn-chengdu.aliyuncs.com/wz_study/docker_study:1.0
- #1.0: Pulling from wz_study/docker_study
- #7b1a6ab2e44d: Already exists
- #65a6e47fb1c7: Already exists
- #Digest: sha256:270b01b377a1a7f0a3daac0a33ca389deeb373c53f66d76600335c4109c64864
- #Status: Downloaded newer image for registry.cn-#chengdu.aliyuncs.com/wz_study/docker_study:1.0
- #registry.cn-chengdu.aliyuncs.com/wz_study/docker_study:1.0
- docker images
- #REPOSITORY TAG IMAGE ID CREATED #SIZE
- #registry.cn-chengdu.aliyuncs.com/wz_study/docker_study 1.0 938b4fc0baf5 44 minutes ago 179MB
- #redis latest 7614ae9453d1 8 months ago 113MB
- #ubuntu latest ba6acccedd29 10 months ago 72.8MB
- #hello-world latest feb5d9fea6a5 11 months ago 13.3kB
Docker Registry是官方提供的工具,可以用于构建私有镜像仓库
1.下载镜像Docker Registry
docker pull registry
2.运行Docker Registry,默认情况,仓库被创建在容器的/var/lib/registry目录下,建议自行用容器卷(下节讲)映射,方便于宿主机联调
docker run -d -p 5000:5000 -v /usr/myregistry/:/tmp/registry --privileged=true registry
3.演示修改原始Ubuntu镜像,增加ifconfig功能
- #容器外
- docker run -it ubuntu /bin/bash
-
- #容器内
- apt-get update
- apt-get install net-tools
-
- #容器外
- docker commit -m="ifconfig add" -a="wz" 8f3c3ae1e09d myubuntu:1.1
4. 看私服上有什么镜像(空的)
curl -XGET http://192.168.80.128:5000/v2/_catalog
5. 修改镜像的tag
按照公式: docker tag 镜像:Tag Host:Port/Repository:Tag
docker tag myubuntu:1.1 192.168.80.128:5000/myubuntu:1.1
6.修改配置文件使其支持http
- vim /etc/docker/daemon.json
-
- {
- "registry-mirrors": ["https://aa25jngu.mirror.aliyuncs.com"],
- "insecure-registries": ["192.168.111.162:5000"]
- }
docker默认不允许http方式推送镜像,通过配置选项来取消这个限制。====> 修改完后如果不生效,建议重启docker
7.推送到私服
docker push 192.168.80.128:5000/myubuntu:1.1
8.再次执行步骤4,查看是否推送上了
9.拉取镜像到本地
docker pull 192.168.80.128:5000/myubuntu:1.1
我们在上一节的演示中的docker run命令中使用了如下参数
-v /usr/myregistry/:/tmp/registry --privileged=true
这就代表使用了数据卷,使容器与主机共享数据。
卷就是目录或文件,存在于一个或多个容器中,由docker挂载到容器,但不属于联合文件系统,因此能够绕过Union File System提供一些用于持续存储或共享数据的特性。
Docker容器产生的数据,如果不备份,那么当容器实例删除后,容器内的数据自然也就没有了。
卷的设计目的就是数据的持久化,完全独立于容器的生存周期,因此Docker不会在容器删除时删除其挂载的数据卷。
一句话来说,有点类似我们Redis里面的rdb和aof文件,将docker容器内的数据保存进宿主机的磁盘中。
特点:
1:数据卷可在容器之间共享或重用数据
2:卷中的更改可以直接实时生效,爽
3:数据卷中的更改不会包含在镜像的更新中
4:数据卷的生命周期一直持续到没有容器使用它为止
使用格式:
docker run -it --privileged=true -v /宿主机绝对路径目录:/容器内目录 镜像名
默认情况下容器实例与主机之间数据是共享的,假如我们希望容器实例这边是只读的,可以这样设置:
docker run -it --privileged=true -v /宿主机绝对路径目录:/容器内目录:ro 镜像名
假如我们希望容器2继承容器1的卷规则呢?(容器2->容器1->主机)
docker run -it --privileged=true --volumes-from 容器1名 --name 容器2名 镜像名
怎么查看容器卷是否挂载成功呢?
docker inspect 容器ID
