docker(六)企业级Docker镜像仓库harbor的部署和使用

什么是harbor?

Harbor是一个用于存储和分发Docker镜像的企业级Registry服务器。
镜像的存储harbor使用的是官方的docker registry(v2命名是distribution)服务去完成。
harbor在docker distribution的基础上增加了一些安全、访问控制、管理的功能以满足企业对于镜像仓库的需求。
harbor以docker-compose的规范形式组织各个组件,并通过docker-compose工具进行启停。

docker的registry用本地存储或者s3都可以的,harbor的功能是在此之上提供用户权限管理、镜像复制等功能,提高使用的registry的效率。Harbor的镜像拷贝功能是通过docker registry的API去拷贝,这种做法屏蔽了繁琐的底层文件操作、不仅可以利用现有docker registry功能不必重复造轮子,而且可以解决冲突和一致性的问题。

Harbor是VMware公司开源了企业级Registry项目, 其的目标是帮助用户迅速搭建一个企业级的Docker registry服务。它以Docker公司开源的registry为基础,额外提供了如下功能:

基于角色的访问控制(Role Based Access Control)
基于策略的镜像复制(Policy based image replication)
镜像的漏洞扫描(Vulnerability Scanning)
AD/LDAP集成(LDAP/AD support)
镜像的删除和空间清理(Image deletion & garbage collection)
友好的管理UI(Graphical user portal)
审计日志(Audit logging)
RESTful API
部署简单(Easy deployment)

安装(基于上一篇博客)

docker部署
(1)下载docker
(2)加密,生成证书

[root@server3 ~]# mkdir /etc/docker/certs
[root@server3 ~]# openssl req -newkey rsa:4096 -nodes -sha256 -keyout certs/westos.org.key -x509 -days 365 -out certs/westos.org.crt

(3)生成用户的认证文件

[root@server3 ~]# mkdir /etc/docker/auth
[root@server3 ~]# docker run --rm --entrypoint htpasswd registry:2 -Bbn lx redhat > auth/htpasswd
[root@server3 ~]# docker run --rm --entrypoint htpasswd registry:2 -Bbn admin westos >> auth/htpasswd   #追加
[root@server3 ~]# cat auth/htpasswd 

(4)运行容器。

[root@server3 ~]# docker run -d \
> --restart=always \
> --name registry \
> -v "$(pwd)"/certs:/certs \
>  -e REGISTRY_HTTP_ADDR=0.0.0.0:443 \
> -e REGISTRY_HTTP_TLS_CERTIFICATE=/certs/westos.org.crt \
> -e REGISTRY_HTTP_TLS_KEY=/certs/westos.org.key \
> -p 443:443 \
> -v "$(pwd)"/auth:/auth \
> -e "REGISTRY_AUTH=htpasswd" \
> -e "REGISTRY_AUTH_HTPASSWD_REALM=Registry Realm" \
> -e REGISTRY_AUTH_HTPASSWD_PATH=/auth/htpasswd \
> registry
把物理机的证书和认证的文件挂接到容器内   --name 不加会有随机名称
本地的路径 挂接到容器内 后面的证书 密码 都是容器内的 没有会自动生成
先加密 后认证 也可以加密认证一起做

(5)拷贝证书到指定目录
docker(六)企业级Docker镜像仓库harbor的部署和使用_第1张图片
(6)添加解析
docker(六)企业级Docker镜像仓库harbor的部署和使用_第2张图片

以上都在上一篇博客写过。

docker-compose的部署
(1)下载,授予执行权限
docker(六)企业级Docker镜像仓库harbor的部署和使用_第3张图片
Harbor的搭建

(1)上传harbor包并修改配置文件
在这里插入图片描述
docker(六)企业级Docker镜像仓库harbor的部署和使用_第4张图片
(2)执行./prepare,更新一下配置文件
docker(六)企业级Docker镜像仓库harbor的部署和使用_第5张图片
(3)执行./install.sh,开始安装并启动
docker(六)企业级Docker镜像仓库harbor的部署和使用_第6张图片
docker(六)企业级Docker镜像仓库harbor的部署和使用_第7张图片
docker(六)企业级Docker镜像仓库harbor的部署和使用_第8张图片
docker(六)企业级Docker镜像仓库harbor的部署和使用_第9张图片

以上就部署成功了
上传测试:
docker(六)企业级Docker镜像仓库harbor的部署和使用_第10张图片
docker(六)企业级Docker镜像仓库harbor的部署和使用_第11张图片
下载测试:
docker(六)企业级Docker镜像仓库harbor的部署和使用_第12张图片

你可能感兴趣的:(企业运维)