docker registry私有倉庫搭建

 

前提:已安裝好docker,不懂安裝的能夠查看個人另外一篇博客使用docker-compose編排django、mysql實戰html

系統:centos7mysql

 

1、pull registry鏡像到本地sql

docker pull registry

 

2、運行registry鏡像docker

docker run -d -p 5000:5000 -v /home/$user/registry:/var/lib/registry registry

 

3、查看registry是否成功啓動且可用django

docker ps -a #查看registry容器狀態

若是本機有圖形界面,在瀏覽器中訪問 http://127.0.0.1:5000/v1/,看到以下內容則表示registry可用centos

若是沒有圖形界面,則執行命令: curl -XGET http://127.0.0.1:5000/v2,能夠看到返回一個{}瀏覽器

 

4、修改/etc/docker/daemon.js文件配置,增長以下內容(客戶端、服務器端都須要作該配置,在本機只須要配置一次就能夠):服務器

{
    "insecure-registries": ["127.0.0.1:5000"] 
}

若是當前已有內容,則在原文件的{}裏面的末尾追加內容便可,正常狀況來講,本身搭建registry倉庫是方便多人使用,這個時候就須要增長多個insecure-registries內容,示例以下:curl

{
    "insecure-registries": ["127.0.0.1:5000""192.168.1.5:5000","xxx.cn:5000"] 
}

若是不執行該操做,在push鏡像的時候會報錯:http: server gave HTTP response to HTTPS clientui

緣由是Docker從1.3.X以後,與docker registry交互默認使用的是https,然而此處搭建的私有倉庫只提供http服務,因此當與私有倉庫交互時就會報上面的錯誤。

固然另一種解決方案就是給服務器開啓https協議

5、經過docker tag重命名鏡像

docker pull busybox #先下載最新的鏡像
docker tag busybox:latest 127.0.0.1:5000/busybox:v1 #tag

 

6、push tag後的鏡像到registry

docker push 127.0.0.1:5000/busybox:v1

7、驗證鏡像已成功push

在瀏覽器訪問:http://127.0.0.1:5000/v2/_catalog,成功時會顯示busybox

 

更多實踐能夠參考http://www.javashuo.com/article/p-zuvnktoa-bk.html

相關文章
相關標籤/搜索