kubeSphere使用应用商店安装部署Harbor
从应用商店中部署 Harbor
-
查看是否已安装应用商店。
若未安装,则可以阅读 Linux安装部署KubeSphere基于k8s集群 的启用可插拔功能组件
-
找到 Harbor,设置名称并选择应用版本,点击下一步。
-
在应用配置页面,编辑 Harbor 的配置文件,请注意以下字段。
type:访问 Harbor 服务的方式。本示例使用 nodePort。
tls:指定是否启用 HTTPS。多数情况下设置为 false。
commonName:192.168.18.111 #填写自己的IP地址,用于访问的地址,这里我填写k8s-master1的IP地址。
externalURL:暴露给租户的 URL。tls 设置为 false 使用http://192.168.18.111:30002。
若 tls 设置为 true 使用https://192.168.18.111:30003。
访问 Harbor
基于配置文件中 expose.type 字段的设置,访问方式可能会不同。本示例使用 nodePort 访问 Harbor,按照先前步骤中的设置,访问http://nodeIP:30002。
data:image/s3,"s3://crabby-images/7687b/7687bac1c6ffe386853b7802d7d8fa826c3d465d" alt=""
若 tls 设置为 true,访问https://nodeIP:30003。
data:image/s3,"s3://crabby-images/95d42/95d4269626f5c5e2f67d94afeace5693beddc770" alt=""
使用默认帐户和密码 (admin/Harbor12345) 登录 Harbor。密码由配置文件中的 harborAdminPassword 字段定义。
data:image/s3,"s3://crabby-images/b77dd/b77dde73e1658d051820fbcbc08b3beaaa1b869f" alt=""
所有节点添加 Harbor 镜像仓库
Harbor根据 tls 设置使用 HTTP 和 HTTPS 为仓库请求提供服务。
-
HTTP
您需要修改集群中所有节点的 Docker 配置,如果外部 Harbor 仓库的 IP 地址为http://192.168.18.111:30002,您需要在 /etc/docker/daemon.json 文件中增加 insecure-registries 标签。
1
2
3
4
5
6
7
8vi /etc/docker/daemon.json
{
"registry-mirrors": ["https://0nth4654.mirror.aliyuncs.com"],
"insecure-registries": ["http://192.168.18.111:30002"]
}
# 重启docker
systemctl daemon-reload && systemctl restart docker若为低版本docker。
1
2
3
4
5
6vi /usr/lib/systemd/system/docker.service
#修改
ExecStart=/usr/bin/docker daemon -H fd:// --insecure-registry 192.168.18.111:30002
#重启服务
systemctl daemon-reload && systemctl restart docker进入配置中心密钥页面,创建密钥。
-
HTTPS
您需要修改集群中所有节点的 Docker 配置,如果外部 Harbor 仓库的 IP 地址为https://192.168.18.111:30003,您需要在 /etc/docker/daemon.json 文件中增加 insecure-registries 标签。
1
2
3
4
5
6
7
8vi /etc/docker/daemon.json
{
"registry-mirrors": ["https://0nth4654.mirror.aliyuncs.com"],
"insecure-registries": ["https://192.168.18.111:30003"]
}
# 重启docker
systemctl daemon-reload && systemctl restart docker若为低版本docker。
1
2
3
4
5
6vi /usr/lib/systemd/system/docker.service
#修改
ExecStart=/usr/bin/docker daemon -H fd:// --insecure-registry 192.168.18.111:30003
#重启服务
systemctl daemon-reload && systemctl restart docker进入配置中心密钥页面,创建密钥。
Harbor 镜像仓库域名设置
因为 KubeSphere 无法直接解析 harbor 域名,需要在 coredns 添加解析记录
将nodelocaldns解析都转发给coredns
data:image/s3,"s3://crabby-images/73493/73493213bd5f8e3811a2823dce8c4322f8255b52" alt=""
1 | forward . 10.233.0.3 { |
data:image/s3,"s3://crabby-images/37ea6/37ea6da5c01e043ed74b7b59841a6e0b76ee3bfc" alt=""
在coredns中添加主机记录
data:image/s3,"s3://crabby-images/0c448/0c4486c4fee092f0a7c93e1a52decdde3c5be8ef" alt=""
1 | hosts { |
data:image/s3,"s3://crabby-images/526f1/526f17dcd2d80858a0fa977bd33e23a58b045473" alt=""
通过 configmap 加载 CA 证书
进入 harbor-core 工作负载。
data:image/s3,"s3://crabby-images/a6c92/a6c92962dab6156f55e094d9606e975822aae8eb" alt=""
进入终端查看CA证书的位置及值,复制值。
data:image/s3,"s3://crabby-images/07d2d/07d2dad2ac6e04142ee15102d3c5b22309d9f11d" alt=""
data:image/s3,"s3://crabby-images/71182/71182d4d31650c6fdae5412be61df32083ce707c" alt=""
界面进入工作台>企业空间>System-workspace>项目>kubesphere-system>配置中心>配置,新建harbor4shl-ca
data:image/s3,"s3://crabby-images/da909/da9096e9899300ddcc075e90b6562946a93000f5" alt=""
data:image/s3,"s3://crabby-images/5181b/5181b16eadd43451b552c3ced7b54fd0851c3cc4" alt=""
挂载 configmap harbor4shl-ca
进入 ks-apiserve 工作负载。
data:image/s3,"s3://crabby-images/a1236/a12366577978582b81a0fe5d2559b1555df1567c" alt=""
data:image/s3,"s3://crabby-images/4ee71/4ee7151205c8c114d71cc094800d32b7b78656f9" alt=""
data:image/s3,"s3://crabby-images/0dde7/0dde7b69309a558309ea7885ef0e2a76a2341f3a" alt=""
data:image/s3,"s3://crabby-images/e84e2/e84e26f12cbec0554702633e811a1ddf97b76607" alt=""
data:image/s3,"s3://crabby-images/96489/96489aab877d7b7acb690113b65d41f6b81cf71a" alt=""
验证
进入配置中心的密钥,创建密钥。