纯净CentOS搭建harbor镜像私仓

物理宿主机IP:  192.168.1.4

在官网下载 CentOS-7-x86_64-DVD-1810

用Hyper-v建立一代虚机,安装时遇分辨率问题无法继续,需要在选择启动界面按TAB键以编辑启用参数,追加下列参数(注意800*600中的乘号用小号的x)

video=hyperv_fb:800x600

安装完成后 IP 设置为192.168.1.13 ,用root登陆:

 一、安装DOCKER

//更新yum
yum -y update

//安装依赖包

yum install -y yum-utils  device-mapper-persistent-data  lvm2

//设置稳定版仓库

yum-config-manager   --add-repo  https://download.docker.com/linux/centos/docker-ce.repo

//安装 docker

yum install docker-ce

//启动 docker服务
service docker start

//开机自动启动 docker服务
systemctl enable docker

 二、下安装docker-compose

方法一:在线安装,可能因为下载文件不全而出现错误:“Cannot open self /usr/local/bin/docker-compose or archive /usr/local/bin/docker-compose.pkg”

curl -L "https://github.com/docker/compose/releases/download/1.24.1/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

方法二:离线安装

下载地址:https://github.com/docker/compose/releases/download/1.24.1/docker-compose-Linux-x86_64

下载完成后将文件上传到 /usr/local/bin/ 文件夹下,然后将其重命名为docker-compose即可。

 

安装完成后修改此文件的执行权限:

//授权
chmod +x /usr/local/bin/docker-compose

//测试安装
docker-compose --version

其它一些常用的docker-compose命令:

docker-compose up -d                ###后台启动,如果容器不存在根据镜像自动创建

docker-compose down  -v             ###停止容器并删除容器

docker-compose start                 ###启动容器,容器不存在就无法启动,不会自动创建镜像

docker-compose stop                 ###停止容器

 

三、安装 harbor

下载最新版的离线包
下载地址:https://storage.googleapis.com/harbor-releases/harbor-offline-installer-latest.tgz
上传到任意目录并解压,我把它解压到 /usr/local/ 目录,然后配置解压后harbor目录下的harbor.cfg 文件

cd /usr/local/harbor
vi harbor.cfg

编辑修改harbor.cfg文件内容如下:

# hostname设置访问地址,可以使用ip、域名,不可以设置为127.0.0.1或localhost,此处我设置为将要使用的域名

hostname = rep.dhis2.org.cn  #也可以是IP地址,如 192.168.1.3

# Harbor启动后,管理员UI登录的密码,默认是Harbor12345,改为admin

harbor_admin_password = admin

  harbor的启动依赖一系列的容器,修改容编排文件docker-compose.yml,以配置允许非HTTPs的5000端口

vi docker-compose.yml

编辑内容如下:添加ports端口,为了使用http快速访问。(注意“-”短线后有个空格)

registry:
  networks:
    - harbor
  ports:
    - 5000:5000

 初始化配置文件,若是修改了harbor.cfg则需要重新初始化。初始后将丢失镜像数据 。所以如果只修改了common中的配置文件,直接重启即可,不能执行初始化。

./prepare

 执行安装命名。注意,只能安装一次,如果要重置容器可以用前面介绍的docker-compose常用命令(修改配置文件后最好把容器删除再创建)。

chmod u+x install.sh   #授权
#安装
./install.sh

访问 http://rep.dhis2.org.cn ,并使用admin/admin登陆

登陆后,选择library项目(也可以自己新建项目),点击“推送镜像” 按钮即可获得客户端的推送命令:见上图黄色部分

四、从其它客户机向私仓推送镜像

客户机首先需要安装docker。为了支持非HTTPS还需要修改文件 /etc/docker/daemon.json (是个json文件,如果没有就创建)

sudo vim /etc/docker/daemon.json

文件内添加 insecure-registries 键值:

 {
 "registry-mirrors": ["https://registry.docker-cn.com"],
"insecure-registries": ["rep.dhis2.org.cn"] }

然后,重启客户机的docker

service docker restart

准备要推送到私仓服务器的镜像:

通过tag的方式把私仓的地址打入欲推送的目标镜像,生成一个新镜像,语法如下:(即上图中的“在项目中标记镜像”)

docker tag 原镜像名[:原TAG] rep.dhis2.org.cn/library/放入私仓的镜像名[:私仓镜像TAG]

比如,将客户机中的cheewai/postgis:postgres-11-postgis-2.5镜像推到私仓library项目中,新的镜像名:TAG为 dhis2_db:2320

docker tag cheewai/postgis:postgres-11-postgis-2.5 rep.dhis2.org.cn/library/dhis2_db:2320

此时客户机镜像如下:

远程登陆私仓服务器:

docker login rep.dhis2.org.cn

 用第二张图中标黄的语法推送此镜像:

docker push rep.dhis2.org.cn/library/dhis2_db:2320

 刷新查看私仓服务器中的镜像:

posted @ 2019-08-04 20:46  Laro  阅读(290)  评论(0编辑  收藏  举报