微服务之docker本地仓库搭建过程

编程

Docker 是一个开源的应用容器引擎,基于Go 语言并遵从 Apache2.0 协议开源。

Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。

容器是完全使用沙箱机制,相互之间不会有任何接口(类似 iPhone 的 app),更重要的是容器性能开销极低。

Docker的镜像是存放在镜像仓库的,镜像仓库有开源的,叫Docker Hub,我们也可以上传自己的私有镜像到Docker hub ,虽然我们有自己的私有repository,但有些镜像是需要收费的。因此我们有必要搭建自己的私有仓库地址。

私有仓库地址需要一个叫Registry的东东,这个东西目前也被官网开源了,我们可以直接从Docker hub上拉取下来,放到本地,然后做一些操作,做一些修改达到私有仓库的目的。

一、部署Registry

运行容器拉取命令 docker pull registry

将会看到如上图标红所示的registry,已经拉取的本地了,并且默认仓库地址为:docker.io 也就是官网仓库地址。

二、运行容器

执行运行容器命令  docker run -d -p 5000:5000 -v /opt/apps/myregistry:/var/lib/registry/ docker.io/registry

运行registry镜像,得到如上图标红效果,表示registry已经成功运行起来

命令参数解释:

-d 是后台启动容器。

-p 将容器的 5000 端口映射到 Host 的 5000 端口,5000 是 registry 服务端口。

-v 将容器 /var/lib/registry 目录映射到 Host 的 /opt/apps/registry:,用于存放镜像数据。

上传的镜像数据保存在如下所示的贴图目录下面:
 

我们可以访问一下改地址:

http://192.168.1.101:5000/v2/_catalog , 我们可以看到现在本地仓库中已经有的几个镜像包了。

三、举例说明

经过上述几个步骤,我们已经成功将本地host仓库建好,那么我们应该如何才能将打包好的镜像文件推送到本地仓库呢?下面我们就拿一个例子说明一下,

简单演示一下如何将新构建的docker镜像文件推送到本地仓库。

如上图,我们就拿之前创建的docker.io/busybox为例,现在我们重新构建一个版本

执行命令  docker tag docker.io/busybox 127.0.0.1:5000/busybox:1.1  得到如下贴图:

说明:

执行上述命令之后,说明已经将busybox重新改名了,改成busybox:1.1,这样是为了区分原先的busybox

需要注意的是镜像命名有个规则:

[registry-host]:[port]/[username]/tag

registry-host:表示镜像仓库地址

username:表示自定义用户名

tag:则表示该镜像标签

比如:docker.io/busybox  则默认镜像仓库地址当然就表示官网了,本地的则就是127.0.0.1:5000

此时执行 docker push 127.0.0.1:5000/busybox:1.1 将该镜像推送到本地仓库中,得到如下图所示的结果:

说明之前已经在本地仓库中存在此镜像了

下面简单介绍一下,如何将已经存在的本地仓库镜像文件删除

通过 curl --header "Accept:application/vnd.docker.distribution.manifest.v2+json" -I -XGET http://192.168.1.101:5000/v2/busybox/manifests/latest 拿到镜像对应sha256值

然后执行 curl -I -XDELETE 私有仓库地址/v2/镜像名称/manifests/镜像对应sha256值

得到的是上述结果,删除失败,这也是目前我遇到的问题,没找到是啥原因,也请有志同道合的朋友欢迎提提意见。

以上是 微服务之docker本地仓库搭建过程 的全部内容, 来源链接: utcz.com/z/513363.html

回到顶部