实验环境:

CentOS7  1611

Docker  1.12.6

registry    2.0

1、安装并运行registry

安装:

[root@docker01 ~]# docker pull registry

Using default tag: latest

Trying to pull repository docker.io/library/registry ...

latest: Pulling from docker.io/library/registry

79650cf9cc01: Pull complete

70ce42745103: Pull complete

77edd1a7fa4d: Pull complete

432773976ace: Pull complete

3234a47fe5a9: Pull complete

Digest: sha256:a3551c422521617e86927c3ff57e05edf086f1648f4d8524633216ca363d06c2

[root@docker01 ~]# docker images

REPOSITORY           TAG                 IMAGE ID            CREATED             SIZE

docker.io/busybox    latest              c30178c5239f        6 days ago          1.106 MB

docker.io/registry   latest              9d0c4eabab4d        6 weeks ago         33.17 MB

[root@docker01 ~]#

运行:

[root@docker01 ~]# docker run -d -p 5000:5000 -v /mnt/date/registry:/var/lib/registry registry

75841a99e1fc882617bc37d088a8c80abae225cfe2842110f2049600df560a47

[root@docker01 ~]#

-d后台运行

-p指定端口

-v把registry的镜像路径/var/lib/registry映射到本机的/mnt/date/registry

检查5000端口

netstat -an | grep 5000

[root@docker01 ~]# netstat -an | grep 5000

tcp6       0      0 :::5000                 :::*                    LISTEN

[root@docker01 ~]#

telnet 127.0.0.1 5000成功。

[root@docker01 ~]# telnet 127.0.0.1 5000

Trying 127.0.0.1...

Connected to 127.0.0.1.

Escape character is '^]'.

q

HTTP/1.1 400 Bad Request

Content-Type: text/plain

Connection: close

400 Bad RequestConnection closed by foreign host.

[root@docker01 ~]#

2、添加tag标记

[root@registry ~]# docker tag busybox 10.100.50.120:5000/busybox

[root@registry ~]# docker images

REPOSITORY                   TAG                 IMAGE ID            CREATED             SIZE

10.100.50.122:5000/busybox   latest              c30178c5239f        6 days ago          1.106 MB

docker.io/busybox            latest              c30178c5239f        6 days ago          1.106 MB

docker.io/registry           latest              9d0c4eabab4d        6 weeks ago         33.17 MB

[root@registry ~]#

3、上传镜像报错

[root@registry xinetd.d]# docker push 10.100.50.120:5000/busybox

The push refers to a repository [10.100.50.122:5000/busybox]

Get https://10.100.50.120:5000/v1/_ping: http: server gave HTTP response to HTTPS client

[root@registry xinetd.d]#

解决方案:

修改/etc/sysconfig/docker文件,并重新启动docker服务。

ADD_REGISTRY='--add-registry 10.100.50.120:5000'

INSECURE_REGISTRY='--insecure-registry 10.100.50.120:5000'

4、上传镜像

[root@registry ~]# docker push 10.100.50.120:5000/busybox

The push refers to a repository [10.100.50.120:5000/busybox]

3a1dff9afffd: Pushed

latest: digest:     sha256:be3c11fdba7cfe299214e46edc642e09514dbb9bbefcd0d3836c05a1e0cd0642 size: 527

[root@registry ~]#

其他坑:

坑1:

IPV4 forwording报错,但是容器运行正常。

[root@registry mnt]# docker run -d -p 5000:5000 -v /mnt/date/registry registry

WARNING: IPv4 forwarding is disabled. Networking will not work.

970e18480c47661fd2cffab9f7e0410989e62ed9d229333cb32e5727a2e88b3b

[root@registry mnt]#

解决方案:

在/etc/sysctl.conf文件中加入net.ipv4.ip_forward=1并重启网络服务。

修改后正常:

[root@registry mnt]# docker run -d -p 5000:5000 -v /mnt/date/registry registry

abbec57e5dca734689cfd953f27564156ec24e32ae6e532043309f0332653650

[root@registry mnt]# docker ps

CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                    NAMES

abbec57e5dca        registry            "/entrypoint.sh /etc/"   31 seconds ago      Up 30 seconds       0.0.0.0:5000->5000/tcp   compassionate_mclean

[root@registry mnt]#

坑2:

查看镜像存放位置显示404 page not found网上很多教程都是下面这个命令

[root@docker01 ~]# curl http://10.100.50.122:5000/v2/search

404 page not found

通过docker search registry发现安装的是2.0版本。

V2的命令格式如下:

http://10.100.50.122:5000/v2/_catalog[root@docker01 ~]# curl -X GET

{"repositories":["busybox","centos"]}

[root@docker01 ~]#

http://www.jianshu.com/p/fc36368b5c44文档:

docker私有库搭建过程(Registry)的更多相关文章

  1. docker学习---搭建Docker私有库及删除库内镜像

    环境准备系统: cat /etc/redhat-release CentOS Linux release (Core) 主机两台,分别是docker私有库服务器(IP 192.168.121.121) ...

  2. 建立docker私有库(docker registry)(转)

    建立docker私有库(docker registry) 博客分类: docker   我的目标还是无互联网安装,部署内部的docker私有库,目前docker镜像的获得还是需要互联网,将下载好的do ...

  3. 代理上网环境配置docker私有库

    最后更新时间:2018年12月27日 Docker使用代理上网去 pull 各类 images,需要做如下配置: 创建目录: /etc/systemd/system/docker.service.d ...

  4. ubuntu npm 私有库搭建 (npmjs.org 官方版本)

    目标 npm.xxx.com 安装和推送nodejs包 npmui.xxx.com 管理已经推送的nodejs包   安装 couchdb   https://launchpad.net/~couch ...

  5. 基础架构之Docker私有库

    由于项目要容器化,所有搭建自己的镜像库也是很有必要的,不然发到直接使用官方的镜像库,速度绝对能让你头疼,这篇文章就介绍搭建自己的镜像私有库. (一)  环境要求 Centos 7.5.1804 Doc ...

  6. 简体字冯|docker-安装docker私有库

    原创文章,转载请注明出处. 作者:简体字丶冯; QQ:564372931 安装docker 各终端安装docker 教程 菜鸟docker教程 就挺好,本着不重复造轮子的原则就不深入了,自己学习. 如 ...

  7. maven私有库搭建

    一.在企业中基本上都会有自己的maven私有库,主要的目的就是方便依赖包的下载.如果采用远程的方式来实现的话,很多时候会考虑网速问题.如果自己活着公司搭建的私有库,这一样在使用上面会效率更高. 二.私 ...

  8. [k8s]helm原理&私有库搭建&monocularui和kubeapp探究

    运行最简单的charts示例 helm的2个chart例子: https://github.com/kubernetes/helm/tree/master/docs/examples/nginx he ...

  9. ubuntu 14.04 https 形式安装docker 私有库 harbor

    起始目录/root,root 登陆后,直接在该目录进行下面的命令 下载harbor 预编译包 0.4.5 准备通过域名 reg.server.com 来访问镜像库所以需要在/etc/hosts 文件中 ...

随机推荐

  1. Oracle 12C 新特性之表分区或子分区的在线迁移

    Oracle 12c 中迁移表分区或子分区到不同的表空间不再需要复杂的过程.与之前版本中未分区表进行在线迁移类似,表分区或子分区可以在线或是离线迁移至一个不同的表空间.当指定了 ONLINE 语句,所 ...

  2. 拖拽系列二、利用JS面向对象OOP思想实现拖拽封装

    接着上一篇拖拽系列一.JavaScript实现简单的拖拽效果这一篇博客将接着对上一节实现代码利用JS面向对象(OOP)思维对上一节代码进行封装; 使其模块化.避免全局函数污染.方便后期维护和调用:写到 ...

  3. bitnami gitlab 配置域名

    正常安装完成以后gitlab的代码仓库域名的地址依然是IP,这样不便于我们记忆,所以我想给gitlab增加一个域名 找到gitlab.yml 配置文件,在gitlab 节点下的host 由IP变更为域 ...

  4. Android相机是如何获取到图像的

    在研究zxing的过程中,脑袋中一直有个疑惑,那个相机并没有拍照,它是怎么获取图像的 带着这个疑惑查看Camera源码 Camera源码中有这样一个接口: public interface Previ ...

  5. 面试(3)-java-se-java中的匿名内部类总结

    java中的匿名内部类总结 匿名内部类也就是没有名字的内部类 正因为没有名字,所以匿名内部类只能使用一次,它通常用来简化代码编写 但使用匿名内部类还有个前提条件:必须继承一个父类或实现一个接口 实例1 ...

  6. java中为什么实体类需要实现序列化

    当客户端访问某个能开启会话功能的资源,web服务器就会创建一个HTTPSession对象,每个HTTPSession对象都会占用一定的内存,如果在同一个时间段内访问的用户太多,就会消耗大量的服务器内存 ...

  7. Python列表(一)

    列表由一系列特定顺序排列的元素组成,在python中使用[]来表示列表,并用,来进行元素分割. >>> name_list['alben', 'james', 'harden', ' ...

  8. RGB565的理解

    一个彩色图像由R G B三个分量组成,一个RGB565的每一个像素点数据为2Byte,即16位,那么从名字上就可看出来这16位中,高5位为R分量,中间6位为G分量,低5位为B分量. 下面做了一个实验, ...

  9. AngularJs 第三节随笔

    利用$scope暴露模型数据 利用向控制器传递$scope对象的机制,可以把模型数据暴露给试图.在你的应用中可能还有其他数据,但是只有通过$scope 触及这些数据,angular才会把它当成数据模型 ...

  10. js写插件教程

    <!doctype html><html lang="en"><head>    <meta charset="UTF-8&qu ...