四、harbor实践之初识harbor

1 什么是Harbor

  harbor是VMware公司开源的企业级Registry项目,其的目标是帮助用户迅速搭建一个企业级的Docker registry 服务。

2 什么是Registry

  Registry是一个无状态的,高可扩展的服务器端应用程序,用于存储和分发Docker Image。

3 第一次使用Harbor

  3.1登录

  默认用户名密码:admin/Harbor12345

  

  3.2创建项目

  填写项目名称,设置访问级别;如果设置为公共仓库,则所有人对此项目下的镜像拥有读权限,命令行中不需要执行"docker login"即可下载镜像。

   

4为项目添加镜像

  4.1登录本地私有registry

docker login 192.168.88.128

  

  登录过程中组件的交互:

  

(a) 首先,这个请求会由监听80端口的proxy容器接收到。根据预先设置的匹配规则, 容器中的Nginx会将请求转发给后端的registry 容器;
(b) 在registry容器一方,由于配置了基于token的认证,registry会返回错误代码401,提示Docker客户端访问token服务绑定的URL。在Harbor中,这个URL指向Core Services;
(c) Docker 客户端在接到这个错误代码后,会向token服务的URL发出请求,并根据HTTP协议的Basic Authentication规范,将用户名密码组合并编码,放在请求头部(header);
(d)类似地,这个请求通过80端口发到proxy容器后,Nginx会根据规则把请求转发给ui容器,ui容器监听token服务网址的处理程序接收到请求后,会将请求头解码,得到用户名、密码;
(e) 在得到用户名、密码后,ui容器中的代码会查询数据库,将用户名、密码与mysql容器中的数据进行比对(注:ui 容器还支持LDAP的认证方式,在那种情况下ui会试图和外部LDAP服务进行通信并校验用户名/密码)。比对成功,ui容器会返回表示成功的状态码, 并用密钥生成token,放在响应体中返回给Docker 客户端。

  4.2为镜像打tag

#tag格式为:domain(ip)/project/image:versiondocker tag vmware/photon:1.0 192.168.88.128/hb/vmware/photon:1.0

  

  4.3push镜像到私有registry

docker push 192.168.88.128/hb/vmware/photon:1.0

  

  4.4 删除、下载镜像

docker rmi
docker pull

原文地址:https://www.cnblogs.com/Rcsec/p/8484284.html

时间: 2024-10-20 14:10:38

四、harbor实践之初识harbor的相关文章

创建harbor的secret和harbor进行通信(yaml格式)

需求:以yaml文件格式的方式来创建能够拉取harbor镜像的secret. ? 然后在pod中引用 docker login -u USERNAME -pPASSWORD HARBORSERVER #以这种方式先成功登陆到harbor仓库 cat ~/.docker/config.json | base64 -w 0 #然后登陆信息会保存到如上的json格式文件里.我们通过base64编码工具,将其再进行转换 vim pull.image.secret.yaml apiVersion: v1

[Unity3D ARPG网络游戏编程实践]1——初识unity网络编程

[Unity3D ARPG网络游戏编程实践] 想杀人了,百度了半天也不知道本地服务怎么写,结果资源里的服务器竟然可以用了~~~~(>_<)~~~~ 使用了两种方法1 这个方法特别郁闷,自己写服务器,自己写客户端可以通讯.可是这个服务器用在 [Unity3D ARPG网络游戏编程实践] 中就不能链接成功,还好资源里带有启动本地服务的程序,不会原因,不懂服务器链接的原理宣雨松版服务器客户端通讯代码 服务器端 using UnityEngine; using System.Collections;

算法第四章实践报告

1.选择第二题进行分析. 给定n位正整数a,去掉其中任意k≤n 个数字后,剩下的数字按原次序排列组成一个新 的正整数.对于给定的n位正整数a和正整数 k,设计一个算法找出剩下数字组成的新数最 小的删数方案. 输入 178543 4 输出132.问题描述:就是删掉指定数字中的一些数字,然后重新组成一个新的数使得这个数达到最小.3.算法描述:这个问题第一眼看下去容易想到对数组不停的排序然后不断删掉最大的,但是按着这个思路去做却发现,不断提取整型数组然后排序会比较复杂,因为要不断求余数等等,而且代码不

算法 第四章实践

1.实践题目 程序存储问题 2.问题描述 设有n 个程序{1,2,-, n }要存放在长度为L的磁带上.程序i存放在磁带上的长度是 li,1≤i≤n. 程序存储问题要求确定这n 个程序在磁带上的一个存储方案, 使得能够在磁带上存储尽可能多的程序. 对于给定的n个程序存放在磁带上的长度,计算磁带上最多可以存储的程序数. 3.算法描述 for(int i=0;i<n;i++) cin>>a[i];//将程序的长度存放在数组之中 sort(a,a+n);//将数组中的元素排序 int num=

第四章实践

1.实践题目 删数问题 2.问题描述 给定n位正整数a,去掉其中任意k≤n 个数字后,剩下的数字按原次序排列组成一个新 的正整数.对于给定的n位正整数a和正整数 k,设计一个算法找出剩下数字组成的新数最 小的删数方案. 输入格式: 第 1 行是1 个正整数 a.第 2 行是正整数k. 输出格式: 输出最小数. 输入样例: 在这里给出一组输入.例如: 178543 4 输出样例: 在这里给出相应的输出.例如: 13 3.算法描述 对输入的字符数组从第一个字符进行遍历,当小的数在前的时候,继续向后遍

算法的第四章实践报告

分析程序存储问题.内容包括:   1. 实践题目 设有n 个程序要存放在长度为L的磁带上.各个程序存放在磁带上的长度已列出. 程序存储问题要求确定使得n  个程序能够在磁带上存储尽可能多的程序的一个存储方案.       2.问题描述 要求每次选择长度最小的程序放入磁带中,使得能放入的程序量最多       3.算法描述(说明你的贪心策略,并且参考会场安排问题,利用反证法证明贪心选择和最优子结构性质) 每次选择剩下的程序中长度最小的程序,如会场安排问题,按小集合排在前来遍历,也即是“贪心策略”.

Android Multimedia框架总结(十四)Camera框架初识及自定义相机案例

转载请把头部出处链接和尾部二维码一起转载,本文出自逆流的鱼yuiop:http://blog.csdn.net/hejjunlin/article/details/52738492 前言:国庆节告一段落,又是新一月,上月主要是围绕MediaPlayer相关展开,从今天开始,开始分析多媒体框架中的Camera模块,看下今天的Agenda: Camera拍照 Camera录像 新API android.hardware.camera2 新旧API特点对比 Camera自定义相机 新API andro

第四章实践报告

7-1最优合并问题 1.问题描述: 给定k 个排好序的序列, 用 2 路合并算法将这k 个序列合并成一个序列. 假设所采用的 2 路合并算法合并 2 个长度分别为m和n的序列需要m+n-1 次比较.试设 计一个算法确定合并这个序列的最优合并顺序,使所需的总比较次数最少. 为了进行比较,还需要确定合并这个序列的最差合并顺序,使所需的总比较次数最多. 输入格式:第一行有 1 个正整数k,表示有 k个待合并序列. 第二行有 k个正整数,表示 k个待合并序列的长度. 输出格式:输出最多比较次数和最少比较

Harbor镜像仓库部署

一.简介 Harbor是VMware中国研发团队开发并开源企业级Registry,对中文支持很友好. Harbor是一个用于存储和分发Docker镜像的企业级Registry服务器. Harbor具有如下特点: 1.基于角色的访问控制 - 用户与Docker镜像仓库通过"项目"进行组织管理,一个用户可以对多个镜像仓库在同一命名空间(project)里有不同的权限. 2.镜像复制 - 镜像可以在多个Registry实例中复制(同步).尤其适合于负载均衡,高可用,混合云和多云的场景. 3.