通常情况下我们可以使用https://hub.docker.com/作为docker image的仓库,但是有些场景下,我们希望能够有本地的仓库。比如:
1,代码中含有保密的信息,比如环境的账号,密码等等;
2,代码本身作为公司的资产,不能对外公开,否则有法律风险。
在创建本地仓库之前,请确保已经在目的机器上安装了Docker。这里我们使用docker容器运行registry镜像的方式,来创建registry。
一般情况下安装的docker已经自带了registry镜像,如果没有可以从docker hub上获取。
在docker容器中启动registry镜像
docker@default:~$ run -d -p 5000:5000 localregistry registry
其中 localregistry表示此容器的名称,registry表示了镜像本身。可以运行docker ps查看结果:
docker@default:~$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
afae402eb9ae registry "/entrypoint.sh /e..." 4 hours ago Up 20 minutes 0.0.0.0:5000->5000/tcp localregistry
自动启动仓库
如果想让registry作为永久的可用仓库,应该在Docker machine重启或退出之后,设置registry仍然能够自动重启或保持使用状态。可以使用--restart=always达到此目的。
docker@default:~$ docker run -d -p 5000:5000 --restart=always --name localregistry registry
当Docker从registry获取image,或上传image到registry时,它会判断pull或push的uri的第一部分是否包含‘.’或‘:’来判断,是仓库名称还是用户名。
以localhost为例,如果url中只包含localhost,而没有‘.’或 :5000, Docker会认为localhost是用户名,效果就如同localhost/ubuntu或wxqsly/snapshot一样,此时Docker会请求默认的Docker Hub仓库。否则Docker会认为localhost代表了主机名,并且会请求到你指定的仓库。
从Docker Hub获取ubuntu镜像
docker@default:~$ docker pull ubuntu:16.04
将镜像标记为localhost:5000/my-ubuntu,这实际上给已有的镜像增加了额外的标记。当uri的第一部分为主机名(加端口),Docker在push的时候会认为第一部分为仓库的地址。如下例子将标记的镜像push到本地的仓库。
$ docker tag ubuntu:16.04 localhost:5000/my-ubuntu
$ docker push localhost:5000/my-ubuntu
参考
https://docs.docker.com/regis...
https://blog.docker.com/2013/...
https://rominirani.com/docker...
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。