中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

DockerHub私有倉庫創建

發布時間:2020-07-15 18:56:44 來源:網絡 閱讀:1373 作者:Night和Drink 欄目:云計算

Docker倉庫實際上提供兩方面的功能,一個是鏡像管理,一個是認證。
前者主要由docker-registry項目來實現,通過http服務來上傳下載;后者可以通過docker-index項目或者利用現成認證方案實現http請求管理。

使用官方倉庫:簡單,但是速度慢

登陸dockerhub官網創建用戶并登陸既可使用官方提供的dockerhub空間,增加自己的userID作為上傳的根目錄實現images的版本控制
https://hub.docker.com/
http://note.youdao.com/noteshare?id=54dad70770ed572d8ba05e35f05104d2&sub=A354A2FC89EB4F1C81302EF5A186FB8F
創建后在dockers服務器上使用docker login進行登陸,登陸后即可進行倉庫的上傳下載動作

本地自建倉庫:復雜,速度快,安全

1、使用官方鏡像創建
配置文件

官方鏡像開出的registry也是一個容器,如果不指定鏡像存儲位置為一個宿主機的磁盤位置的話可能會導致鏡像丟失,所以需要用-v參數掛載本地的存儲上去
docker run -d -p 5000:5000 -v /data/docker_images:/tmp registry:0.9.1
##標紅部分可以自己指定宿主機的一個存儲位置
這種方式創建較為簡單快捷

1)在安裝有docker服務的服務器上運行:

docker run -d -p 5000:5000 -v /data/docker_images:/tmp registry:0.9.1

運行結果如下:

2)docker ps (查看正在運行中的docker容器)

3)由于第一步創建時沒有加--name參數,所以容器創建會產生一個隨機name,為了管理方便對容器進行重命名
docker rename keen_banach registry

4)查看容器對于的日志
docker logs registry(容器名或ID)

5)通過get訪問查看容器運行是否正常

curl localhost:5000

相當于瀏覽器直接訪問返回的結果(這部分返回值是由registry容器鏡像制作時dockerfile中引用決定的)

6)查看宿主機上的掛載位置:(新增了一個*.db文件)

ls /data/docker_images

內容如下:(是一條sqlite的SQL語句)

7)在本地測試上傳一個鏡像:
#docker images (查看本地的鏡像文件)

#docker tag rancher/agent:v1.2.11 10.234.2.182:5000/rancher-agent:v1(對其中一個鏡像重命名)

一頓操作,完全失敗,無法上傳,報錯404
最終確診是由于docker 1.3版本以后默認已經支持到了registry v2 版本,而v2版本會涉及到https和鑒權,所以按照原來的路徑push的話始終無法完成上傳的動作;

v2版本的dir路徑:/var/lib/registry

v1版本的dir路徑:/tmp/registry

解決方法
或者docker降級,或者registry升級到v2版本,并且重新配置,v2版本相交于v1更加合理,但是配置也更加繁瑣
8)最終解決方式使用registry v2版本代替

docker run -d -p 5000:5000 --name registry registry:latest

9)上傳鏡像

docker push 132.232.204.252:5000/rancher-agent

客戶端和服務端上傳均會報錯,報錯信息:
The push refers to repository [132.232.204.252:5000/rancher-agent]
Get https://132.232.204.252:5000/v2/: http: server gave HTTP response to HTTPS client
大致意思就是客戶端用https的請求服務端返回了http的返回
因為Docker從1.3.X之后,與docker registry交互默認使用的是https,然而此處搭建的私有倉庫只提供http服務,所以當與私有倉庫交互時就會報https錯誤。為了解決這個問題需要在啟動docker server時增加啟動參數為默認使用http訪問。
解決方法有兩種思路:
一、本地配置信任
修改docker.service文件中的start啟動項
路徑一般為:/usr/lib/systemd/system/
vim /usr/lib/systemd/system/docker.service

ExexStart=/usr/bin/dockerd -H unix:// 在改行后增加需要信任的服務端地址
--insecure-registry 127.0.0.1:5000 --insecure-registry 132.232.204.252:5000

修改后需要重新加載deamon
重啟docker服務
#systemctl daemon-reload
#systemctl restart docker.service
查看docker info 修改前后對比增加了信任的注冊registries

再進行上傳即可成功

查看倉庫web中也新增了鏡像

二、在服務端配置nginx代理,增加證書

============================================================================
docker-registry版本發展
1、2013年3月13日
docker在github上有了第一個release[3]
2、2013年7月3日
docker在github上發布了docker registry v1[4]
3、2015年1月30日
docker registry v2(項目名叫docker distribution)有了第一個release,同時停止更新docker registry v1[5]
4、2015年4月16日
docker發布docker1.6,同時正式推廣docker registry v2
在使用docker registry v2的時候需要注意,只有docker1.6以上版本才支持registry v2,但是docker是向前兼容的,我們從源代碼里可以看出,docker engine在下載鏡像的時候,會先判斷遠端倉庫是v1還是v2版,從而使用不同的下載策略,這個策略可太重要了

坑點:
1、docker的發展有兩部分,一是在2017年3月之前docker一直使用的版本命名方式是docker1.xx,這種方式的最后一個版本是docker1.13.1版本,在2017年3月,改用年分命名方式,第一版docker17.03,docker版本和redistry的結合部分在docker1.3版本發生一些變化,因為registry v2版本的出現
2、registry 建議直接使用v2版本,0.9.1是最后一個v1版本,雖然docker有向前兼容性,但是registry的v1和v2項目是完全不同的兩個項目,并且不具有兼容性

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

南涧| 砀山县| 邳州市| 安国市| 文昌市| 朔州市| 宾阳县| 屏山县| 麻阳| 黄大仙区| 祁东县| 武城县| 永修县| 手机| 年辖:市辖区| 利津县| 从江县| 齐齐哈尔市| 乐都县| 云霄县| 江津市| 孟村| 左权县| 卢氏县| 荆州市| 庄浪县| 大化| 方山县| 万全县| 长子县| 凤台县| 崇明县| 兴化市| 沛县| 江源县| 扎赉特旗| 耿马| 上蔡县| 辽阳市| 体育| 望江县|