Docker 搭建私有仓库

为什么要弄私有仓库,大多是为了速度,我们再私有仓库中的push和pull的速度是特别快的。

利用registry快速搭建

https://hub.docker.com/_/registry/

Run a local registry: Quick Version
$ docker run -d -p 5000:5000 --restart always --name registry registry:2
Now, use it from within Docker:

$ docker pull ubuntu
$ docker tag ubuntu localhost:5000/ubuntu
$ docker push localhost:5000/ubuntu

这是官方的一个小demo。下面是我自己的实践。

# 拉取registry2.0版本
[root@FantJ ~]# docker pull registry:2
Trying to pull repository docker.io/library/registry ... 
2: Pulling from docker.io/library/registry
81033e7c1d6a: Pull complete 
b235084c2315: Pull complete 
c692f3a6894b: Pull complete 
ba2177f3a70e: Pull complete 
a8d793620947: Pull complete 
Digest: sha256:672d519d7fd7bbc7a448d17956ebeefe225d5eb27509d8dc5ce67ecb4a0bce54
Status: Downloaded newer image for docker.io/registry:2
# 后台启动运行
[root@FantJ ~]# docker run -d -p 5000:5000 --restart always --name registry registry:2
ce5b8bfa6d7f535906730ea3a058b00e7cfdaaa20ea0db3c49d700a4e2c8a645
[root@FantJ ~]# docker images
REPOSITORY              TAG                 IMAGE ID            CREATED             SIZE
docker.io/openjdk       8-jre               bef23b4b9cac        2 weeks ago         443 MB
docker.io/fantj/nginx   latest              ae513a47849c        4 weeks ago         109 MB
docker.io/nginx         latest              ae513a47849c        4 weeks ago         109 MB
docker.io/registry      2                   d1fd7d86a825        4 months ago        33.3 MB
# tag 镜像
[root@FantJ ~]# docker tag docker.io/nginx 127.0.0.1:5000/nginx
# 上传到私有仓库
[root@FantJ ~]# docker push 127.0.0.1:5000/nginx
The push refers to a repository [127.0.0.1:5000/nginx]
7ab428981537: Pushed 
82b81d779f83: Pushed 
d626a8ad97a1: Pushed 
latest: digest: sha256:e4f0474a75c510f40b37b6b7dc2516241ffa8bde5a442bde3d372c9519c84d90 size: 948
[root@FantJ ~]# 

缺点:没有可视化管理工具,私有仓库服务宕机造成麻烦,没有用户管理机制、没有操作的记录功能。
优点:搭建操作简单

利用harbor搭建

下载地址:https://storage.googleapis.com/harbor-releases/release-1.5.0/harbor-offline-installer-v1.5.1.tgz

wget https://storage.googleapis.com/harbor-releases/release-1.5.0/harbor-offline-installer-v1.5.1.tgz

tar zxvf harbor-offline-installer-v1.5.1.tgz

cd harbor

修改配置harbor.cfg
hostname = fantj.top:8888 

http还是https啥的自己看着改

保存退出,直接运行install.sh

cd ..
./install.sh

注意一点:harbor默认会占用80端口,所以请确保你的80端口不被占用,那怎么修改呢?

修改配置docker-compose.yml(需要改端口再进行)

将80:80的第一个80改为自定义的端口号

我在这里改成8888端口。

然后运行install.sh

......
[Step 4]: starting Harbor ...
Creating network "harbor_harbor" with the default driver
Creating harbor-log
Creating redis
Creating registry
Creating harbor-db
Creating harbor-adminserver
Creating harbor-ui
Creating nginx
Creating harbor-jobservice

✔ ----Harbor has been installed and started successfully.----

Now you should be able to visit the admin portal at http://fantj.top:8888 . 
For more details, please visit https://github.com/vmware/harbor .

好的,成功了,我们来访问一下。


默认账号密码:
admin
Harbor12345

如果想修改,去harbor.cfg修改。

[root@FantJ harbor]# docker ps
CONTAINER ID        IMAGE                                  COMMAND                  CREATED             STATUS                   PORTS                                                                NAMES
ea66b87c5d26        vmware/harbor-jobservice:v1.5.1        "/harbor/start.sh"       7 minutes ago       Up 7 minutes                                                                                  harbor-jobservice
5fecbc47ea68        vmware/nginx-photon:v1.5.1             "nginx -g 'daemon ..."   7 minutes ago       Up 7 minutes (healthy)   0.0.0.0:443->443/tcp, 0.0.0.0:4443->4443/tcp, 0.0.0.0:8888->80/tcp   nginx
9ccfa0d137de        vmware/harbor-ui:v1.5.1                "/harbor/start.sh"       7 minutes ago       Up 7 minutes (healthy)                                                                        harbor-ui
b1f6387545d6        vmware/harbor-db:v1.5.1                "/usr/local/bin/do..."   7 minutes ago       Up 7 minutes (healthy)   3306/tcp                                                             harbor-db
6bcd46635374        vmware/registry-photon:v2.6.2-v1.5.1   "/entrypoint.sh se..."   7 minutes ago       Up 7 minutes (healthy)   5000/tcp                                                             registry
c40db866f7d2        vmware/harbor-adminserver:v1.5.1       "/harbor/start.sh"       7 minutes ago       Up 7 minutes (healthy)                                                                        harbor-adminserver
8d0ee20abfbf        vmware/redis-photon:v1.5.1             "docker-entrypoint..."   7 minutes ago       Up 7 minutes             6379/tcp                                                             redis
17c002dd8b98        vmware/harbor-log:v1.5.1               "/bin/sh -c /usr/l..."   7 minutes ago       Up 7 minutes (healthy)   127.0.0.1:1514->10514/tcp                                            harbor-log
[root@FantJ harbor]# docker images
REPOSITORY                    TAG                 IMAGE ID            CREATED             SIZE
vmware/redis-photon           v1.5.1              19245c7a4f51        3 days ago          207 MB
vmware/clair-photon           v2.0.1-v1.5.1       e7f0ab982469        3 days ago          303 MB
vmware/notary-server-photon   v0.5.1-v1.5.1       611385e920c3        3 days ago          211 MB
vmware/notary-signer-photon   v0.5.1-v1.5.1       f9e01495db0e        3 days ago          209 MB
vmware/registry-photon        v2.6.2-v1.5.1       2efae6b250b1        3 days ago          198 MB
vmware/nginx-photon           v1.5.1              90d35cd72a68        3 days ago          135 MB
vmware/harbor-log             v1.5.1              67000769dfac        3 days ago          200 MB
vmware/harbor-jobservice      v1.5.1              3f7a7987ca5b        3 days ago          194 MB
vmware/harbor-ui              v1.5.1              8dbe945233a8        3 days ago          212 MB
vmware/harbor-adminserver     v1.5.1              a11b8eb3f9d8        3 days ago          183 MB
vmware/harbor-db              v1.5.1              afa780d73279        3 days ago          526 MB
vmware/mariadb-photon         v1.5.1              59ed57632415        3 days ago          526 MB
vmware/postgresql-photon      v1.5.1              41b693c0ce50        3 days ago          221 MB
docker.io/openjdk             8-jre               bef23b4b9cac        2 weeks ago         443 MB
vmware/harbor-migrator        v1.5.0              466c57ab0dc3        4 weeks ago         1.16 GB
127.0.0.1:5000/nginx          latest              ae513a47849c        4 weeks ago         109 MB
docker.io/fantj/nginx         latest              ae513a47849c        4 weeks ago         109 MB
docker.io/nginx               latest              ae513a47849c        4 weeks ago         109 MB
vmware/photon                 1.0                 4b481ecbef2a        5 weeks ago         130 MB
docker.io/registry            2                   d1fd7d86a825        4 months ago        33.3 MB

可以看到我们的进程和镜像都多了很多的以vmware开头的(harbor是vmware公司的开源工具).

好了,开始push测试

[root@FantJ harbor]# docker tag docker.io/nginx fantj.top:8888/internet-plus/nginx
[root@FantJ harbor]# docker push fantj.top:8888/internet-plus/nginx
The push refers to a repository [fantj.top:8888/internet-plus/nginx]
Get https://fantj.top:8888/v1/_ping: dial tcp: lookup fantj.top: no such host

它提示需要用https请求才安全,解决方式有两种:
第一种:docker启动的时候添加对域名+端口的信任 --insecure-registry=xxxx.xx.xx.xx:8888
第二种:添加ssl证书,改天更新

Harbor重启

#docker-compose stop
# ./install.sh
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,794评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,050评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,587评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,861评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,901评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,898评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,832评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,617评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,077评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,349评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,483评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,199评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,824评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,442评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,632评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,474评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,393评论 2 352

推荐阅读更多精彩内容