data:image/s3,"s3://crabby-images/2ac2f/2ac2f631b05e3b307686bd0d0f317b199a5c19b1" alt="Harbor权威指南:容器镜像、Helm Chart等云原生制品的管理与实践"
3.2 通过Helm Chart安装Harbor
3.1节介绍了如何在单机环境下安装Harbor。当用户希望在多节点环境或者生产环境下运行Harbor时,可能需要在Kubernetes集群上部署Harbor。为此,Harbor提供了Helm Chart来帮助用户在Kubernetes上部署Harbor。
本节为读者介绍如何使用Helm将Harbor部署到Kubernetes集群。
在基于Helm安装Harbor Chart到Kubernetes之前,需要安装机器满足如表3-6所示的需求。
表3-6
data:image/s3,"s3://crabby-images/46f0e/46f0e77c0b2146ce521c88b430b3d56fcaa7e7cf" alt="img"
3.2.1 获取Helm Chart
在安装前需要执行如下命令添加Helm Chart仓库:
data:image/s3,"s3://crabby-images/b61ef/b61efc803d12116ae0a608bde17ec426de2979a1" alt="img"
我们可以从Harbor的Helm Chart项目的官方发布网站GitHub上查看Release,目录为“github.com/goharbor/harbor-helm/releases”,如图3-4所示。注意:这里不推荐用户从GitHub上直接下载Release,推荐执行命令通过Helm下载。
data:image/s3,"s3://crabby-images/6e7d7/6e7d73ecb32f7184b4f35a476c4b386f423412d2" alt="img"
图3-4
3.2.2 配置Helm Chart
本节详细讲解如何配置Helm Chart。以下介绍的各项配置可在安装过程中通过“--set”命令指定,也可通过编辑values.yaml文件指定。
若希望少量修改Helm Chart的配置完成安装,则可重点关注以下3项配置。
1.配置服务的暴露方式
Harbor Helm-Chart支持Ingress、ClusterIP、NodePort及LoadBalancer等几种访问暴露(expose)方式。在Kubernetes集群中使用Harbor时可选择ClusterIP。如果需要在Kubernetes集群外提供Harbor服务,则可选择使用Ingress、NodePort或LoadBalancer。
访问方式可通过设置expose.type的值来实现。
◎ Ingress:Kubernetes集群需要安装Ingress controller。注意:如果没有开启TLS,则在推送或者拉取镜像时,在命令中需要添加端口号。具体原因可参考“github.com/goharbor/harbor/issues/5291”页面。
◎ ClusterIP:通过集群的内部IP暴露Harbor。该值可支持在Kubernetes集群内部使用Harbor的场景。
◎ NodePort:通过集群中每个Node的IP 和静态端口暴露Harbor。当从集群外部访问时,通过请求NodeIP:NodePort可以访问一个NodePort服务。
◎ LoadBalancer:使用云提供商的负载均衡器,可以对外暴露Harbor。
2.配置外部地址
外部地址是客户端访问Harbor的地址,也是Harbor的管理页面显示完整的“docker”“helm”命令用到的地址;在Docker、Helm客户端交互中暴露完整的Token服务地址。
外部地址可通过设置externalURL的值来实现,格式为“protocol://domain[:port]”。在不同的访问方式下,对domain有不同的要求。
◎ Ingress:当访问方式为Ingress时,应将domain设置为expose.ingress.hosts.core的值。
◎ ClusterIP:当访问方式为ClusterIP时,应将domain设置为expose.clusterIP.name的值。
◎ NodePort:当访问方式为NodePort时,应将domain设置为Kubernetes node的IP地址:Port端口号。
◎ LoadBalancer:当访问方式为LoadBalancer时,应将domain设置为用户自定义的域名。并添加DNS的CNAME记录映射该域名为用户从云提供商处得到的域名。
此外,如果 Harbor 被部署在负载均衡器或反向代理后面,则需要将外部地址设置为负载均衡器或反向代理的访问地址。
3.配置数据持久化
Harbor Helm Chart支持以下几种存储方式。
◎ Disable:关闭持久化数据。在使用过程中产生的数据会随着Pod的消亡而消亡。在生产环境下不建议用户关闭持久化数据。
◎ Persistent Volume Claim:在部署Kubernetes集群时需要一个默认的StorageClass,该StorageClass将被用于动态地为没有设定storage class的PersistentVolumeClaims配置存储。如果需要使用非默认的StorageClass,则要在相应的组件配置下指定storageClass。如果需要使用已有的持久卷,则要在相应的组件配置下指定existingClaim。
◎ External Storage:外部存储仅支持存储镜像和Chart文件。外部存储支持的类型包括azure、gsc、s3、swift及oss。
下面分别介绍其中各项的详细配置。
服务暴露方式的配置如表3-7所示。
表3-7
data:image/s3,"s3://crabby-images/a1125/a11257389b42ca516c002e71e87b26dd0b8b0bdf" alt="img"
续表
data:image/s3,"s3://crabby-images/4cd35/4cd35e9213d253d07dac9f498f5c318d8f02feee" alt="img"
TLS的配置如表3-8所示。
表3-8
data:image/s3,"s3://crabby-images/a3b34/a3b345f3cdf96a2d395cc20452208a629b56a770" alt="img"
续表
data:image/s3,"s3://crabby-images/bf9e7/bf9e798e7b15e8085e30fb2a10b0e3f8f6ec7f7a" alt="img"
续表
data:image/s3,"s3://crabby-images/7a1b7/7a1b70073a59c4724860b057de04ef360bab2417" alt="img"
◎ 存储的配置如表3-9所示。
表3-9
data:image/s3,"s3://crabby-images/7e67f/7e67fd1454dc5bd127449fe9ac3c4ce58f87e4c7" alt="img"
续表
data:image/s3,"s3://crabby-images/0a6f9/0a6f9eac79b5432f9109a8f3eee640224cd41170" alt="img"
续表
data:image/s3,"s3://crabby-images/75cbc/75cbcd3cd87751d0be0823af0868682240f28bc3" alt="img"
◎ 一般配置如表3-10所示。
表3-10
data:image/s3,"s3://crabby-images/9b602/9b6020094c7a67fda4c93d9484336a254edeecfa" alt="img"
续表
data:image/s3,"s3://crabby-images/6b79e/6b79e5cfb96d35928a33fb26df6625f6982498f3" alt="img"
◎ Nginx的配置如表3-11所示。注意:如果访问方式是Ingress,则无须配置Nginx。
表3-11
data:image/s3,"s3://crabby-images/e59d8/e59d8c0111ddc9732934fd98be07c643793e6508" alt="img"
◎ Portal的配置如表3-12所示。
表3-12
data:image/s3,"s3://crabby-images/a67e1/a67e1198ed635d13cec65a5f5ab5a6acde7dac78" alt="img"
◎ Core的配置如表3-13所示。
表3-13
data:image/s3,"s3://crabby-images/c629b/c629b5a66178fe0d521afbb28ec1d68c4e0ca18c" alt="img"
◎ JobService的配置如表3-14所示。
表3-14
data:image/s3,"s3://crabby-images/2dcc6/2dcc689e38151323ccd7e6526bb46ada3ac50f20" alt="img"
续表
data:image/s3,"s3://crabby-images/9082b/9082b4a0cbdc6bd0b94fb190b2cc1516a225919c" alt="img"
◎ Registry的配置如表3-15所示。
表3-15
data:image/s3,"s3://crabby-images/77dab/77dabdd1e21718555763c1e3177366bab020fa45" alt="img"
续表
data:image/s3,"s3://crabby-images/305e1/305e1ff70da6b239daac9bfb728b456dbfaa1817" alt="img"
◎ ChartMuseum的配置如表3-16所示。
表3-16
data:image/s3,"s3://crabby-images/bbd0b/bbd0be084a78c8a20d662b3924e6882268d68722" alt="img"
◎ Clair的配置如表3-17所示。
表3-17
data:image/s3,"s3://crabby-images/1413e/1413e8c0387e5c3f5b5f2478dfb793a5816977ba" alt="img"
续表
data:image/s3,"s3://crabby-images/5bf6a/5bf6a91c484501488b889fee605ecb91e6bc25b5" alt="img"
◎ Trivy的配置如表3-18所示。
表3-18
data:image/s3,"s3://crabby-images/a4631/a46310c601bf6e33971151cb5b8a3b93b643eb67" alt="img"
续表
data:image/s3,"s3://crabby-images/f8c59/f8c5972ccc4db917e85fe412def451e159d5b060" alt="img"
◎ Notary组件的配置如表3-19所示。
表3-19
data:image/s3,"s3://crabby-images/59f95/59f951291866fb4f3849370d27f83f5ff7583958" alt="img"
◎ Database的配置如表3-20所示。
表3-20
data:image/s3,"s3://crabby-images/4bf03/4bf03b3a6cd6be36412aaf4a1ae37d431120b144" alt="img"
续表
data:image/s3,"s3://crabby-images/0279f/0279fa4fbcfd73bf12c7890260dd73a945d15a72" alt="img"
◎ Redis的配置如表3-21所示。
表3-21
data:image/s3,"s3://crabby-images/f3145/f3145245fb1823c3ec15f41f2f8064f781c185a8" alt="img"
续表
data:image/s3,"s3://crabby-images/fd55b/fd55bf991b2a11379b14c1bf9beb8a6c737a0f2f" alt="img"
3.2.3 安装Helm Chart
在完成Chart的配置后,使用Helm安装Harbor Helm Chart,命令如下,其中my-release为部署名。
◎ Helm 2:
data:image/s3,"s3://crabby-images/13519/135190952e4c3270e7e3679db7043e270f827f0e" alt="img"
◎ Helm 3:
data:image/s3,"s3://crabby-images/58b1b/58b1b9f7342dd12dc289a84ac649eb8362a43d21" alt="img"
使用Helm卸载Harbor Helm Chart,命令如下,其中my-release为部署名。
◎ Helm 2:
data:image/s3,"s3://crabby-images/94e5c/94e5c34b65423608ddeaa0f3d8740c69bf9d828f" alt="img"
◎ Helm 3:
data:image/s3,"s3://crabby-images/78bb1/78bb13ddc407d8529c7948159413dfc21ee24cdf" alt="img"