镜像仓库Harbor的搭建与理解

2018-06-30  本文已影响0人  初级赛亚人

简介

Harbor是一个用于存储和分发Docker镜像的企业级Registry服务器,通过添加一些企业必需的功能特性,例如安全、标识和管理等,扩展了开源Docker Distribution。作为一个企业级私有Registry服务器,Harbor提供了更好的性能和安全。提升用户使用Registry构建和运行环境传输镜像的效率。Harbor支持安装在多个Registry节点的镜像资源复制,镜像全部保存在私有Registry中, 确保数据和知识产权在公司内部网络中管控。另外,Harbor也提供了高级的安全特性,诸如用户管理,访问控制和活动审计等。


注:对于以下的操作,建议在linux系统上进行,如Ubuntu,CentOS等;若你要在mac上进行,也建议你在mac上启动的一个linux的docker容器中进行安装,即使mac对于开发人员来说的确方便了很多,但是在部署一个平台的时候,总是会遇到各种各样的坑;windows用户同样在docker中搭建;我在mac上部署harbor时遇到很多坑,本文不会提及这些坑,也不会有写相应的解决方法解决这些坑

Harbor的安装

Harbor在github上的地址,从readme.md中可以知道安装的方式分为

至于Online installer和OVA installer这两种搭建方式,本文不会提及,有兴趣的同学可以自己尝试,相信在看完本文之后你也可以完成自己的Harbor仓库的搭建。

Offline installer

在官方的发布版本中,找到一个最新的发布版本(本文写与2018.06.29,官方version为1.5.1)
下载之后会得到一个类似于harbor-offline-installer-v1.5.1.tgz的文件,用命令

tar zxvf harbor-offline-installer-vx.x.x.tgz harbor

将其解压到harbor文件中。

harbor文件夹分析

打开解压之后的harbor文件,会发现主要有以下一些文件

配置harbor.cfg

由于harbor.cfg配置内容众多,不同版本的harbor.cfg也不尽相同,所以此处不列出来,只提一些重要的,以及在部署中会用到的做讲解。

注:secretkey_path的值对于新手来说不建议更改,否则在启动harbor时会发现部分容器的状态始终为unhealthy,若要修改也是可以的,文章后会提及

安装

如果一切顺利,此时你访问你所配置的hostname,应该能顺利访问harbor的主页面了,密码如果没有在harbor.cfg里面更改过,那么账号密码默认是admin/Harbor12345

Https的配置

理解

这里主要理解harbor下的ui服务,它会对我们之后使用docker-compose进行项目部署有很好的启发作用,尤其是前后端分离的项目,以及多个容器之间的数据交互。

打开harbor项目所在的目录,使用命令

docker-compose ps

可看到类似于如下内容


harbor.png

可以看到harbor-ui这个容器的Command是/harbor/start.sh,我们用命令

docker-compose exec ui /bin/bash

进入harbor-ui容器看看它这个start.sh做了些什么;注意这里的命令使用ui而不是harbor-ui的原因是因为docker-compose exec进入的是一个service,而harbor-ui这个容器在docker-compose.yml中是一个名为ui的service


/harbor/start.sh

这就是harbor的搭建和理解,由这篇文章衍生的docker-compose的项目部署已写好

上一篇 下一篇

猜你喜欢

热点阅读