一、基础设置

 1.1 安装vim、wget

yum install -y vim wget

 1.2 卸载home、扩大root

如果考虑镜像仓库是给研发团队使用,需要配置较大容量的,因为centos安装是默认只给root目录配置50G的空间。

可以根据我之前的笔记(http://www.cnblogs.com/straycats/p/7769105.html),扩大root空间。

 1.3 关闭防火墙

内部镜像库使用,为了部署方便直接关了防火墙。

systemctl stop firewalld
systemctl disable firewalld

 1.4 增加域名解析

ps.由于基于https的harbor需要使用域名,故本次部署的harbor域名为bakreg.cn

# 修改host文件

vim /etc/hosts

# 修改下面的内容,wq保存。

127.0.0.1   localhost bakreg.cn localhost4 localhost4.localdomain4

 1.5 设置主机名

# 这里将主机名设置和内部域名一样。

hostnamectl --static set-hostname bakreg.cn

 1.6 重启OS

reboot

 二、安装docker、docker-compose

由于Harbor是基于Docker Registry V2版本,所以就要求Docker版本不小于1.10.0,Docker-compose版本不小于1.6.0。

 2.1 安装docker

yum install -y docker

 2.2 设置docker镜像加速

墙的缘故,访问docker hub不够稳定,故需要设置镜像加速器来解决这个问题。
 这里使用的是阿里云的镜像加速器。登录阿里云后,访问https://cr.console.aliyun.com/#/accelerator

 2.3 启动、开机启动docker

systemctl start docker
systemctl enable docker

 2.4 安装epel

yum install -y epel-release

 2.5 安装pip 

yum install -y python-pip

 2.6 安装docker-compose 

pip install docker-compose

 2.7 查看版本

docker --version
docker-compose --version

 三、添加CA证书

ps.如果需要搭建基于https的harbor需要添加ca证书,如果搭建的是基于http可以跳过该步骤。

# 创建目录/root/cert/

mkdir -p /root/cert/

# 进入目录/root/cert/

cd /root/cert/

# 生成证书请求文件csr(域名bakreg.cn自行修改)

openssl req -nodes -subj "/CN=bakreg.cn" -newkey rsa:2048 -keyout bakreg.cn.key -out bakreg.cn.csr

# 生成有效期10年的CA证书crt

openssl x509 -req -days 3650 -in bakreg.cn.csr -signkey bakreg.cn.key -out bakreg.cn.crt 

# 获取CA私钥srl

openssl x509 -req -in bakreg.cn.csr -CA bakreg.cn.crt -CAkey bakreg.cn.key -CAcreateserial -out bakreg.cn.crt -days 10000

 四、部署harbor

 4.1 获取安装包

官方(https://github.com/vmware/harbor/releases)提供了2种部署包(在线、离线),我选了在线安装包(配了docker加速的情况下,在线包下载镜像的时间要比离线包快很多)。

# 下载在线安装包(下载地址根据官网自行选择,我部署的时候最新是1.4.0)

cd
wget https://storage.googleapis.com/harbor-releases/release-1.4.0/harbor-online-installer-v1.4.0.tgz

# 解压

tar xvf harbor-online-installer-v1.4.0.tgz

 4.2 修改配置文件

# 编辑harbor.cfg

vim /root/harbor/harbor.cfg

# /root/harbor/harbor.cfg文件是Harbor的配置文件,下面列一些可能会修改的项(下面的配置是基于https的harbor,因为https配置后只要在客户机添加证书和域名解析,可以连接多个镜像仓库;如果是http,daemon.json里配置后只能连接一个自己的私有仓库)。

## Configuration file of Harbor

# hostname设置访问地址。可以使用ip、域名、主机名,不可以设置为127.0.0.1或localhost。(如果部署的是备份库,填写ip而不是域名,否则会导致仓库管理连接失败,host无法识别原因不明)
hostname = bakreg.cn # 访问协议。默认是http,如果搭建https的仓库就改为https。
ui_url_protocol = https # 可选的https证书配置地址
ssl_cert = /root/cert/bakreg.cn.crt
ssl_cert_key = /root/cert/bakreg.cn.key # 用于在复制策略中加密或解密远程注册表的密码的密钥路径。secretkey_path不需要修改。如果必须修改它,你需要在/root/harbor/docker-compose.yml中手动调整路径,因为它们是硬编码。
secretkey_path = /data # 邮件设置,发送重置密码邮件时使用
# email_identity作为用户名
email_identity = email_server = 邮箱的smtp服务器域名
email_server_port = 25
email_username =
email_password =
email_from =
email_ssl = false
email_insecure = false # 管理员admin的登录密码。默认是Harbor12345
harbor_admin_password = Harbor12345 # 认证方式。默认是db_auth,支持多种认证方式,如数据库认证(db_auth)、LADP(ldap_auth)。
auth_mode = db_auth # LDAP认证时配置项(这项可以登录后配置也可以)。
ldap_url = # LDAP URL
ldap_searchdn = # LDAP 搜索DN
ldap_search_pwd = # LDAP 搜索DN的密码
ldap_basedn = # LDAP 基础DN
ldap_filter = # LDAP 过滤器
ldap_uid = # LDAP 用户uid的属性
ldap_scope = 2
ldap_timeout = 5 # 是否开启注册。on开启,off关闭。
self_registration = off # Token有效时间。默认30分钟。
token_expiration = 30 # 标记用户创建项目权限控制。默认是everyone(允许所有人创建),也可以设置为adminonly(只能管理员才能创建)
project_creation_restriction = everyone

 4.3 harbor启动、开机启动

cd /root/harbor
./install.sh

由于使用了docker-compose,可以使用后台启动的方式来实现harbor的开机启动功能。

cd /root/harbor

# 停止容器

docker-compose stop

# 后台启动容器

docker-compose up -d

 五、登录

由于服务部署在192.168.3.1,可以根据IP直接访问。

 http访问web:http://192.168.3.1

 https访问web:https://192.168.3.1

使用管理员(admin)登录(没有修改harbor_admin_password的话,密码是Harbor12345)。


 六、向基于http的harbor上传下载镜像

 6.1 客户机配置

Docker从1.3.X之后,与docker registry交互默认使用的是https,然而harbor只提供http服务。为了解决这个问题需要在启动docker时增加启动参数为默认使用http访问。

这里提供2种可行的操作。

 1)修改daemon.json

# 编辑daemon.json

vim /etc/docker/daemon.json

# 添加下面的内容,wq保存。

{
"insecure-registries":["192.168.3.1"]
}

# 重启docker

systemctl restart docker

 2)修改docker.service

# 编辑docker.service

vim /usr/lib/systemd/system/docker.service

# 添加下面的内容,wq保存。

在“ExecStart=”中添加
--insecure-registry 192.168.3.1 \

# 重新载入systemd

systemctl daemon-reload

# 重启docker

systemctl restart docker 

 6.2 上传下载镜像

# docker登录harbor

docker login 192.168.3.1

# 标记镜像nginx:v1为192.168.3.1/你的用户名/nginx:v1

docker tag nginx:v1 192.168.3.1/你的用户名/nginx:v1

# 推送镜像到harbor

docker push 192.168.3.1/你的用户名/nginx:v1

# 拉取镜像

docker pull 192.168.3.1/你的用户名/nginx:v1

# docker退出登录harbor

docker logout 192.168.3.1

 七、向基于https的harbor上传下载镜像

 7.1 客户机配置

由于通过openssl创建的是不可信的,直接拉取或登录时会报“x509: certificate signed by unknown authority”,故需要让客户机信任该证书。

将192.168.3.1中的/root/cert/bakreg.cn.crt迁移到客户机的/root目录中。

# 将bakreg.cn的证书追加到客户机的证书库中

cat /root/bakreg.cn.crt >>/etc/pki/tls/certs/ca-bundle.crt

# 重启docker

systemctl restart docker

# 修改客户机的hosts

vim /etc/hosts

# 增加下面的内容,wq保存。

192.168.3.1 bakreg.cn

 7.2 上传下载镜像

# docker登录harbor

docker login bakreg.cn

# 标记镜像nginx:v1为bakreg.cn/你的用户名/nginx:v1

docker tag nginx:v1 bakreg.cn/你的用户名/nginx:v1

# 推送镜像到harbor

docker push bakreg.cn/你的用户名/nginx:v1

# 拉取镜像

docker pull bakreg.cn/你的用户名/nginx:v1

# docker退出登录harbor

docker logout bakreg.cn

centos7 部署镜像仓库 harbor步骤详解的更多相关文章

  1. centos7 部署镜像仓库 harbor

    =============================================== 2018/4/16_第2次修改                       ccb_warlock 更新 ...

  2. CentOS7.3部署镜像仓库Harbor

    参考文档: harbor介绍:https://github.com/vmware/harbor harbor安装&使用指导:https://github.com/vmware/harbor/b ...

  3. 离线手动部署docker镜像仓库——harbor仓库(HTTPS)

    实验环境: harbor服务器系统:CentOS Linux release 7.5.1804 (Core)harbor服务器IP:10.1.12.114harbor版本:v1.5.0docker版本 ...

  4. 私有镜像仓库Harbor基础介绍与部署

    企业级私有镜像仓库Harbor 一:介绍 Harbor,是一个英文单词,意思是港湾,港湾是干什么的呢,就是停放货物的,而货物呢,是装在集装箱中的,说到集装箱,就不得不提到Docker容器,因为dock ...

  5. CentOS7/RHEL7安装Redis步骤详解

    CentOS7/RHEL7安装Redis步骤详解 CentOS7/RHEL7安装Redis还是头一次测试安装了,因为centos7升级之后与centos6有比较大的区别了,下面我们就一起来看看Cent ...

  6. Linux centos7环境下安装JDK的步骤详解

    Linux centos7环境下安装JDK的步骤详解 测试root用户下JAVA版本 输入命令:   java –version 1.先到Oracle官网里下载好jdk,网址如下: http://ww ...

  7. Linux centos7环境下安装MySQL的步骤详解

    Linux centos7环境下安装MySQL的步骤详解 安装MySQL mysql 有两个跟windows不同的地方 1).my.ini 保存到/etc/my.ini 2).用户权限,单独用户执行 ...

  8. docker 镜像仓库 Harbor 部署 以及 跨数据复制

    docker 镜像仓库 Harbor 部署 跨数据复制 Harbor 是 Vmwar 公司开源的 企业级的 Docker Registry 管理项目 它主要 提供 Dcoker Registry 管理 ...

  9. 企业级Docker镜像仓库Harbor部署与使用

    yum install docker 官网地址:https://docs.docker.com/compose/install/ 运行此命令以下载Docker Compose的当前稳定版本 1 sud ...

随机推荐

  1. .net 批量导出文件,以ZIP压缩方式导出

     1. 首先Nuget          ICSharpCode.SharpZipLib <script type="text/javascript"> $(funct ...

  2. [IOI1998]Polygon(区间dp)

    [IOI1998]Polygon 题意翻译 多边形是一个玩家在一个有n个顶点的多边形上的游戏,如图所示,其中n=4.每个顶点用整数标记,每个边用符号+(加)或符号*(乘积)标记. 第一步,删除其中一条 ...

  3. [SCOI2010]股票交易(单调队列优化dp)

    [SCOI2010]股票交易 题目描述 最近lxhgww又迷上了投资股票,通过一段时间的观察和学习,他总结出了股票行情的一些规律. 通过一段时间的观察,lxhgww预测到了未来T天内某只股票的走势,第 ...

  4. gradlew compileDebug --stacktrace -info

    gradlew compileDebug --stacktrace -info 在命令行中进入项目的根目录,或者可以在Android studio的Terminal中直接操作也可以,然后敲入一个命令: ...

  5. IBM和DoE推出世界上最快的超级计算机

    IBM和美国能源部的橡树岭国家实验室今天发布了该部门最新的超级计算机Summit.IBM声称峰会目前是世界上“最强大,最聪明的科学超级计算机”,其峰值性能每秒高达20万亿次.当新的榜单在本月晚些时候发 ...

  6. Java字节数组流学习

    字节数组流 基于内存操作,内部维护着一个字节数组,我们可以利用流的读取机制来处理字符串.无需关闭,不会报IOException. ByteArrayInputStream 包含一个内部缓冲区,该缓冲区 ...

  7. 数据库与缓存:3.mongodb的基本知识

    1. mongodb是什么? NoSQL 非关系型数据库,主要用于数据的海量存储.分为server数据存储端和client数据操作端. 1.1 关系型与非关系型数据库的区别? 1.sql:数据库--表 ...

  8. 日常Git使用——2019年12月11日16:19:03

    1.git介绍 1.1 什么是git? 什么是Git? 比如一个项目,两个人同时参与开发,那么就把这个项目放在一个公共的地方,需要的时候都可以去获取,有什么改动,都可以进行提交. 为了做到这一点,就需 ...

  9. 【JVM】垃圾收集器和收集器的选择策略

    前言:新生代的收集器有:Serial,ParNew,Parallel Scavenge等.老年代有:CMS,SerialOld,Paraller Old等.接下来将深入理解各个垃圾收集器的原理,以及它 ...

  10. SpringMvc的过滤器。

    一:过滤器的原理: 过滤器放在web资源之前,可以在请求抵达它所应用的web资源(可以是一个Servlet.一个Jsp页面,甚至是一个HTML页面)之前截获进入的请求,并且在它返回到客户之前截获输出请 ...