310 lines
7.5 KiB
YAML
310 lines
7.5 KiB
YAML
# 修改 image中的自建harbor地址!
|
||
|
||
apiVersion: v1
|
||
kind: Namespace
|
||
metadata:
|
||
name: kube-system
|
||
|
||
---
|
||
|
||
apiVersion: v1
|
||
kind: ServiceAccount
|
||
metadata:
|
||
labels:
|
||
k8s-app: kubernetes-dashboard
|
||
name: kubernetes-dashboard
|
||
namespace: kube-system
|
||
|
||
---
|
||
|
||
kind: Service
|
||
apiVersion: v1
|
||
metadata:
|
||
labels:
|
||
k8s-app: kubernetes-dashboard
|
||
kubernetes.io/cluster-service: "true"
|
||
name: kubernetes-dashboard
|
||
namespace: kube-system
|
||
spec:
|
||
ports:
|
||
- port: 443
|
||
targetPort: 8443
|
||
nodePort: 30554
|
||
selector:
|
||
k8s-app: kubernetes-dashboard
|
||
type: NodePort
|
||
|
||
---
|
||
|
||
apiVersion: v1
|
||
kind: Secret
|
||
metadata:
|
||
labels:
|
||
k8s-app: kubernetes-dashboard
|
||
name: kubernetes-dashboard-certs
|
||
namespace: kube-system
|
||
type: Opaque
|
||
|
||
---
|
||
|
||
apiVersion: v1
|
||
kind: Secret
|
||
metadata:
|
||
labels:
|
||
k8s-app: kubernetes-dashboard
|
||
name: kubernetes-dashboard-csrf
|
||
namespace: kube-system
|
||
type: Opaque
|
||
data:
|
||
csrf: ""
|
||
|
||
---
|
||
|
||
apiVersion: v1
|
||
kind: Secret
|
||
metadata:
|
||
labels:
|
||
k8s-app: kubernetes-dashboard
|
||
name: kubernetes-dashboard-key-holder
|
||
namespace: kube-system
|
||
type: Opaque
|
||
|
||
---
|
||
|
||
kind: ConfigMap
|
||
apiVersion: v1
|
||
metadata:
|
||
labels:
|
||
k8s-app: kubernetes-dashboard
|
||
name: kubernetes-dashboard-settings
|
||
namespace: kube-system
|
||
|
||
---
|
||
|
||
kind: Role
|
||
apiVersion: rbac.authorization.k8s.io/v1
|
||
metadata:
|
||
labels:
|
||
k8s-app: kubernetes-dashboard
|
||
name: kubernetes-dashboard
|
||
namespace: kube-system
|
||
rules:
|
||
# Allow Dashboard to get, update and delete Dashboard exclusive secrets.
|
||
- apiGroups: [""]
|
||
resources: ["secrets"]
|
||
resourceNames: ["kubernetes-dashboard-key-holder", "kubernetes-dashboard-certs", "kubernetes-dashboard-csrf"]
|
||
verbs: ["get", "update", "delete"]
|
||
# Allow Dashboard to get and update 'kubernetes-dashboard-settings' config map.
|
||
- apiGroups: [""]
|
||
resources: ["configmaps"]
|
||
resourceNames: ["kubernetes-dashboard-settings"]
|
||
verbs: ["get", "update"]
|
||
# Allow Dashboard to get metrics.
|
||
- apiGroups: [""]
|
||
resources: ["services"]
|
||
resourceNames: ["heapster", "dashboard-metrics-scraper"]
|
||
verbs: ["proxy"]
|
||
- apiGroups: [""]
|
||
resources: ["services/proxy"]
|
||
resourceNames: ["heapster", "http:heapster:", "https:heapster:", "dashboard-metrics-scraper", "http:dashboard-metrics-scraper"]
|
||
verbs: ["get"]
|
||
|
||
---
|
||
|
||
kind: ClusterRole
|
||
apiVersion: rbac.authorization.k8s.io/v1
|
||
metadata:
|
||
labels:
|
||
k8s-app: kubernetes-dashboard
|
||
name: kubernetes-dashboard
|
||
rules:
|
||
# Allow Metrics Scraper to get metrics from the Metrics server
|
||
- apiGroups: ["metrics.k8s.io"]
|
||
resources: ["pods", "nodes"]
|
||
verbs: ["get", "list", "watch"]
|
||
|
||
---
|
||
|
||
apiVersion: rbac.authorization.k8s.io/v1
|
||
kind: RoleBinding
|
||
metadata:
|
||
labels:
|
||
k8s-app: kubernetes-dashboard
|
||
name: kubernetes-dashboard
|
||
namespace: kube-system
|
||
roleRef:
|
||
apiGroup: rbac.authorization.k8s.io
|
||
kind: Role
|
||
name: kubernetes-dashboard
|
||
subjects:
|
||
- kind: ServiceAccount
|
||
name: kubernetes-dashboard
|
||
namespace: kube-system
|
||
|
||
---
|
||
|
||
apiVersion: rbac.authorization.k8s.io/v1
|
||
kind: ClusterRoleBinding
|
||
metadata:
|
||
name: kubernetes-dashboard
|
||
roleRef:
|
||
apiGroup: rbac.authorization.k8s.io
|
||
kind: ClusterRole
|
||
name: kubernetes-dashboard
|
||
subjects:
|
||
- kind: ServiceAccount
|
||
name: kubernetes-dashboard
|
||
namespace: kube-system
|
||
|
||
---
|
||
|
||
kind: Deployment
|
||
apiVersion: apps/v1
|
||
metadata:
|
||
labels:
|
||
k8s-app: kubernetes-dashboard
|
||
name: kubernetes-dashboard
|
||
namespace: kube-system
|
||
spec:
|
||
replicas: 1
|
||
revisionHistoryLimit: 10
|
||
selector:
|
||
matchLabels:
|
||
k8s-app: kubernetes-dashboard
|
||
template:
|
||
metadata:
|
||
labels:
|
||
k8s-app: kubernetes-dashboard
|
||
spec:
|
||
containers:
|
||
- name: kubernetes-dashboard
|
||
image: 20.47.129.116:8033/cmii/dashboard:v2.0.1
|
||
ports:
|
||
- containerPort: 8443
|
||
protocol: TCP
|
||
args:
|
||
- --auto-generate-certificates
|
||
- --namespace=kube-system
|
||
# Uncomment the following line to manually specify Kubernetes API server Host
|
||
# If not specified, Dashboard will attempt to auto discover the API server and connect
|
||
# to it. Uncomment only if the default does not work.
|
||
# - --apiserver-host=http://my-address:port
|
||
volumeMounts:
|
||
- name: kubernetes-dashboard-certs
|
||
mountPath: /certs
|
||
# Create on-disk volume to store exec logs
|
||
- mountPath: /tmp
|
||
name: tmp-volume
|
||
livenessProbe:
|
||
httpGet:
|
||
scheme: HTTPS
|
||
path: /
|
||
port: 8443
|
||
initialDelaySeconds: 30
|
||
timeoutSeconds: 30
|
||
securityContext:
|
||
allowPrivilegeEscalation: false
|
||
readOnlyRootFilesystem: true
|
||
runAsUser: 1001
|
||
runAsGroup: 2001
|
||
volumes:
|
||
- name: kubernetes-dashboard-certs
|
||
secret:
|
||
secretName: kubernetes-dashboard-certs
|
||
- name: tmp-volume
|
||
emptyDir: {}
|
||
serviceAccountName: kubernetes-dashboard
|
||
# Comment the following tolerations if Dashboard must not be deployed on master
|
||
tolerations:
|
||
- key: node-role.kubernetes.io/master
|
||
effect: NoSchedule
|
||
|
||
---
|
||
|
||
kind: Service
|
||
apiVersion: v1
|
||
metadata:
|
||
labels:
|
||
k8s-app: dashboard-metrics-scraper
|
||
name: dashboard-metrics-scraper
|
||
namespace: kube-system
|
||
spec:
|
||
ports:
|
||
- port: 8000
|
||
targetPort: 8000
|
||
selector:
|
||
k8s-app: dashboard-metrics-scraper
|
||
|
||
---
|
||
|
||
kind: Deployment
|
||
apiVersion: apps/v1
|
||
metadata:
|
||
labels:
|
||
k8s-app: dashboard-metrics-scraper
|
||
name: dashboard-metrics-scraper
|
||
namespace: kube-system
|
||
spec:
|
||
replicas: 1
|
||
revisionHistoryLimit: 10
|
||
selector:
|
||
matchLabels:
|
||
k8s-app: dashboard-metrics-scraper
|
||
template:
|
||
metadata:
|
||
labels:
|
||
k8s-app: dashboard-metrics-scraper
|
||
annotations:
|
||
seccomp.security.alpha.kubernetes.io/pod: 'runtime/default'
|
||
spec:
|
||
containers:
|
||
- name: dashboard-metrics-scraper
|
||
image: 20.47.129.116:8033/cmii/metrics-scraper:v1.0.4
|
||
ports:
|
||
- containerPort: 8000
|
||
protocol: TCP
|
||
livenessProbe:
|
||
httpGet:
|
||
scheme: HTTP
|
||
path: /
|
||
port: 8000
|
||
initialDelaySeconds: 30
|
||
timeoutSeconds: 30
|
||
volumeMounts:
|
||
- mountPath: /tmp
|
||
name: tmp-volume
|
||
securityContext:
|
||
allowPrivilegeEscalation: false
|
||
readOnlyRootFilesystem: true
|
||
runAsUser: 1001
|
||
runAsGroup: 2001
|
||
serviceAccountName: kubernetes-dashboard
|
||
# Comment the following tolerations if Dashboard must not be deployed on master
|
||
tolerations:
|
||
- key: node-role.kubernetes.io/master
|
||
effect: NoSchedule
|
||
volumes:
|
||
- name: tmp-volume
|
||
emptyDir: {}
|
||
---
|
||
apiVersion: v1
|
||
kind: ServiceAccount
|
||
metadata:
|
||
name: admin-user
|
||
namespace: kube-system
|
||
|
||
---
|
||
apiVersion: rbac.authorization.k8s.io/v1
|
||
kind: ClusterRoleBinding
|
||
metadata:
|
||
name: admin-user
|
||
roleRef:
|
||
apiGroup: rbac.authorization.k8s.io
|
||
kind: ClusterRole
|
||
name: cluster-admin
|
||
subjects:
|
||
- kind: ServiceAccount
|
||
name: admin-user
|
||
namespace: kube-system
|
||
---
|
||
# kubectl -n kube-system describe secret $(kubectl -n kube-system get secret | grep admin-user | awk '{print $1}') |