詳解Docker私有倉(cāng)庫(kù)最簡(jiǎn)便的搭建方法
Doker 在業(yè)界的應(yīng)用越來(lái)越廣泛,怎么用戶(hù)管理好自己的鏡像、容器等就是一個(gè)迫在眉睫的任務(wù)。
由于業(yè)務(wù)需要,我們需要在搭建一套自己的 Docker 私有鏡像倉(cāng)庫(kù),網(wǎng)上找了很多,都是說(shuō)要 pull 一個(gè) regisitry 鏡像,然后通過(guò)這個(gè)鏡像啟動(dòng)一個(gè)容器來(lái)運(yùn)行倉(cāng)庫(kù)應(yīng)用,我按照官網(wǎng)的說(shuō)明 pull 了一個(gè) registry ,但是啟動(dòng)的時(shí)候有報(bào)錯(cuò),具體是什么就不細(xì)說(shuō)了,反正是有錯(cuò),于是開(kāi)始研究別的方法,別說(shuō)還真找到了一個(gè),而且是我發(fā)現(xiàn)的最簡(jiǎn)便的辦法,我不知道我是不是國(guó)內(nèi)第一個(gè)發(fā)現(xiàn)的,但我應(yīng)該是第一個(gè)寫(xiě)出來(lái)給大家參考的。
下面不廢話(huà),直接說(shuō)方法:
- 首先,你的系統(tǒng)要是 CentOS 7.0 以上,因?yàn)閮?nèi)核的要求,以及各種相關(guān)的庫(kù)和軟件的需要,以及 epel 的需要。
- 直接安裝 docker-registry 這個(gè)包。
- 稍微修改一下配置,讓你的私有倉(cāng)庫(kù)支持 http,因?yàn)閺?docker1.3.2 開(kāi)始,docker registry 默認(rèn)都是使用 https 協(xié)議而不使用 http,甭管你從 docker hub 上找你需要的鏡像,還是你自己打出來(lái)的 private registry。
- 重啟相關(guān)的 docker 服務(wù)。
- 測(cè)試及使用。
下面就詳細(xì)列一下每一步的步驟:
使用 CentOS 7.X 系統(tǒng),添加 epel 源,并更新系統(tǒng)到最新版本,重啟讓新的內(nèi)核生效。
#wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo #yum clean all #yum makecache #yum update -y #reboot
安裝 docker 相關(guān)的服務(wù),其中 docker-registry 這個(gè)最重要,因?yàn)檫@就是私有倉(cāng)庫(kù)的服務(wù),有了這個(gè)服務(wù)就不需要像網(wǎng)上一樣去 pull 鏡像,然后再起一個(gè)容器。
#yum install docker docker-registry -y
如果不需要開(kāi)發(fā)相關(guān)的接口調(diào)用程序,這兩個(gè)就夠了,如果需要開(kāi)發(fā)就直接安裝所有的 docker 包,一共也沒(méi)幾個(gè)。但是最好把 docker-latest 和 docker-latest-logrotate 兩個(gè)包卸載掉,因?yàn)檫@倆是 docker 客戶(hù)端,版本是 1.12 跟 server 的版本 1.10 不是太匹配。
#yum install docker* -y #yum remove docker-latest* -y
把 docker 的兩個(gè)服務(wù)設(shè)置為自動(dòng)啟動(dòng),并讓其運(yùn)行。
#systemctl enable docker #systemctl start docker #systemctl enable docker-registry #systemctl start docker-registry
查看一下本機(jī)監(jiān)聽(tīng)的端口,是不是有5000這個(gè)端口了?5000端口就是默認(rèn)的 docker-registry 監(jiān)聽(tīng)端口,當(dāng)然,這個(gè)你可以根據(jù)自己喜歡進(jìn)行修改。
[root@01 /]# netstat -tnlp Active Internet connections (only servers) Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 1109/sshd tcp 0 0 127.0.0.1:25 0.0.0.0:* LISTEN 1384/master tcp 0 0 0.0.0.0:5000 0.0.0.0:* LISTEN 20437/python tcp6 0 0 :::22 :::* LISTEN 1109/sshd tcp6 0 0 ::1:25 :::* LISTEN 1384/master
測(cè)試一下是不是能通過(guò)網(wǎng)絡(luò)進(jìn)行訪問(wèn)了?
[root@01 /]# curl "http://192.168.1.107:5000" "\\"docker-registry server\\""[root@01 /]# [root@01 /]#
既然可以訪問(wèn)了,那就往這上面 push 一個(gè)鏡像來(lái)測(cè)試一下吧。這個(gè)需要你首先 tag 一個(gè)鏡像,然后才能 push 上去。以我目前的已經(jīng)有的鏡像為例。
[root@01 /]# docker tag cfba59e097ba 192.168.1.107:5000/test1 [root@01 /]# docker images REPOSITORY TAG IMAGE ID CREATED SIZE 192.168.1.107:5000/test1 latest ac0b483c17fa 3 days ago 634.6 MB docker.io/redmine latest cfba59e097ba 3 days ago 634.6 MB docker.io/registry latest c9bd19d022f6 2 weeks ago 33.27 MB [root@01 /]#
現(xiàn)在 push 的話(huà)有報(bào)錯(cuò),如下。
[root@01 /]# docker pull 192.168.1.107:5000/test1 Using default tag: latest Trying to pull repository 192.168.1.107:5000/test1 ... unable to ping registry endpoint https://192.168.1.107:5000/v0/ v2 ping attempt failed with error: Get https://192.168.1.107:5000/v2/: EOF v1 ping attempt failed with error: Get https://192.168.1.107:5000/v1/_ping: EOF [root@01 /]#
但是基本上一眼就能看出來(lái),地址里都是 https,而我現(xiàn)在能訪問(wèn)的只是 http,所以,就需要解決啟用 http 的問(wèn)題,因?yàn)槲业男枨笫窃趦?nèi)網(wǎng)里搭建,外網(wǎng)無(wú)法訪問(wèn),何必要加密,只會(huì)拖慢速度。接下來(lái)就是修改對(duì)應(yīng)的配置文件,啟用 http ,這個(gè)配置文件也是有說(shuō)這個(gè)有說(shuō)那個(gè)的,下面的才是正確的配置文件,親測(cè)有效,如下。
[root@01 /]# vim /etc/sysconfig/docker
把下面這一行添加進(jìn)去。
OPTIONS='--insecure-registry 192.168.1.107:5000'
重啟 docker 服務(wù)。
[root@01 /]# systemctl restart docker docker-registry
再次 push,成功完成。
[root@01 system]# docker push 192.168.1.107:5000/test1 The push refers to a repository [192.168.1.107:5000/test1] 07c28c5d0371: Image successfully pushed 6365a80ad26a: Image successfully pushed c5e7c0f1d017: Image successfully pushed b45f06d28f46: Image successfully pushed 3f3c0394ba5a: Image successfully pushed ddd6e2a8209e: Image successfully pushed f306cb9361f7: Image successfully pushed 2d143a3783bc: Image successfully pushed f110684b8ae3: Image successfully pushed d7d24df90586: Image successfully pushed e26addf75a78: Image successfully pushed 82c666956815: Image successfully pushed 9a2b1c643e93: Image successfully pushed eb9546f264dc: Image successfully pushed f96222d75c55: Image successfully pushed Pushing tag for rev [cfba59e097ba] on {http://192.168.1.107:5000/v1/repositories/test1/tags/latest} [root@01 system]#
既然成功了,就往下 pull 一下試試,看看能不能讓別的機(jī)器用,結(jié)果當(dāng)然也是成功的,因?yàn)槲乙呀?jīng) pull 過(guò)了,所以顯示鏡像已經(jīng)存在,如下。
[root@01 /]# docker pull 192.168.1.107:5000/test1 Using default tag: latest Trying to pull repository 192.168.1.107:5000/test1 ... Pulling repository 192.168.1.107:5000/test1 cfba59e097ba: Already exists f96222d75c55: Already exists d17727727b61: Already exists 92db66c8ffce: Already exists 10a436a2f8fa: Already exists 8b40995a66da: Already exists a2cba87d9ea4: Already exists 5a187c7a57c4: Already exists d15f50d30606: Already exists 4366383cdf86: Already exists c7cb938f30c3: Already exists f135d604f740: Already exists 3f3d23c69aef: Already exists e6adcc9c0e4b: Already exists 53289b480679: Already exists Status: Image is up to date for 192.168.1.107:5000/test1:latest 192.168.1.107:5000/test1: this image was pulled from a legacy registry. Important: This registry version will not be supported in future versions of docker. [root@01 /]#
至此,簡(jiǎn)單的私有倉(cāng)庫(kù)已經(jīng)搭建完畢,后續(xù)如果有需求要在公網(wǎng)上提供服務(wù)的話(huà),加 SSL 證書(shū),加用戶(hù)名/密碼等操作按部就班地去完成就行了。IT 技術(shù)更新很快,可能之前還沒(méi)有這個(gè)服務(wù),只是最近才有,所以,選了這一行就需要一輩子不斷學(xué)習(xí)不斷進(jìn)步才能站在橋頭迎風(fēng)斬浪。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Docker搭建本地私有倉(cāng)庫(kù)的詳細(xì)步驟
- Docker Registry 私有倉(cāng)庫(kù)搭建詳細(xì)步驟
- 詳解docker私有倉(cāng)庫(kù)搭建與使用實(shí)戰(zhàn)
- Docker 搭建私有倉(cāng)庫(kù)(registry、harbor)
- 詳解Docker私有倉(cāng)庫(kù)Registry的搭建驗(yàn)證
- Centos 7中Docker私有倉(cāng)庫(kù)的搭建方法
- 搭建Docker私有倉(cāng)庫(kù)(自簽名方式)
- Docker搭建私有倉(cāng)庫(kù)(registry與Harbor)的實(shí)現(xiàn)
- docker私有倉(cāng)庫(kù)的搭建和使用詳解
- 如何搭建配置Docker私有倉(cāng)庫(kù)的實(shí)現(xiàn)步驟
相關(guān)文章
使用docker創(chuàng)建集成服務(wù)lnmp環(huán)境
本篇文章主要介紹了使用docker創(chuàng)建集成服務(wù)lnmp環(huán)境,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-04-04解決Docker中的error during connect異常情況
這篇文章主要介紹了解決Docker中的error during connect異常情況,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11使用docker構(gòu)建一個(gè)redis鏡像的方法詳解
Redis是一個(gè)開(kāi)源的使用ANSI C語(yǔ)言編寫(xiě)、支持網(wǎng)絡(luò)、可基于內(nèi)存亦可持久化的日志型、Key-Value型NoSQL數(shù)據(jù)庫(kù),本文介紹了docker創(chuàng)建redis鏡像的方法,分享給大家,需要的朋友可以參考下2024-06-06windows server 2016安裝docker的方法步驟
這篇文章主要介紹了windows server 2016安裝docker的方法步驟,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-06-06如何使用docker+frp進(jìn)行內(nèi)網(wǎng)穿透
這篇文章主要介紹了使用docker+frp進(jìn)行內(nèi)網(wǎng)穿透,在公網(wǎng)上的ubuntu系統(tǒng)需要配置相關(guān)操作,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2024-04-04