by default, the data in clusterrole system:node is as below:
$ kubectl get clusterrole system:node -o yaml
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
name: system:node
rules:
- apiGroups:
  - ""
  resources:
  - pods
  verbs:
  - get
  - list
  - watch
- apiGroups:
  - ""
  resources:
  - pods
  verbs:
  - create
  - delete
- apiGroups:
  - ""
  resources:
  - pods/status
  verbs:
  - patch
  - updateNow, I want to change the clusterrole system:node, add a - patch under the pods resources, it shoue be like this:
- apiGroups:
  - ""
  resources:
  - pods
  verbs:
  - get
  - list
  - watch
  - patchI could update it by using kubectl edit, but I want to update it in the bash script, so kubectl edit is not suitable, is there any other solution by using kubectl?
Probably, the simplest automatable way is to add a new rule to the ClusterRole.
Create a file named append.yaml with the following content:
- apiGroups:
  - ""
  resources:
  - pods
  verbs:
  - patchThen, append this rule to the existing YAML manifest of the ClusterRole and reapply it with:
kubectl apply -f <(cat <(kubectl get clusterrole system:node -o yaml) append.yaml)The new rule will be merged with the other permissions for pods, which you can verify with:
kubectl describe clusterrole system:nodeThe nicest imperative solution would be to patch the object with kubectl patch, but it doesn't seem to be easily possible:
rules array of the ClusterRole object seems to use a replace patch strategy, that is, the provided patch would just replace the existing array rather being merged with it.chages.yaml
rules:
- apiGroups:
  - ""
  resources:
  - pods
  verbs:
  - get
  - list
  - watch
  - patch #added
- apiGroups:
  - ""
  resources:
  - pods
  verbs:
  - create
  - delete
- apiGroups:
  - ""
  resources:
  - pods/status
  verbs:
  - patch
  - updateUse the following bash command to update the ClusterRole
kubectl patch clusterrole system:node  --patch "$(cat changes.yaml)" For more details visit k8s official documentations
You can use a kubectl apply -f node-role.yaml where node-role.yaml contains the yaml definition of the ClusterRole with your change included. kubectl apply will update the role if it already exists (and create it otherwise).