良许Linux教程网 干货合集 Linux下配置docker的本地仓库具体方法

Linux下配置docker的本地仓库具体方法

Docker是时下相当火热的技术,关于docker的介绍此处就不多说,本文主要介绍下如何在Linux下配置docker的本地仓库,有需要的小伙伴可以参考一下。

Linux下配置docker的本地仓库具体方法

一,本地安装

# yum install -y python-devel libevent-devel python-pip gcc xz-devel

# pip install docker-registry

也可以从 docker-registry (https://github.com/docker/docker-registry)项目下载源码进行安装。

二,使用官方 registry 镜像

# docker run -d -p 5000:5000 registry #将使用官方的 registry 镜像来启动本地的私有仓库,但是并没有启动,只是为你创建好

默认情况下,会将仓库存放于容器的 /tmp/registry 目录下,如果容器被删除,则数据也会丢失,所以我们可以通过 -v 参数来将镜像文件存放在本地的指定路径:

# docker run -d -p 5000:5000 -v /opt/data/registry:/tmp/registry registry  

# docker start $(docker ps -l | grep registry | awk '{print $1}')    #启动仓库

要在本地仓库上传镜像,首先需要标记一个镜像,以下标记 busybox ,由于 busybox 镜像比较小,没有的建议先下载:

# docker pull buxybox

# docker tag busybox 192.168.0.232:5000/busybox    # 对 buxybox 镜像进行标记

# docker images  #查看标记的镜像

# docker push 192.168.0.232:5000/busybox   #然后开始上传吧
2016/06/14 11:01:17 Error: Invalid registry endpoint https://192.168.0.232:5000/v1/: Get https://192.168.0.232:5000/v1/_ping: dial tcp 192.168.0.232:5000: connection refused. If this private registry supports only HTTP or HTTPS with an unknown CA certificate, please add `--insecure-registry 192.168.0.232:5000` to the daemon's arguments. In the case of HTTPS, if you have access to the registry's CA certificate, no need for the flag; simply place the CA certificate at /etc/docker/certs.d/192.168.0.232:5000/ca.crt

呵呵,报错了!因为Docker从1.3.X之后默认docker registry使用的是https,所以当用docker pull命令下载远程镜像时,如果远程docker registry是非https的时候就会报上面的错误。

为了解决这个问题需要在启动docker server时增加启动参数:

# vim /etc/sysconfig/docker #ip 换为自己的ip

other_args="--insecure-registry 192.168.0.232:5000" #默认为空的

# service docker restart #重启docker

# docker start $(docker ps -l | grep registry | awk '{print $1}') #启动 registry

# docker push 192.168.0.232:5000/busybox #然后重新上传吧,这次肯定成功

# curl http://192.168.0.232:5000/v1/search #查看上传的镜像
{"num_results": 1, "query""""results": [{"description""""name""library/busybox"}]}

注意: /v1 代表 registry 的版本,使用 docker pull 安装的默认为 v1 版本。

测试:

使用另一台机器 pull 本地的私有仓库,但是要在 private registry 上使用 SSL,另一种就是强制使用普通方式,仍然像上面一样,在配置文件中加上以下参数:

other_args="--insecure-registry 192.168.0.232:5000"

重启 docker 服务,然后 pull:

[root@sta docker]# docker pull 192.168.0.232:5000/busybox
Pulling repository 192.168.0.232:5000/busybox
437595becdeb: Download complete
437595becdeb: Pulling image (latest) from 192.168.0.232:5000/busybox
Status: Image is up to date for 192.168.0.232:5000/busybox:latest
Docker 从入门到精通(二) 搭建本地仓库Docker 从入门到精通(二) 搭建本地仓库
Docker 从入门到精通(二) 搭建本地仓库Docker 从入门到精通(二) 搭建本地仓库

以上就是良许教程网为各位朋友分享的Linux系统相关内容。想要了解更多Linux相关知识记得关注公众号“良许Linux”,或扫描下方二维码进行关注,更多干货等着你 !

img
本文由 良许Linux教程网 发布,可自由转载、引用,但需署名作者且注明文章出处。如转载至微信公众号,请在文末添加作者公众号二维码。
良许

作者: 良许

良许,世界500强企业Linux开发工程师,公众号【良许Linux】的作者,全网拥有超30W粉丝。个人标签:创业者,CSDN学院讲师,副业达人,流量玩家,摄影爱好者。
上一篇
下一篇

发表评论

联系我们

联系我们

公众号:良许Linux

在线咨询: QQ交谈

邮箱: yychuyu@163.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部