条件:安装docker&docker-compose

如未安装,请看:linux离线安装docker + docker-compose

harbor

1.下载

下载地址:https://github.com/goharbor/harbor/releases

2.安装

1.上传至服务器,并解压

tar -zxvf harbor-offline-installer-v1.10.6.tgz

2.配置Harbor(我的版本为yml格式,有一些为cfg格式)

# Configuration file of Harbor# The IP address or hostname to access admin UI and registry service.
# DO NOT use localhost or 127.0.0.1, because Harbor needs to be accessed by external clients.
# hostname设置访问地址,可以使用ip、域名,不可以设置为127.0.0.1或localhost
hostname: 192.168.1.4 #这里需求修改为ip或者域名# http related config
http:# port for http, default is 80. If https enabled, this port will redirect to https portport: 80# https related config
#因为测试使用 HTTP 协议,故将 HTTPS 配置注释
#生产环境必须要使用 HTTPS,并且 HTTPS 需要额外的配置
#https:# https port for harbor, default is 443
#  port: 443# The path of cert and key files for nginx
#  certificate: /your/certificate/path
#  private_key: /your/private/key/path# Uncomment external_url if you want to enable external proxy
# And when it enabled the hostname will no longer used
# external_url: https://reg.mydomain.com:8433# The initial password of Harbor admin
# It only works in first time to install harbor
# Remember Change the admin password from UI after launching Harbor.
#harbor 系统管理员密码配置,账户admin,密码默认为Harbor12345
harbor_admin_password: Harbor12345# Harbor DB configuration
#DB配置
database:# The password for the root user of Harbor DB. Change this before any production use.#密码默认为root123password: root123# The maximum number of connections in the idle connection pool. If it <=0, no idle connections are retained.max_idle_conns: 50# The maximum number of open connections to the database. If it <= 0, then there is no limit on the number of open connections.# Note: the default number of connections is 100 for postgres.max_open_conns: 100# The default data volume
data_volume: /data# Harbor Storage settings by default is using /data dir on local filesystem
# Uncomment storage_service setting If you want to using external storage
# storage_service:
#   # ca_bundle is the path to the custom root ca certificate, which will be injected into the truststore
#   # of registry's and chart repository's containers.  This is usually needed when the user hosts a internal storage with self signed certificate.
#   ca_bundle:#   # storage backend, default is filesystem, options include filesystem, azure, gcs, s3, swift and oss
#   # for more info about this configuration please refer https://docs.docker.com/registry/configuration/
#   filesystem:
#     maxthreads: 100
#   # set disable to true when you want to disable registry redirect
#   redirect:
#     disabled: false# Clair configuration
clair:# The interval of clair updaters, the unit is hour, set to 0 to disable the updaters.updaters_interval: 12jobservice:# Maximum number of job workers in job servicemax_job_workers: 10notification:# Maximum retry count for webhook jobwebhook_job_max_retry: 10chart:# Change the value of absolute_url to enabled can enable absolute url in chartabsolute_url: disabled# Log configurations
log:# options are debug, info, warning, error, fatallevel: info# configs for logs in local storagelocal:# Log files are rotated log_rotate_count times before being removed. If count is 0, old versions are removed rather than rotated.rotate_count: 50# Log files are rotated only if they grow bigger than log_rotate_size bytes. If size is followed by k, the size is assumed to be in kilobytes.# If the M is used, the size is in megabytes, and if G is used, the size is in gigabytes. So size 100, size 100k, size 100M and size 100G# are all valid.rotate_size: 200M# The directory on your host that store loglocation: /var/log/harbor# Uncomment following lines to enable external syslog endpoint.# external_endpoint:#   # protocol used to transmit log to external endpoint, options is tcp or udp#   protocol: tcp#   # The host of external endpoint#   host: localhost#   # Port of external endpoint#   port: 5140#This attribute is for migrator to detect the version of the .cfg file, DO NOT MODIFY!
_version: 1.10.0# Uncomment external_database if using external database.
# external_database:
#   harbor:
#     host: harbor_db_host
#     port: harbor_db_port
#     db_name: harbor_db_name
#     username: harbor_db_username
#     password: harbor_db_password
#     ssl_mode: disable
#     max_idle_conns: 2
#     max_open_conns: 0
#   clair:
#     host: clair_db_host
#     port: clair_db_port
#     db_name: clair_db_name
#     username: clair_db_username
#     password: clair_db_password
#     ssl_mode: disable
#   notary_signer:
#     host: notary_signer_db_host
#     port: notary_signer_db_port
#     db_name: notary_signer_db_name
#     username: notary_signer_db_username
#     password: notary_signer_db_password
#     ssl_mode: disable
#   notary_server:
#     host: notary_server_db_host
#     port: notary_server_db_port
#     db_name: notary_server_db_name
#     username: notary_server_db_username
#     password: notary_server_db_password
#     ssl_mode: disable# Uncomment external_redis if using external Redis server
# external_redis:
#   host: redis
#   port: 6379
#   password:
#   # db_index 0 is for core, it's unchangeable
#   registry_db_index: 1
#   jobservice_db_index: 2
#   chartmuseum_db_index: 3
#   clair_db_index: 4# Uncomment uaa for trusting the certificate of uaa instance that is hosted via self-signed cert.
# uaa:
#   ca_file: /path/to/ca# Global proxy
# Config http proxy for components, e.g. http://my.proxy.com:3128
# Components doesn't need to connect to each others via http proxy.
# Remove component from `components` array if want disable proxy
# for it. If you want use proxy for replication, MUST enable proxy
# for core and jobservice, and set `http_proxy` and `https_proxy`.
# Add domain to the `no_proxy` field, when you want disable proxy
# for some special registry.
proxy:http_proxy:https_proxy:# no_proxy endpoints will appended to 127.0.0.1,localhost,.local,.internal,log,db,redis,nginx,core,portal,postgresql,jobservice,registry,registryctl,clair,chartmuseum,notary-serverno_proxy:components:- core- jobservice- clair

View Code

3.启动Harbor

修改完配置文件后,在的当前目录执行./install.sh,Harbor服务就会根据当期目录下的docker-compose.yml开始下载依赖的镜像,检测并按照顺序依次启动各个服务

sudo ./install.sh

成功

3、Harbor仓库使用

1)、登录Web Harbor

输入账户密码进入  默认账号/密码:admin/Harbor12345

新建项目

4、Harbor的使用(上传下载镜像)

新建项目后,使用admin用户提交镜像到Harbor仓库

1、使用docker login

docker login 192.168.1.4

使用docker login出现如下问题:

原因:因为使用的是 HTTP协议故需要在客户端进行配置

Username: admin
Password:
Error response from daemon: Get https://192.168.1.4/v2/: dial tcp 192.168.1.4:443: connect: connection refused

解决方案:

1、修改 /etc/docker/daemon.json 文件,加入"insecure-registries" : 服务器i
sudo vi /etc/docker/daemon.json#文件加入"insecure-registries":[""]

2.修改后重启 Docker 服务

sudo systemctl restart docker

3、再次登录

登录成功

5、使用

1、 给镜像打tag

进入刚刚创建的test

2、查看推送镜像的DOCKER命令

3、这里使用goharbor/nginx-photon为案例

docker tag goharbor/nginx-photon:v1.10.6 ip/test/harbor-nginx:v1.0.2

4、打完成后,查看

docker images

5、推送

docker push ip/test/harbor-nginx:v1.0.2

6、推送成功,查看

7、下载

docker pull ip/test/harbor-nginx:v1.0.2

linux搭建harbor与使用相关推荐

  1. 搭建Harbor企业级docker仓库

    from: https://www.cnblogs.com/pangguoping/p/7650014.html 搭建Harbor企业级docker仓库 一.Harbor简介 1.Harbor介绍 H ...

  2. 1+X 云计算运维与开发(中级)案例实战——搭建harbor私有仓库并实现主从同步

    1+X 云计算运维与开发(中级)案例实战--搭建harbor私有仓库并实现主从同步 前言 思路 实操 1.(个人习惯)修改主机名,添加主机映射 2. 配置镜像加速器 3. 生成CA证书,并分发证书 4 ...

  3. 甲骨文云上使用arm架构实例和对象存储搭建Harbor

    今天尝试使用甲骨文云的arm实例(4ocpus+24Gb memory)搭建Harbor,并且存储使用甲骨文云兼容S3协议的对象存储. 事情准备 准备好arm架构的实例,防火墙开放80和443端口,设 ...

  4. 搭建Harbor最新版本步骤

    搭建Harbor最新版本步骤 目录 搭建Harbor最新版本步骤 1. 下载安装包 2. Harbor配置文件修改 3. 安装docker-ce,默认centos不带docker yum源,需要手动增 ...

  5. 搭建Harbor私有镜像仓库

    Docker容器应用的开发和运行离不开可靠的镜像管理,部署一个私有的镜像仓库是十分有必要的.虽然Docker官方提供了docker-registry用于构建私有的镜像仓库.但它的功能没有Harbor丰 ...

  6. 我的世界php安装,我的世界Linux搭建网页后台Multicraft下载与安装

    小编为大家带来了<我的世界>Linux搭建网页后台Multicraft下载与安装,首先下载Multicraft Linux版,下载好了以后请玩家自己看着下面的教程来安装. 64位:http ...

  7. 搭建Harbor 2.x仓库 - docker私仓搭建

    搭建Harbor仓库 Harbor是什么?为什么会用到Harbor? harbor是构建企业级私有docker镜像的仓库的开源解决方案,它是 Docker Registry的更高级封装,它除了提供友好 ...

  8. Linux 搭建SVN 服务器

    一. SVN 简介 Subversion(SVN) 是一个开源的版本控制系統, 也就是说 Subversion 管理着随时间改变的数据. 这些数据放置在一个中央资料档案库 (repository) 中 ...

  9. Linux搭建安卓开发环境

    Linux下搭建Android开发环境 为什么要在Linux搭建开发环境呢?从直观来说,Android虚拟机在Linux下运行速度更快,而且性能更稳定. 我使用的Linux环境是ubuntu-10.1 ...

  10. docker搭建harbor私有镜像库

    创建harbor私有镜像库 一.部署准备: harbor软件包 在部署节点上: 1)解压harbor的软件包将harbor目录下所有文件发送到/opt/目录下 tar zxvf harbor-offl ...

最新文章

  1. Ubuntu中虚拟环境pip安装包超时问题
  2. 关于容器的三件事,你知道吗?
  3. android SharedPreferences保存list数据
  4. UE4学习-新建C++组件、编码遇到问题
  5. pythonqt4上位机开发_「新阁教育」自由口通信上位机实战案例
  6. 未来计算机控制器趋势,未来DCS控制系统技术发展4大趋势
  7. CUDA:在GPU上实现核函数的嵌套以及编译运行
  8. Java笔记:final修饰符
  9. Java面试基础部分合集
  10. Ruby语言快速入门
  11. 【我的Android进阶之旅】 解决Android编译出现问题:AAPT: error: resource string/xxx (aka xxx:string/xxx) not found.
  12. 单片机实现TM1620驱动 含完整程序源码
  13. 利用java打印心型图案
  14. 浏览器的两种设置方法:本地的设置方法与静默设置
  15. 解决RTL8723BE网卡Linux上WIFI信号信号差的问题
  16. HTML 表格合并(表格合并行属性 rowspan 将多行合并成一行)
  17. 如何批量修改拼多多价格?基于按键精灵实现--拼多多改价精灵
  18. 「不得不看的猴子摘桃问题」
  19. 【腾讯云】云服务器 Nginx 内网访问 COS 省流量费
  20. android 仿qq发动态,Android opengl 实现动态贴纸(仿QQ的拍摄)

热门文章

  1. Python基于迁移学习的交通信号识别实战【图像多分类任务】【实测准确度超过96.7%】
  2. python实现Kruskal算法求解加权图中最小生成树问题
  3. python+sklearn利用特征文件来训练和测试模型并使用joblib方法持久化存储模型
  4. 美男子第一次的JAVA博客
  5. linux软链接删除重新创显示,Linux 下如何创建 /删除软连接
  6. 2021-07-01样式和图片标签
  7. picpick尺子像素大小精度不够准确_袖珍大小MFJ-223 1-60MHz彩色图形VNA矢量网络分析仪...
  8. 支持向量机_支持向量机(SVM)说明及示例
  9. java并发编程(2)--线程 原子性 volatile AtomicInteger
  10. liunx下安装redis开启网络