mirror of
https://github.com/kubernetes-sigs/kind.git
synced 2025-12-01 07:26:05 +07:00
181 lines
4.7 KiB
Go
181 lines
4.7 KiB
Go
/*
|
|
Copyright 2019 The Kubernetes Authors.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
package nodeimage
|
|
|
|
/*
|
|
The default PV driver manifest and images are provisionally rancher.io/local-path-provisioner
|
|
NOTE: we have customized it in the following ways:
|
|
- storage is under /var instead of /opt
|
|
- our own image and helper image
|
|
- schedule to linux nodes only
|
|
- install as the default storage class
|
|
*/
|
|
|
|
const storageProvisionerImage = "docker.io/kindest/local-path-provisioner:v20240513-b9bba138"
|
|
const storageHelperImage = "docker.io/kindest/local-path-helper:v20230510-486859a6"
|
|
|
|
// image we need to preload
|
|
var defaultStorageImages = []string{storageProvisionerImage, storageHelperImage}
|
|
|
|
const defaultStorageManifest = `
|
|
apiVersion: v1
|
|
kind: Namespace
|
|
metadata:
|
|
name: local-path-storage
|
|
|
|
---
|
|
apiVersion: v1
|
|
kind: ServiceAccount
|
|
metadata:
|
|
name: local-path-provisioner-service-account
|
|
namespace: local-path-storage
|
|
|
|
---
|
|
apiVersion: rbac.authorization.k8s.io/v1
|
|
kind: ClusterRole
|
|
metadata:
|
|
name: local-path-provisioner-role
|
|
rules:
|
|
- apiGroups: [ "" ]
|
|
resources: [ "nodes", "persistentvolumeclaims", "configmaps" ]
|
|
verbs: [ "get", "list", "watch" ]
|
|
- apiGroups: [ "" ]
|
|
resources: [ "endpoints", "persistentvolumes", "pods" ]
|
|
verbs: [ "*" ]
|
|
- apiGroups: [ "" ]
|
|
resources: [ "events" ]
|
|
verbs: [ "create", "patch" ]
|
|
- apiGroups: [ "storage.k8s.io" ]
|
|
resources: [ "storageclasses" ]
|
|
verbs: [ "get", "list", "watch" ]
|
|
|
|
---
|
|
apiVersion: rbac.authorization.k8s.io/v1
|
|
kind: ClusterRoleBinding
|
|
metadata:
|
|
name: local-path-provisioner-bind
|
|
roleRef:
|
|
apiGroup: rbac.authorization.k8s.io
|
|
kind: ClusterRole
|
|
name: local-path-provisioner-role
|
|
subjects:
|
|
- kind: ServiceAccount
|
|
name: local-path-provisioner-service-account
|
|
namespace: local-path-storage
|
|
|
|
---
|
|
apiVersion: apps/v1
|
|
kind: Deployment
|
|
metadata:
|
|
name: local-path-provisioner
|
|
namespace: local-path-storage
|
|
spec:
|
|
replicas: 1
|
|
selector:
|
|
matchLabels:
|
|
app: local-path-provisioner
|
|
template:
|
|
metadata:
|
|
labels:
|
|
app: local-path-provisioner
|
|
spec:
|
|
nodeSelector:
|
|
kubernetes.io/os: linux
|
|
# TODO: Remove the "master" taint after kubeadm nodes no longer have it.
|
|
# This can be done once kind no longer supports kubeadm 1.24.
|
|
# https://github.com/kubernetes-sigs/kind/issues/1699
|
|
tolerations:
|
|
- key: node-role.kubernetes.io/control-plane
|
|
operator: Equal
|
|
effect: NoSchedule
|
|
- key: node-role.kubernetes.io/master
|
|
operator: Equal
|
|
effect: NoSchedule
|
|
serviceAccountName: local-path-provisioner-service-account
|
|
containers:
|
|
- name: local-path-provisioner
|
|
image: ` + storageProvisionerImage + `
|
|
imagePullPolicy: IfNotPresent
|
|
command:
|
|
- local-path-provisioner
|
|
- --debug
|
|
- start
|
|
- --helper-image
|
|
- ` + storageHelperImage + `
|
|
- --config
|
|
- /etc/config/config.json
|
|
volumeMounts:
|
|
- name: config-volume
|
|
mountPath: /etc/config/
|
|
env:
|
|
- name: POD_NAMESPACE
|
|
valueFrom:
|
|
fieldRef:
|
|
fieldPath: metadata.namespace
|
|
volumes:
|
|
- name: config-volume
|
|
configMap:
|
|
name: local-path-config
|
|
|
|
---
|
|
apiVersion: storage.k8s.io/v1
|
|
kind: StorageClass
|
|
metadata:
|
|
name: standard
|
|
namespace: kube-system
|
|
annotations:
|
|
storageclass.kubernetes.io/is-default-class: "true"
|
|
provisioner: rancher.io/local-path
|
|
volumeBindingMode: WaitForFirstConsumer
|
|
reclaimPolicy: Delete
|
|
|
|
---
|
|
kind: ConfigMap
|
|
apiVersion: v1
|
|
metadata:
|
|
name: local-path-config
|
|
namespace: local-path-storage
|
|
data:
|
|
config.json: |-
|
|
{
|
|
"nodePathMap":[
|
|
{
|
|
"node":"DEFAULT_PATH_FOR_NON_LISTED_NODES",
|
|
"paths":["/var/local-path-provisioner"]
|
|
}
|
|
]
|
|
}
|
|
setup: |-
|
|
#!/bin/sh
|
|
set -eu
|
|
mkdir -m 0777 -p "$VOL_DIR"
|
|
teardown: |-
|
|
#!/bin/sh
|
|
set -eu
|
|
rm -rf "$VOL_DIR"
|
|
helperPod.yaml: |-
|
|
apiVersion: v1
|
|
kind: Pod
|
|
metadata:
|
|
name: helper-pod
|
|
spec:
|
|
containers:
|
|
- name: helper-pod
|
|
image: ` + storageHelperImage + `
|
|
imagePullPolicy: IfNotPresent
|
|
`
|