vault-csi: deploy vault provider daemonset
This commit is contained in:
parent
5666eceec7
commit
2acc7a06b2
@ -1,7 +1,6 @@
|
|||||||
# infrastructure/vault-csi/kustomization.yaml
|
# infrastructure/vault-csi/kustomization.yaml
|
||||||
apiVersion: kustomize.config.k8s.io/v1beta1
|
apiVersion: kustomize.config.k8s.io/v1beta1
|
||||||
kind: Kustomization
|
kind: Kustomization
|
||||||
namespace: kube-system
|
|
||||||
resources:
|
resources:
|
||||||
- secrets-store-csi-driver.yaml
|
- secrets-store-csi-driver.yaml
|
||||||
- vault-csi-provider.yaml
|
- vault-csi-provider.yaml
|
||||||
|
|||||||
@ -1,17 +1,111 @@
|
|||||||
# infrastructure/vault-csi/vault-csi-provider.yaml
|
# infrastructure/vault-csi/vault-csi-provider.yaml
|
||||||
apiVersion: helm.toolkit.fluxcd.io/v2
|
apiVersion: v1
|
||||||
kind: HelmRelease
|
kind: ServiceAccount
|
||||||
metadata:
|
metadata:
|
||||||
name: vault-csi-provider
|
name: vault-csi-provider
|
||||||
namespace: kube-system
|
namespace: kube-system
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: ClusterRole
|
||||||
|
metadata:
|
||||||
|
name: vault-csi-provider-clusterrole
|
||||||
|
rules:
|
||||||
|
- apiGroups: [""]
|
||||||
|
resources: ["serviceaccounts/token"]
|
||||||
|
verbs: ["create"]
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: ClusterRoleBinding
|
||||||
|
metadata:
|
||||||
|
name: vault-csi-provider-clusterrolebinding
|
||||||
|
roleRef:
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
kind: ClusterRole
|
||||||
|
name: vault-csi-provider-clusterrole
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: vault-csi-provider
|
||||||
|
namespace: kube-system
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: Role
|
||||||
|
metadata:
|
||||||
|
name: vault-csi-provider-role
|
||||||
|
namespace: kube-system
|
||||||
|
rules:
|
||||||
|
- apiGroups: [""]
|
||||||
|
resources: ["secrets"]
|
||||||
|
verbs: ["get"]
|
||||||
|
resourceNames: ["vault-csi-provider-hmac-key"]
|
||||||
|
- apiGroups: [""]
|
||||||
|
resources: ["secrets"]
|
||||||
|
verbs: ["create"]
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: RoleBinding
|
||||||
|
metadata:
|
||||||
|
name: vault-csi-provider-rolebinding
|
||||||
|
namespace: kube-system
|
||||||
|
roleRef:
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
kind: Role
|
||||||
|
name: vault-csi-provider-role
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: vault-csi-provider
|
||||||
|
namespace: kube-system
|
||||||
|
---
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: DaemonSet
|
||||||
|
metadata:
|
||||||
|
name: vault-csi-provider
|
||||||
|
namespace: kube-system
|
||||||
|
labels: { app.kubernetes.io/name: vault-csi-provider }
|
||||||
spec:
|
spec:
|
||||||
interval: 15m
|
updateStrategy:
|
||||||
chart:
|
type: RollingUpdate
|
||||||
|
selector:
|
||||||
|
matchLabels: { app.kubernetes.io/name: vault-csi-provider }
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels: { app.kubernetes.io/name: vault-csi-provider }
|
||||||
spec:
|
spec:
|
||||||
chart: vault-csi-provider
|
serviceAccountName: vault-csi-provider
|
||||||
version: "~1.1.0"
|
containers:
|
||||||
sourceRef:
|
- name: provider-vault-installer
|
||||||
kind: HelmRepository
|
image: hashicorp/vault-csi-provider:1.7.0
|
||||||
name: hashicorp
|
imagePullPolicy: IfNotPresent
|
||||||
namespace: flux-system
|
args:
|
||||||
values: {}
|
- -endpoint=/provider/vault.sock
|
||||||
|
- -log-level=info
|
||||||
|
resources:
|
||||||
|
requests: { cpu: 50m, memory: 100Mi }
|
||||||
|
limits: { cpu: 50m, memory: 100Mi }
|
||||||
|
volumeMounts:
|
||||||
|
- { name: providervol, mountPath: "/provider" }
|
||||||
|
livenessProbe:
|
||||||
|
httpGet:
|
||||||
|
path: "/health/ready"
|
||||||
|
port: 8080
|
||||||
|
scheme: "HTTP"
|
||||||
|
failureThreshold: 2
|
||||||
|
initialDelaySeconds: 5
|
||||||
|
periodSeconds: 5
|
||||||
|
successThreshold: 1
|
||||||
|
timeoutSeconds: 3
|
||||||
|
readinessProbe:
|
||||||
|
httpGet:
|
||||||
|
path: "/health/ready"
|
||||||
|
port: 8080
|
||||||
|
scheme: "HTTP"
|
||||||
|
failureThreshold: 2
|
||||||
|
initialDelaySeconds: 5
|
||||||
|
periodSeconds: 5
|
||||||
|
successThreshold: 1
|
||||||
|
timeoutSeconds: 3
|
||||||
|
volumes:
|
||||||
|
- name: providervol
|
||||||
|
hostPath:
|
||||||
|
path: "/var/run/secrets-store-csi-providers"
|
||||||
|
nodeSelector:
|
||||||
|
kubernetes.io/os: linux
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user