Skip to content

Commit af44040

Browse files
authored
Merge pull request #17483 from hakman/azure-cloud-node
azure: Deploy cloud-node-manager for K8s 1.31+
2 parents 06b3e84 + 9c057c3 commit af44040

File tree

2 files changed

+110
-0
lines changed

2 files changed

+110
-0
lines changed
Lines changed: 95 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,95 @@
1+
apiVersion: v1
2+
kind: ServiceAccount
3+
metadata:
4+
labels:
5+
k8s-app: cloud-node-manager
6+
kubernetes.io/cluster-service: "true"
7+
name: cloud-node-manager
8+
namespace: kube-system
9+
---
10+
kind: ClusterRole
11+
apiVersion: rbac.authorization.k8s.io/v1
12+
metadata:
13+
name: cloud-node-manager
14+
labels:
15+
k8s-app: cloud-node-manager
16+
kubernetes.io/cluster-service: "true"
17+
rules:
18+
- apiGroups: [""]
19+
resources: ["nodes"]
20+
verbs: ["watch","list","get","update", "patch"]
21+
- apiGroups: [""]
22+
resources: ["nodes/status"]
23+
verbs: ["patch"]
24+
---
25+
apiVersion: rbac.authorization.k8s.io/v1
26+
kind: ClusterRoleBinding
27+
metadata:
28+
name: cloud-node-manager
29+
labels:
30+
k8s-app: cloud-node-manager
31+
kubernetes.io/cluster-service: "true"
32+
roleRef:
33+
apiGroup: rbac.authorization.k8s.io
34+
kind: ClusterRole
35+
name: cloud-node-manager
36+
subjects:
37+
- kind: ServiceAccount
38+
name: cloud-node-manager
39+
namespace: kube-system
40+
---
41+
apiVersion: apps/v1
42+
kind: DaemonSet
43+
metadata:
44+
name: cloud-node-manager
45+
namespace: kube-system
46+
labels:
47+
component: cloud-node-manager
48+
kubernetes.io/cluster-service: "true"
49+
spec:
50+
selector:
51+
matchLabels:
52+
k8s-app: cloud-node-manager
53+
template:
54+
metadata:
55+
labels:
56+
k8s-app: cloud-node-manager
57+
annotations:
58+
cluster-autoscaler.kubernetes.io/daemonset-pod: "true"
59+
spec:
60+
priorityClassName: system-node-critical
61+
serviceAccountName: cloud-node-manager
62+
hostNetwork: true # required to fetch correct hostname
63+
nodeSelector:
64+
kubernetes.io/os: linux
65+
tolerations:
66+
- key: CriticalAddonsOnly
67+
operator: Exists
68+
- key: node-role.kubernetes.io/master
69+
operator: Equal
70+
value: "true"
71+
effect: NoSchedule
72+
- operator: "Exists"
73+
effect: NoExecute
74+
- operator: "Exists"
75+
effect: NoSchedule
76+
containers:
77+
- name: cloud-node-manager
78+
image: mcr.microsoft.com/oss/kubernetes/azure-cloud-node-manager:v1.33.1
79+
imagePullPolicy: IfNotPresent
80+
command:
81+
- cloud-node-manager
82+
- --node-name=$(NODE_NAME)
83+
- --v=4
84+
env:
85+
- name: NODE_NAME
86+
valueFrom:
87+
fieldRef:
88+
fieldPath: spec.nodeName
89+
resources:
90+
requests:
91+
cpu: 50m
92+
memory: 50Mi
93+
limits:
94+
cpu: 2000m
95+
memory: 512Mi

upup/pkg/fi/cloudup/bootstrapchannelbuilder/bootstrapchannelbuilder.go

Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -756,6 +756,21 @@ func (b *BootstrapChannelBuilder) buildAddons(c *fi.CloudupModelBuilderContext)
756756
}
757757
}
758758

759+
if b.Cluster.IsKubernetesGTE("1.31") && b.Cluster.GetCloudProvider() == kops.CloudProviderAzure {
760+
{
761+
key := "azure-cloud-node.addons.k8s.io"
762+
id := "k8s-1.31"
763+
location := key + "/" + id + ".yaml"
764+
765+
addons.Add(&channelsapi.AddonSpec{
766+
Name: fi.PtrTo(key),
767+
Selector: map[string]string{"k8s-addon": key},
768+
Manifest: fi.PtrTo(location),
769+
Id: id,
770+
})
771+
}
772+
}
773+
759774
if b.Cluster.GetCloudProvider() == kops.CloudProviderGCE {
760775
if fi.ValueOf(b.Cluster.Spec.CloudConfig.ManageStorageClasses) {
761776
key := "storage-gce.addons.k8s.io"

0 commit comments

Comments
 (0)