目录
[2.Linux 部署docker compose](#2.Linux 部署docker compose)
[4.K8S 1.29版本 部署Harbor](#4.K8S 1.29版本 部署Harbor)
[5.K8S 1.29版本 使用Harbor](#5.K8S 1.29版本 使用Harbor)
[1.docker 登录harbor失败](#1.docker 登录harbor失败)
一、实验
1.环境
(1)主机
表1 主机
|--------|--------------|--------|----------------|------------|
| 主机 | 架构 | 版本 | IP | 备注 |
| master | K8S master节点 | 1.29.0 | 192.168.204.8 | |
| node1 | K8S node节点 | 1.29.0 | 192.168.204.9 | |
| node2 | K8S node节点 | 1.29.0 | 192.168.204.10 | 已部署Kuboard |
(2)master节点查看集群
bash
1)查看node
kubectl get node
2)查看node详细信息
kubectl get node -o wide
data:image/s3,"s3://crabby-images/fbe66/fbe6626d384c4cda5364d0d673e89d1863df147e" alt=""
data:image/s3,"s3://crabby-images/bfbae/bfbae7070821a6fda5f8c557bd9a63eb7a36b41d" alt=""
(3)查看pod
bash
[root@master ~]# kubectl get pod -A
data:image/s3,"s3://crabby-images/8af5d/8af5d092a4ec88736ebeccbee191248f4bc4441c" alt=""
(4) 访问Kuboard
bash
http://192.168.204.10:30080/kuboard/cluster
查看节点
data:image/s3,"s3://crabby-images/1f496/1f4969e5ba97c995a3945e94f1d5e3ad0b3ea1af" alt=""
(5)查看docker版本
bash
docker -v
master节点
data:image/s3,"s3://crabby-images/a3c2b/a3c2b463ff4dbd23c4a691309b0a07bc87775fb0" alt=""
node1节点
data:image/s3,"s3://crabby-images/79115/79115819c05f6140bada7a5b01068ab2e75e69ab" alt=""
node2节点
data:image/s3,"s3://crabby-images/0704b/0704b55152da1df09e440d5cd7c3e351605cb900" alt=""
2.Linux 部署docker compose
(1) 查阅
bash
https://github.com/docker/compose/releases
最新版为v2.27.0
data:image/s3,"s3://crabby-images/96832/9683242b716b3714dc311782119fd2ea23657058" alt=""
(2) 下载
bash
https://github.com/docker/compose/releases/download/v2.27.0/docker-compose-linux-x86_64
(3) 查看
bash
[root@master ~]# ls | grep docker
data:image/s3,"s3://crabby-images/2e202/2e202d2120d1c56e87d900489d02f9e772c27821" alt=""
(4)移动并更名为docker-compose
bash
[root@master ~]# mv docker-compose-linux-x86_64 /usr/bin/docker-compose
data:image/s3,"s3://crabby-images/634cd/634cd7d50e7dc4ce96e1e3ab0507a183ae274285" alt=""
(5)为二进制文件添加可执行权限
bash
[root@master ~]# chmod +x /usr/bin/docker-compose
data:image/s3,"s3://crabby-images/de66b/de66b1c141507f714151e40f6e3d97860c03bcca" alt=""
(6)查看docker-compse版本
bash
[root@master ~]# docker-compose version
data:image/s3,"s3://crabby-images/cd089/cd089181427c5e8adfeff043d14baf6db2cef2f5" alt=""
3.证书秘钥配置
(1)确认openssl
bash
[root@master harbor]# rpm -q openssl
data:image/s3,"s3://crabby-images/2d339/2d339285af6e1bf4f290fc0f09293900826e6ec5" alt=""
(2)创建文件夹用于存放生成的证书秘钥文件
bash
[root@master ~]# mkdir -p /harbor/certs/
data:image/s3,"s3://crabby-images/91791/917912dc3121a98cc3b54bfddaf6e579bd450543" alt=""
(3) 生成私钥
bash
[root@master ~]# openssl genrsa -out ca.key 4096
data:image/s3,"s3://crabby-images/6e24a/6e24afe2f92e7cbcaa0454afd1b07b435d3d0194" alt=""
(4)证书秘钥与IP绑定
bash
openssl req -x509 -new -nodes -sha512 -days 3650 \
-subj "/C=CN/ST=Nanjing/L=Nanjing/O=example/OU=Personal/CN=192.168.204.8" \
-key ca.key \
-out ca.crt
data:image/s3,"s3://crabby-images/e5191/e5191bdfdc021670facf9b0b2b0a211c56c48406" alt=""
(5)移动证书位置并查看
bash
[root@master ~]# mv ca* /harbor/certs
[root@master ~]# ls /harbor/certs/
data:image/s3,"s3://crabby-images/d78da/d78dadb0e2b1fceeb75f55cc7648641108be4bcb" alt=""
4.K8S 1.29版本 部署Harbor
(1) 查阅
bash
https://github.com/goharbor/harbor/releases
最新版为v2.10.2
(2) 下载
bash
https://github.com/goharbor/harbor/releases/download/v2.10.2/harbor-offline-installer-v2.10.2.tgz
(3)查看
bash
[root@master ~]# ls | grep harbor
data:image/s3,"s3://crabby-images/ce09d/ce09d11b492cec3deb125a8f32bde42bffa3b4b3" alt=""
(4)解压
bash
[root@master ~]# tar xf harbor-offline-installer-v2.10.2.tgz
data:image/s3,"s3://crabby-images/4c6a6/4c6a66fb11288e5f6aac098697690de2915e3ee2" alt=""
(6)进入目录并查看
bash
[root@master ~]# cd harbor/
[root@master harbor]# ls
data:image/s3,"s3://crabby-images/7e320/7e320360067d4fcbe7c6c9ac87eb94ec46c58503" alt=""
(7) 修改名称
bash
[root@master harbor]# mv harbor.yml.tmpl harbor.yml
data:image/s3,"s3://crabby-images/0c3b9/0c3b92ba88dd3ceb700c82aed60f517a4e4c1720" alt=""
(8)监听端口
8800与8443没有被占用
bash
[root@master harbor]# netstat -antlp | grep 8800
[root@master harbor]# netstat -antlp | grep 8443
data:image/s3,"s3://crabby-images/59c75/59c75ae4c3d6a7f067ea98f963b431310532370e" alt=""
(9)修改配置文件
bash
[root@master harbor]# vim harbor.yml
data:image/s3,"s3://crabby-images/abb8e/abb8e87c3bf393391a1b898aa6d159d80ac54a0b" alt=""
bash
hostname域名修改为要安装harbor的服务器的ip
http端口修改为8800
https端口修改为8443
certificate: 证书路径修改为/harbor/certs/ca.crt
private_key: 秘钥路径修改为/harbor/certs/ca.key
harbor_admin_password: 默认Harbor密码,不修改,就用默认的Harbor12345
data_value: 修改为/data/harbor
修改前:
data:image/s3,"s3://crabby-images/112b5/112b528ef407dd5fddf404ab3085e236de568370" alt=""
data:image/s3,"s3://crabby-images/55c87/55c874ffc017f8144dbb2738d7aa89a1548d3325" alt=""
修改后:
data:image/s3,"s3://crabby-images/3b725/3b725a462c5d5ae4fb3ff7013947b294b40940c8" alt=""
data:image/s3,"s3://crabby-images/69c90/69c90f71973193d375112e8e19ffc04db9938211" alt=""
(10)Docker Hub查看镜像
bash
docker pull goharbor/prepare:v2.10.2
data:image/s3,"s3://crabby-images/c46f5/c46f50ee1e87872812b8184fff19231e4106a67c" alt=""
(11)拉取镜像
node2
bash
[root@node2 ~]# docker pull goharbor/prepare:v2.10.2
data:image/s3,"s3://crabby-images/18f15/18f15cf77b2fcf2a6a6538a95d2714f8f1b72aa5" alt=""
(12) 导出镜像
bash
[root@node2 ~]# docker save -o prepare.tar goharbor/prepare:v2.10.2
data:image/s3,"s3://crabby-images/bf227/bf227dc2f8e0efa31d3759ba9fbb4288ae07e439" alt=""
(13)复制Docker镜像到master节点
bash
[root@node2 ~]# scp prepare.tar root@master:~
data:image/s3,"s3://crabby-images/42537/42537c9228876826d09a60e94ecbbc309f90fa0f" alt=""
(14)master节点导入Docker镜像
bash
[root@master ~]# docker load -i prepare.tar
data:image/s3,"s3://crabby-images/86946/86946bfbd72a8f989f0b10a2a236349066a84989" alt=""
(15)执行预备脚本
bash
[root@master harbor]# ./prepare
data:image/s3,"s3://crabby-images/a50ad/a50ad0c2a30cfcdf0f18eba8625e722d0f44218b" alt=""
(16) 执行安装脚本
bash
[root@master harbor]# ./install.sh
[Step 0]: checking if docker is installed ...
Note: docker version: 24.0.7
[Step 1]: checking docker-compose is installed ...
Note: Docker Compose version v2.21.0
[Step 2]: loading Harbor images ...
a8840e4ae316: Loading layer [==================================================>] 21.63MB/21.63MB
515f0ee642d6: Loading layer [==================================================>] 173.8MB/173.8MB
7e1a15fa7f7c: Loading layer [==================================================>] 25.5MB/25.5MB
4cd39a5aa67d: Loading layer [==================================================>] 18.27MB/18.27MB
3daae6a42996: Loading layer [==================================================>] 5.12kB/5.12kB
e23a6fbc3acf: Loading layer [==================================================>] 6.144kB/6.144kB
87a67eef40a6: Loading layer [==================================================>] 3.072kB/3.072kB
5439373f0cf5: Loading layer [==================================================>] 2.048kB/2.048kB
44c50cb14a57: Loading layer [==================================================>] 2.56kB/2.56kB
e343431b8ac0: Loading layer [==================================================>] 7.68kB/7.68kB
Loaded image: goharbor/harbor-db:v2.10.2
a7437080fdff: Loading layer [==================================================>] 17.16MB/17.16MB
89c54c70338a: Loading layer [==================================================>] 3.584kB/3.584kB
927d190fe457: Loading layer [==================================================>] 2.56kB/2.56kB
dab52f006605: Loading layer [==================================================>] 44.92MB/44.92MB
abc8dcfeeb98: Loading layer [==================================================>] 45.71MB/45.71MB
Loaded image: goharbor/harbor-jobservice:v2.10.2
9343d1011e8e: Loading layer [==================================================>] 21.63MB/21.63MB
d8aa785c45d8: Loading layer [==================================================>] 110.6MB/110.6MB
af30438adf19: Loading layer [==================================================>] 3.072kB/3.072kB
046baf104eef: Loading layer [==================================================>] 59.9kB/59.9kB
b4bf035573f1: Loading layer [==================================================>] 61.95kB/61.95kB
Loaded image: goharbor/redis-photon:v2.10.2
1a53aa673223: Loading layer [==================================================>] 14.15MB/14.15MB
e3ef818740f3: Loading layer [==================================================>] 4.096kB/4.096kB
f51244ac7c03: Loading layer [==================================================>] 3.072kB/3.072kB
971632584e63: Loading layer [==================================================>] 17.4MB/17.4MB
0cfb29c07835: Loading layer [==================================================>] 18.19MB/18.19MB
Loaded image: goharbor/registry-photon:v2.10.2
9fb8de59ccbd: Loading layer [==================================================>] 130.9MB/130.9MB
b0a99212add7: Loading layer [==================================================>] 3.584kB/3.584kB
c63a00cfdba3: Loading layer [==================================================>] 3.072kB/3.072kB
ea1dbece5b3a: Loading layer [==================================================>] 2.56kB/2.56kB
3c735fb3805e: Loading layer [==================================================>] 3.072kB/3.072kB
1b257c0b8709: Loading layer [==================================================>] 3.584kB/3.584kB
6bb174e7db78: Loading layer [==================================================>] 20.48kB/20.48kB
Loaded image: goharbor/harbor-log:v2.10.2
ea9d3f5fbb0c: Loading layer [==================================================>] 121.2MB/121.2MB
b88bdbd268ea: Loading layer [==================================================>] 6.532MB/6.532MB
a6a0154f827a: Loading layer [==================================================>] 246.8kB/246.8kB
664d5baa31ef: Loading layer [==================================================>] 1.477MB/1.477MB
Loaded image: goharbor/harbor-portal:v2.10.2
fe6dfc816265: Loading layer [==================================================>] 17.16MB/17.16MB
c8d1d3bbdf04: Loading layer [==================================================>] 3.584kB/3.584kB
a95b761bfdbe: Loading layer [==================================================>] 2.56kB/2.56kB
c3c092020a00: Loading layer [==================================================>] 58.96MB/58.96MB
75c8aba5c8aa: Loading layer [==================================================>] 5.632kB/5.632kB
84bdcacb7f37: Loading layer [==================================================>] 123.4kB/123.4kB
c80d23d5cead: Loading layer [==================================================>] 80.38kB/80.38kB
fb9a83422043: Loading layer [==================================================>] 59.95MB/59.95MB
17416c18f4d3: Loading layer [==================================================>] 2.56kB/2.56kB
Loaded image: goharbor/harbor-core:v2.10.2
6a65c62b44a3: Loading layer [==================================================>] 14.15MB/14.15MB
50d4a017d046: Loading layer [==================================================>] 4.096kB/4.096kB
b00285e03979: Loading layer [==================================================>] 17.4MB/17.4MB
bd20c4f45bc4: Loading layer [==================================================>] 3.072kB/3.072kB
cdef8cae2c49: Loading layer [==================================================>] 32.77MB/32.77MB
8c8e4274f70f: Loading layer [==================================================>] 50.95MB/50.95MB
Loaded image: goharbor/harbor-registryctl:v2.10.2
acbecb34a764: Loading layer [==================================================>] 17.16MB/17.16MB
478163dbc994: Loading layer [==================================================>] 27.56MB/27.56MB
4ec3465523a2: Loading layer [==================================================>] 4.608kB/4.608kB
07fb78bc4c52: Loading layer [==================================================>] 28.35MB/28.35MB
Loaded image: goharbor/harbor-exporter:v2.10.2
113051e862a0: Loading layer [==================================================>] 121.2MB/121.2MB
Loaded image: goharbor/nginx-photon:v2.10.2
2716f555462f: Loading layer [==================================================>] 14.67MB/14.67MB
d4471d1781eb: Loading layer [==================================================>] 4.096kB/4.096kB
2b9cfa166f1f: Loading layer [==================================================>] 3.072kB/3.072kB
4943bbb50494: Loading layer [==================================================>] 209.9MB/209.9MB
1f70ad7459fb: Loading layer [==================================================>] 17.45MB/17.45MB
c6de541f3b98: Loading layer [==================================================>] 228.1MB/228.1MB
Loaded image: goharbor/trivy-adapter-photon:v2.10.2
Loaded image: goharbor/prepare:v2.10.2
[Step 3]: preparing environment ...
[Step 4]: preparing harbor configs ...
prepare base dir is set to /root/harbor
Clearing the configuration file: /config/portal/nginx.conf
Clearing the configuration file: /config/log/logrotate.conf
Clearing the configuration file: /config/log/rsyslog_docker.conf
Clearing the configuration file: /config/nginx/nginx.conf
Clearing the configuration file: /config/core/env
Clearing the configuration file: /config/core/app.conf
Clearing the configuration file: /config/registry/passwd
Clearing the configuration file: /config/registry/config.yml
Clearing the configuration file: /config/registryctl/env
Clearing the configuration file: /config/registryctl/config.yml
Clearing the configuration file: /config/db/env
Clearing the configuration file: /config/jobservice/env
Clearing the configuration file: /config/jobservice/config.yml
Generated configuration file: /config/portal/nginx.conf
Generated configuration file: /config/log/logrotate.conf
Generated configuration file: /config/log/rsyslog_docker.conf
Generated configuration file: /config/nginx/nginx.conf
Generated configuration file: /config/core/env
Generated configuration file: /config/core/app.conf
Generated configuration file: /config/registry/config.yml
Generated configuration file: /config/registryctl/env
Generated configuration file: /config/registryctl/config.yml
Generated configuration file: /config/db/env
Generated configuration file: /config/jobservice/env
Generated configuration file: /config/jobservice/config.yml
loaded secret from file: /data/secret/keys/secretkey
Generated configuration file: /compose_location/docker-compose.yml
Clean up the input dir
Note: stopping existing Harbor instance ...
[Step 5]: starting Harbor ...
[+] Running 10/10
✔ Network harbor_harbor Created 0.1s
✔ Container harbor-log Started 0.0s
✔ Container registry Started 0.1s
✔ Container registryctl Started 0.1s
✔ Container harbor-portal Started 0.1s
✔ Container harbor-db Started 0.1s
✔ Container redis Started 0.1s
✔ Container harbor-core Started 0.0s
✔ Container nginx Started 0.0s
✔ Container harbor-jobservice Started 0.0s
✔ ----Harbor has been installed and started successfully.----
(17) 查看harbor相关容器
bash
[root@master harbor]# docker ps | grep goharbor
data:image/s3,"s3://crabby-images/25e2e/25e2e59eeb5a46a374e29c22c7471b6c6530f187" alt=""
(18)docker-compose命令显示其管理的harbor容器
bash
[root@master harbor]# docker-compose -f docker-compose.yml ps
data:image/s3,"s3://crabby-images/dff5f/dff5f57044ab2b055dbfd84b4f299265a94eb370" alt=""
(19)访问harbor
bash
https://192.168.204.8:8443/
选高级
data:image/s3,"s3://crabby-images/56cea/56cea7ab1eab22965d281bf5b27cb28ff25d1fa8" alt=""
继续访问
data:image/s3,"s3://crabby-images/19e17/19e17bdb65e50815dea81ea34cf7b8a2fadff31f" alt=""
弹出界面
data:image/s3,"s3://crabby-images/ccd5f/ccd5f5004aa4409b23a1c2e8647e00beb6dbce43" alt=""
(20)登录
bash
账号:admin
密码:Harbor12345
data:image/s3,"s3://crabby-images/59243/5924345494e407c8e0c3ab61c7db74a38fb617d9" alt=""
成功进入系统
data:image/s3,"s3://crabby-images/17edc/17edca45e1cc72918df6305f9d82d09d0e51241f" alt=""
5. K8S 1.29版本 使用Harbor
(1) 创建私有项目
data:image/s3,"s3://crabby-images/d9120/d91209e05b6b1a3fc03460082f6cc1d32227b8e6" alt=""
(2) 查看
data:image/s3,"s3://crabby-images/9dda1/9dda1fd9b2a66043b69db5c8abf5df77aaf4ebf9" alt=""
目前项目为空
data:image/s3,"s3://crabby-images/4b27a/4b27a86cbfbc964db81fea19fe81374793efe64f" alt=""
(3) 创建公开项目
data:image/s3,"s3://crabby-images/83f1a/83f1aa4a62a556f285970ce7305991c7f2d5ebe7" alt=""
(4)再次查看
data:image/s3,"s3://crabby-images/6cc59/6cc5901449bbd18dbaecdbc0a61a51206699f386" alt=""
目前项目为空
data:image/s3,"s3://crabby-images/6c1ee/6c1ee4c23287d279e44ece30506aaa80b5be0275" alt=""
(5)Docker配置Harbor(所有节点)
bash
1)修改
vim /etc/docker/daemon.json
......
"insecure-registries": ["https://192.168.204.8:8443"]
......
2)重新加载配置
systemctl daemon-reload
3)重启服务
systemctl restart docker
systemctl restart cri-docker
修改前:
data:image/s3,"s3://crabby-images/66262/6626292462e888b47a1fe6742d296ab4a3468224" alt=""
修改后:
data:image/s3,"s3://crabby-images/3bf00/3bf00473899b1838fd1f71d1ab25f8099b42f82c" alt=""
这里以node1节点为例
bash
[root@node1 ~]# systemctl status cri-docker
data:image/s3,"s3://crabby-images/3395f/3395f06d1f6cb0daa9260d319748522fdea66e2e" alt=""
data:image/s3,"s3://crabby-images/14d95/14d95f0789a816bf7563442c7cd9d46b459c8e74" alt=""
data:image/s3,"s3://crabby-images/b570a/b570a9847dd911a712f98ade67760657321da48a" alt=""
data:image/s3,"s3://crabby-images/b051c/b051c0615aa8b1bd3dfbc78657a7ef6dff8da61f" alt=""
(6)docker 登录harbor并推送镜像到公开项目
node1节点
bash
[root@node1 ~]# docker login 192.168.204.8:8443 -u admin -p Harbor12345
data:image/s3,"s3://crabby-images/5da26/5da26440d96b9b0a6004061d2c63ed1c1f075bb3" alt=""
拉取镜像
data:image/s3,"s3://crabby-images/a885e/a885e5e540adccc40069b327c5f14748904933c2" alt=""
打标签
bash
[root@node1 ~]# docker tag alpine:latest 192.168.204.8:8443/devops02/alpine:20240502
data:image/s3,"s3://crabby-images/ccb68/ccb68e8f4c1866605d584370fa09dbcea487791e" alt=""
推送镜像到公开项目
bash
[root@node1 ~]# docker push 192.168.204.8:8443/devops02/alpine:20240502
data:image/s3,"s3://crabby-images/85152/8515285d1a2de0184f392dafe60495b512d99f20" alt=""
查看
data:image/s3,"s3://crabby-images/b0fe5/b0fe578d867e65e607bb50237f1de62577f537e2" alt=""
删除本地镜像
bash
[root@node1 ~]# docker rmi -f 192.168.204.8:8443/devops02/alpine:20240502
data:image/s3,"s3://crabby-images/f6557/f6557e7f486257a6022b934b7c96a1e92d5f375c" alt=""
拉取harbor仓库的镜像
bash
[root@node1 ~]# docker pull 192.168.204.8:8443/devops02/alpine:20240502
data:image/s3,"s3://crabby-images/ab6f6/ab6f6caebd6ef3d8149e7e8f41add48d1f2daa8f" alt=""
(7)docker 登录harbor并推送镜像到私有项目
打标签
bash
[root@node1 ~]# docker tag alpine:latest 192.168.204.8:8443/devops01/alpine:20240502
data:image/s3,"s3://crabby-images/c07af/c07af56afc60b95d7e20221151a55e7266536496" alt=""
推送镜像到私有项目
bash
[root@node1 ~]# docker push 192.168.204.8:8443/devops01/alpine:20240502
data:image/s3,"s3://crabby-images/fb28c/fb28c10d7da8ab0c34190035c710ec40e0220efc" alt=""
查看
data:image/s3,"s3://crabby-images/566a6/566a6dbb59e80a098fda1b097d3c78405b3a6dcf" alt=""
删除本地镜像
bash
[root@node1 ~]# docker rmi -f 192.168.204.8:8443/devops01/alpine:20240502
data:image/s3,"s3://crabby-images/0edec/0edec69e685084498a8debc56236766a373b034e" alt=""
拉取harbor仓库的镜像
bash
[root@node1 ~]# docker pull 192.168.204.8:8443/devops01/alpine:20240502
(8) 登出账号
bash
[root@node1 ~]# docker logout 192.168.204.8
data:image/s3,"s3://crabby-images/5dbed/5dbed81e1c712e7fc5c4747e4f7eef84d6eea266" alt=""
(9)其他方式的harbor部署
可以参考本人博客:
Docker容器与虚拟化技术:Harbor私有仓库部署与迁移-CSDN博客
云原生Kubernetes:K8S集群使用带凭证的harbor仓库-CSDN博客
二、问题
1.docker 登录harbor失败
(1)报错
bash
Error response from daemon: Get "https://192.168.204.8:8443/v2/": tls: failed to verify certificate: x509: certificate relies on legacy Common Name field, use SANs instead
data:image/s3,"s3://crabby-images/98715/98715c10d0db141ad8d7449817c9fe61355afaae" alt=""
(2)原因分析
未重启docker。
(3)解决方法
重启docker:
bash
[root@node1 ~]# systemctl restart docker
data:image/s3,"s3://crabby-images/6542c/6542c8fbf8364b3f13d8df4a2713a35b8e9d9755" alt=""
成功:
data:image/s3,"s3://crabby-images/1ec1c/1ec1ca63092e70fa12d1fbd53b4833ef2213c44a" alt=""