Ensuring One Pod Per Node in Kubernetes
k8s/labs/workloads/daemonset.yaml — DaemonSet ensuring one Pod per eligible node for node-level agents or daemons.Deploy storage drivers only on nodes with SSD disks, or monitoring agents only on production nodes.
apiVersion: apps/v1
kind: DaemonSet
metadata:
name: node-monitoring-agent
namespace: monitoring
labels:
app: monitoring-agent
spec:
selector:
matchLabels:
app: monitoring-agent
template:
metadata:
labels:
app: monitoring-agent
spec:
# Optional: Target specific nodes
nodeSelector:
monitoring: enabled
containers:
- name: agent
image: prom/node-exporter:v1.7.0
imagePullPolicy: IfNotPresent
ports:
- containerPort: 9100
name: metrics
# Access host metrics
volumeMounts:
- name: proc
mountPath: /host/proc
readOnly: true
- name: sys
mountPath: /host/sys
readOnly: true
volumes:
- name: proc
hostPath:
path: /proc
- name: sys
hostPath:
path: /sys
# Run on master nodes if needed
tolerations:
- key: node-role.kubernetes.io/control-plane
operator: Exists
effect: NoSchedule