上传文件至 'kubernetes-MD'
This commit is contained in:
parent
13ebf2dbc7
commit
bb2403d365
161
kubernetes-MD/Containerd之Kubernetes链接Harbor.md
Normal file
161
kubernetes-MD/Containerd之Kubernetes链接Harbor.md
Normal file
@ -0,0 +1,161 @@
|
||||
<h1><center>Containerd之Kubernetes链接Harbor</center></h1>
|
||||
|
||||
作者:行癫(盗版必究)
|
||||
|
||||
------
|
||||
|
||||
## 一:环境基础
|
||||
|
||||
#### 1.Harbor正常运行
|
||||
|
||||
#### 2.Kubernetes集群正常
|
||||
|
||||
注意:kubernetes集群环境1.27.3版本(containerd)
|
||||
|
||||
## 二:配置Containerd
|
||||
|
||||
Kubernetes中Containerd连接Harbor仓库,Harbor仓库支持http和https部署,Containerd支持http和https连接,默认https
|
||||
|
||||
#### 1.配置Containerd
|
||||
|
||||
修改Kubernetes集群中所有节点的Containerd配置,配置如下:
|
||||
|
||||
```shell
|
||||
[root@xingdiancloud ~]# vim /etc/containerd/config.toml
|
||||
[plugins."io.containerd.grpc.v1.cri".registry]
|
||||
config_path = "/etc/containerd/certs.d"
|
||||
[plugins."io.containerd.grpc.v1.cri".registry.configs]
|
||||
[plugins."io.containerd.grpc.v1.cri".registry.configs."10.9.12.201".auth]
|
||||
username = "admin"
|
||||
password = "Harbor12345"
|
||||
[plugins."io.containerd.grpc.v1.cri".registry.configs."192.168.1.238:180".auth]
|
||||
username = "admin"
|
||||
password = "Harbor12345"
|
||||
```
|
||||
|
||||
注意:
|
||||
|
||||
找到配置文件中对应的参数位置;将系统中多余的跟上面配置中相同的参数删除
|
||||
|
||||
```shell
|
||||
[root@xingdiancloud ~]# mkdir /etc/containerd/certs.d/10.9.12.201 -p
|
||||
[root@xingdiancloud ~]# cd /etc/containerd/certs.d/10.9.12.201
|
||||
[root@xingdiancloud ~]# cat > hosts.toml << EOF
|
||||
server = "http://10.9.12.201"
|
||||
|
||||
[host."http://10.9.12.201"]
|
||||
capabilities = ["pull", "resolve", "push"]
|
||||
skip_verify = true
|
||||
EOF
|
||||
```
|
||||
|
||||
#### 2.重新启动Containerd
|
||||
|
||||
```shell
|
||||
[root@xingdiancloud ~]# systemctl restart containerd
|
||||
```
|
||||
|
||||
## 三:集群测试
|
||||
|
||||
#### 1.创建Deployment
|
||||
|
||||
```yaml
|
||||
---
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
annotations: {}
|
||||
labels:
|
||||
k8s.kuboard.cn/name: test
|
||||
name: test
|
||||
namespace: default
|
||||
resourceVersion: '397590'
|
||||
spec:
|
||||
progressDeadlineSeconds: 600
|
||||
replicas: 1
|
||||
revisionHistoryLimit: 10
|
||||
selector:
|
||||
matchLabels:
|
||||
k8s.kuboard.cn/name: test
|
||||
strategy:
|
||||
rollingUpdate:
|
||||
maxSurge: 25%
|
||||
maxUnavailable: 25%
|
||||
type: RollingUpdate
|
||||
template:
|
||||
metadata:
|
||||
creationTimestamp: null
|
||||
labels:
|
||||
k8s.kuboard.cn/name: test
|
||||
spec:
|
||||
containers:
|
||||
- image: 10.9.12.201/xingdian/nginx:v1
|
||||
imagePullPolicy: IfNotPresent
|
||||
name: nginx
|
||||
ports:
|
||||
- containerPort: 80
|
||||
name: http
|
||||
protocol: TCP
|
||||
resources: {}
|
||||
terminationMessagePath: /dev/termination-log
|
||||
terminationMessagePolicy: File
|
||||
volumeMounts:
|
||||
- mountPath: /usr/share/nginx/html
|
||||
name: volume-j2ijw
|
||||
dnsPolicy: ClusterFirst
|
||||
restartPolicy: Always
|
||||
schedulerName: default-scheduler
|
||||
securityContext: {}
|
||||
terminationGracePeriodSeconds: 30
|
||||
volumes:
|
||||
- name: volume-j2ijw
|
||||
nfs:
|
||||
path: /opt/xingdiancloud_1
|
||||
server: 10.9.12.250
|
||||
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
annotations: {}
|
||||
labels:
|
||||
k8s.kuboard.cn/name: test
|
||||
name: test
|
||||
namespace: default
|
||||
resourceVersion: '397893'
|
||||
spec:
|
||||
clusterIP: 10.99.28.173
|
||||
clusterIPs:
|
||||
- 10.99.28.173
|
||||
externalTrafficPolicy: Cluster
|
||||
internalTrafficPolicy: Cluster
|
||||
ipFamilies:
|
||||
- IPv4
|
||||
ipFamilyPolicy: SingleStack
|
||||
ports:
|
||||
- name: xbcbcp
|
||||
nodePort: 30009
|
||||
port: 80
|
||||
protocol: TCP
|
||||
targetPort: 80
|
||||
selector:
|
||||
k8s.kuboard.cn/name: test
|
||||
sessionAffinity: None
|
||||
type: NodePort
|
||||
```
|
||||
|
||||
注意:
|
||||
|
||||
此yaml文件中创建的Deployment、Service;还使用了持久化存储;需要借鉴使用。
|
||||
|
||||
#### 2.运行状态
|
||||
|
||||

|
||||
|
||||
#### 3.访问服务
|
||||
|
||||

|
||||
|
||||
注意:
|
||||
|
||||
以上任何一项都可以说明Kubernetes集群中Containerd可以使用Harbor仓库http方式下载镜像
|
Loading…
Reference in New Issue
Block a user