linux搭建harbor与使用
条件:安装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
![](/assets/blank.gif)
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
成功
![](/assets/blank.gif)
![](/assets/blank.gif)
3、Harbor仓库使用
1)、登录Web Harbor
![](/assets/blank.gif)
输入账户密码进入 默认账号/密码:admin/Harbor12345
![](/assets/blank.gif)
新建项目
![](/assets/blank.gif)
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":[""]
![](/assets/blank.gif)
2.修改后重启 Docker 服务
sudo systemctl restart docker
3、再次登录
登录成功
![](/assets/blank.gif)
5、使用
1、 给镜像打tag
进入刚刚创建的test
![](/assets/blank.gif)
2、查看推送镜像的DOCKER命令
![](/assets/blank.gif)
3、这里使用goharbor/nginx-photon为案例
docker tag goharbor/nginx-photon:v1.10.6 ip/test/harbor-nginx:v1.0.2
![](/assets/blank.gif)
4、打完成后,查看
docker images
![](/assets/blank.gif)
5、推送
docker push ip/test/harbor-nginx:v1.0.2
![](/assets/blank.gif)
6、推送成功,查看
![](/assets/blank.gif)
7、下载
docker pull ip/test/harbor-nginx:v1.0.2
![](/assets/blank.gif)
![](/assets/blank.gif)
linux搭建harbor与使用相关推荐
- 搭建Harbor企业级docker仓库
from: https://www.cnblogs.com/pangguoping/p/7650014.html 搭建Harbor企业级docker仓库 一.Harbor简介 1.Harbor介绍 H ...
- 1+X 云计算运维与开发(中级)案例实战——搭建harbor私有仓库并实现主从同步
1+X 云计算运维与开发(中级)案例实战--搭建harbor私有仓库并实现主从同步 前言 思路 实操 1.(个人习惯)修改主机名,添加主机映射 2. 配置镜像加速器 3. 生成CA证书,并分发证书 4 ...
- 甲骨文云上使用arm架构实例和对象存储搭建Harbor
今天尝试使用甲骨文云的arm实例(4ocpus+24Gb memory)搭建Harbor,并且存储使用甲骨文云兼容S3协议的对象存储. 事情准备 准备好arm架构的实例,防火墙开放80和443端口,设 ...
- 搭建Harbor最新版本步骤
搭建Harbor最新版本步骤 目录 搭建Harbor最新版本步骤 1. 下载安装包 2. Harbor配置文件修改 3. 安装docker-ce,默认centos不带docker yum源,需要手动增 ...
- 搭建Harbor私有镜像仓库
Docker容器应用的开发和运行离不开可靠的镜像管理,部署一个私有的镜像仓库是十分有必要的.虽然Docker官方提供了docker-registry用于构建私有的镜像仓库.但它的功能没有Harbor丰 ...
- 我的世界php安装,我的世界Linux搭建网页后台Multicraft下载与安装
小编为大家带来了<我的世界>Linux搭建网页后台Multicraft下载与安装,首先下载Multicraft Linux版,下载好了以后请玩家自己看着下面的教程来安装. 64位:http ...
- 搭建Harbor 2.x仓库 - docker私仓搭建
搭建Harbor仓库 Harbor是什么?为什么会用到Harbor? harbor是构建企业级私有docker镜像的仓库的开源解决方案,它是 Docker Registry的更高级封装,它除了提供友好 ...
- Linux 搭建SVN 服务器
一. SVN 简介 Subversion(SVN) 是一个开源的版本控制系統, 也就是说 Subversion 管理着随时间改变的数据. 这些数据放置在一个中央资料档案库 (repository) 中 ...
- Linux搭建安卓开发环境
Linux下搭建Android开发环境 为什么要在Linux搭建开发环境呢?从直观来说,Android虚拟机在Linux下运行速度更快,而且性能更稳定. 我使用的Linux环境是ubuntu-10.1 ...
- docker搭建harbor私有镜像库
创建harbor私有镜像库 一.部署准备: harbor软件包 在部署节点上: 1)解压harbor的软件包将harbor目录下所有文件发送到/opt/目录下 tar zxvf harbor-offl ...
最新文章
- Ubuntu中虚拟环境pip安装包超时问题
- 关于容器的三件事,你知道吗?
- android SharedPreferences保存list数据
- UE4学习-新建C++组件、编码遇到问题
- pythonqt4上位机开发_「新阁教育」自由口通信上位机实战案例
- 未来计算机控制器趋势,未来DCS控制系统技术发展4大趋势
- CUDA:在GPU上实现核函数的嵌套以及编译运行
- Java笔记:final修饰符
- Java面试基础部分合集
- Ruby语言快速入门
- 【我的Android进阶之旅】 解决Android编译出现问题:AAPT: error: resource string/xxx (aka xxx:string/xxx) not found.
- 单片机实现TM1620驱动 含完整程序源码
- 利用java打印心型图案
- 浏览器的两种设置方法:本地的设置方法与静默设置
- 解决RTL8723BE网卡Linux上WIFI信号信号差的问题
- HTML 表格合并(表格合并行属性 rowspan 将多行合并成一行)
- 如何批量修改拼多多价格?基于按键精灵实现--拼多多改价精灵
- 「不得不看的猴子摘桃问题」
- 【腾讯云】云服务器 Nginx 内网访问 COS 省流量费
- android 仿qq发动态,Android opengl 实现动态贴纸(仿QQ的拍摄)
热门文章
- Python基于迁移学习的交通信号识别实战【图像多分类任务】【实测准确度超过96.7%】
- python实现Kruskal算法求解加权图中最小生成树问题
- python+sklearn利用特征文件来训练和测试模型并使用joblib方法持久化存储模型
- 美男子第一次的JAVA博客
- linux软链接删除重新创显示,Linux 下如何创建 /删除软连接
- 2021-07-01样式和图片标签
- picpick尺子像素大小精度不够准确_袖珍大小MFJ-223 1-60MHz彩色图形VNA矢量网络分析仪...
- 支持向量机_支持向量机(SVM)说明及示例
- java并发编程(2)--线程 原子性 volatile AtomicInteger
- liunx下安装redis开启网络