一、Harbor简介
Harbor是一个用于存储和分发Docker镜像的企业级Registry服务器。 作为一个企业级私有 Registry 服务器,Harbor 提供了更好的性能和安全。提升用户使用 Registry 构建和运行环境传输镜像的效率。Harbor 支持安装在多个 Registry 节点的镜像资源复制,镜像全部保存在私有 Registry 中, 确保数据和知识产权在公司内部网络中管控。另外,Harbor 也提供了高级的安全特性,诸如用户管理,访问控制和活动审计等。 基于角色的访问控制 - 用户与 Docker 镜像仓库通过“项目”进行组织管理,一个用户可以对多个镜像仓库在同一命名空间(project)里有不同的权限。 镜像复制 - 镜像可以在多个 Registry 实例中复制(同步)。尤其适合于负载均衡,高可用,混合云和多云的场景。 图形化用户界面 - 用户可以通过浏览器来浏览,检索当前 Docker 镜像仓库,管理项目和命名空间。 AD/LDAP 支持 - Harbor 可以集成企业内部已有的 AD/LDAP,用于鉴权认证管理。 审计管理 - 所有针对镜像仓库的操作都可以被记录追溯,用于审计管理。 国际化 - 已拥有英文、中文、德文、日文和俄文的本地化版本。更多的语言将会添加进来。 RESTful API - RESTful API 提供给管理员对于 Harbor 更多的操控, 使得与其它管理软件集成变得更容易。 部署简单 - 提供在线和离线两种安装工具, 也可以安装到 vSphere 平台(OVA 方式)虚拟设备。
二、Harbor安装
# 请先安装docker和docker-compose systemctl restart docker # docker 版本不能太低,如果低了请升级 卸载 docker docker-client docker-common curl -fsSL https://get.docker.com/ | sh # 安装完成提示 ✔ ----Harbor has been installed and started successfully.---- # 下载harbor安装包:https://github.com/goharbor/harbor/releases tar -xzvf harbor-offline-installer-v2.3.3.tgz cd harbor cp harbor.yml.tmpl harbor.yml # 修改 harbor.yml 修改hostname为域名或ip 修改harbor_admin_password web登录页面密码 https如果不适用可以注销 data_volume 根据实际情况处理 # 页面访问 http://192.168.0111 admin/Harbor12345
设置开机启动
vi /usr/lib/systemd/system/harbor.service [Unit] Description=Harbor After=docker.service systemd-networkd.service systemd-resolved.service Requires=docker.service Documentation=http://github.com/vmware/harbor [Service] Type=simple Restart=on-failure RestartSec=5 ExecStart=/usr/bin/docker-compose -f /usr/local/harbor/docker-compose.yml up ExecStop=/usr/bin/docker-compose -f /usr/local/harbor/docker-compose.yml down [Install] WantedBy=multi-user.target
# 设置开机启动 systemctl enable harbor systemctl start harbor
三、将docker镜像上传到docker仓库
docker tag 87a94228f133 192.168.0.111/library/nginx:v1 docker login 192.168.0.111 docker push 192.168.0.111/library/nginx:v1 # 遇到的问题 Error response from daemon: Get "https://192.168.0.111/v2/": dial tcp 192.168.0.111:443: connect: connection refused # 解决方法:在客户端本机/etc/docker/daemon.json中添加insecure-registries就可以了 { "registry-mirrors": ["https://pft7f97f.mirror.aliyuncs.com"], "insecure-registries": ["192.168.0.110"] }
四、镜像仓库复制以及分布式分发