-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathkubelet-csr-approver.jsonnet
84 lines (78 loc) · 2.47 KB
/
kubelet-csr-approver.jsonnet
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
local kube = import "kube.libsonnet";
local utils = import "utils.libsonnet";
local arch = "amd64";
{
namespace:: {
metadata+: { namespace: "kube-system" },
},
sa: kube.ServiceAccount("kubelet-csr-approver") + $.namespace,
role: kube.ClusterRole("kubelet-csr-approver") {
rules: [
{
apiGroups: ["certificates.k8s.io"],
resources: ["signers"],
resourceNames: [
//"kubernetes.io/legacy-unknown", // pre k8s-1.18
"kubernetes.io/kubelet-serving",
],
verbs: ["approve"],
},
{
apiGroups: ["certificates.k8s.io"],
resources: ["certificatesigningrequests"],
verbs: ["get", "list", "watch"],
},
{
apiGroups: ["certificates.k8s.io"],
resources: ["certificatesigningrequests/approval"],
verbs: ["update"],
},
],
},
roleBinding: kube.ClusterRoleBinding("kubelet-csr-approver") {
subjects_+: [$.sa],
roleRef_: $.role,
},
deploy: kube.Deployment("kubelet-csr-approver") + $.namespace {
spec+: {
template+: utils.PromScrape(8080) + {
spec+: {
serviceAccountName: $.sa.metadata.name,
priorityClassName: "system-cluster-critical",
tolerations+: utils.toleratesMaster,
containers_+: {
approver: kube.Container("kubelet-csr-approver") {
image: "postfinance/kubelet-csr-approver:v0.2.8", // renovate
args_: {
"metrics-bind-address": ":8080",
"health-probe-bind-address": ":8081",
"bypass-dns-resolution": true,
"max-expiration-sec": 367 * 86400, // 367 days
"provider-regex": "^[0-9a-f]{32}$",
},
env_+: {
GOGC: "25",
GOMEMLIMIT: kube.ResourceFieldRef("requests.memory"),
},
livenessProbe: {
httpGet: {path: "/healthz", port: 8081},
timeoutSeconds: 30,
periodSeconds: 30,
},
startupProbe: self.livenessProbe {
local timeoutSeconds = 5 * 60,
failureThreshold: std.ceil(timeoutSeconds / self.periodSeconds),
},
readinessProbe: self.livenessProbe {
failureThreshold: 3,
},
resources+: {
requests: {memory: "40Mi", cpu: "10m"},
},
},
},
},
},
},
},
}