README ¶
addon-resizer
This container image watches over another container in a deployment, and vertically scales the dependent container up and down. Currently the only option is to scale it linearly based on the number of nodes, and it only works for a singleton.
Currently recommended version is 1.8, on addon-resizer-release-1.8 branch.
Nanny program and arguments
The nanny scales resources linearly with the number of nodes in the cluster. The base and marginal resource requirements are given as command line arguments, but you cannot give a marginal requirement without a base requirement.
The cluster size is periodically checked, and used to calculate the expected resources. If the expected and actual resources differ by more than the threshold (given as a +/- percent), then the deployment is updated (updating a deployment stops the old pod, and starts a new pod).
Usage of pod_nanny:
--container="pod-nanny": The name of the container to watch. This defaults to the nanny itself.
--cpu="MISSING": The base CPU resource requirement.
--deployment="": The name of the deployment being monitored. This is required.
--extra-cpu="0": The amount of CPU to add per node.
--extra-memory="0Mi": The amount of memory to add per node.
--extra-storage="0Gi": The amount of storage to add per node.
--log-flush-frequency=5s: Maximum number of seconds between log flushes
--memory="MISSING": The base memory resource requirement.
--namespace=$MY_POD_NAMESPACE: The namespace of the ward. This defaults to the nanny pod's own namespace.
--pod=$MY_POD_NAME: The name of the pod to watch. This defaults to the nanny's own pod.
--poll-period=10000: The time, in milliseconds, to poll the dependent container.
--storage="MISSING": The base storage resource requirement.
--threshold=0: A number between 0-100. The dependent's resources are rewritten when they deviate from expected by more than threshold.
Example deployment file
The following yaml is an example deployment where the nanny watches and resizes itself.
# Config map for resource configuration.
# Specify 'cpu', 'extra-cpu', 'memory' and 'extra-memory'
# to overwrite resource requirements.
apiVersion: v1
kind: ConfigMap
metadata:
name: nanny-config
namespace: default
data:
NannyConfiguration: |-
apiVersion: nannyconfig/v1alpha1
kind: NannyConfiguration
---
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
name: nanny-v1
namespace: default
labels:
k8s-app: nanny
version: v1
spec:
replicas: 1
selector:
matchLabels:
k8s-app: nanny
version: v1
template:
metadata:
labels:
k8s-app: nanny
version: v1
kubernetes.io/cluster-service: "true"
spec:
containers:
- image: staging-k8s.gcr.io/addon-resizer:1.8.1
imagePullPolicy: Always
name: pod-nanny
resources:
limits:
cpu: 300m
memory: 200Mi
requests:
cpu: 300m
memory: 200Mi
env:
- name: MY_POD_NAME
valueFrom:
fieldRef:
fieldPath: metadata.name
- name: MY_POD_NAMESPACE
valueFrom:
fieldRef:
fieldPath: metadata.namespace
volumeMounts:
- name: nanny-config-volume
mountPath: /etc/config
command:
- /pod_nanny
- --config-dir=/etc/config
- --cpu=300m
- --extra-cpu=20m
- --memory=200Mi
- --extra-memory=10Mi
- --threshold=5
- --deployment=nanny-v1
volumes:
- name: nanny-config-volume
configMap:
name: nanny-config
Addon resizer configuration
To follow instructions in this section, set environment variable ADDON_NAME
to
name of your addon, for example:
ADDON_NAME=heapster
Currently Addon Resizer is used to scale addons: heapster
, metrics-server
, kube-state-metrics
.
Overview
Some addons are scaled by Addon Resizer running as a sidecar container. The default configuration is passed to Addon Resizer via command-line flags and consists of parameters:
- CPU parameters:
--cpu
--extra-cpu
On n-node cluster, the total CPU assigned to the addon will be computed as:
cpu + n * extra-cpu
Note: Addon Resizer uses buckets of cluster sizes, so it will use n larger than the cluster size by up to 50% for clusters larger than 16 nodes. For smaller clusters, n = 16 will be used.
- Memory parameters:
--memory
--extra-memory
On n-node cluster, the total memory assigned to the addon will be computed as:
memory + n * extra-memory
Note: Addon Resizer uses buckets of cluster sizes, so it will use n larger than the cluster size by up to 50% for clusters larger than 16 nodes. For smaller clusters, n = 16 will be used.
These resources are overwritten by analogous values specified in a ConfigMap
$ADDON_NAME-config
in kube-system namespace. By default the ConfigMap is empty.
View current defaults
Find version of addon running in your cluster:
kubectl get deployments -n kube-system -l k8s-app=$ADDON_NAME -L version
# set env variables to received values, for example:
ADDON_DEPLOYMENT=heapster-v1.5.0
ADDON_VERSION=v1.5.0
Find the resource parameters for version of the addon running in your clusters, for example:
kubectl logs -n kube-system -l k8s-app=$ADDON_NAME -l version=$ADDON_VERSION -c
$ADDON_NAME-nanny | head -n 1
You can also see total values computed for addon container CPU and memory requirements by inspecting full deployment specification:
kubectl get deployment -n kube-system $ADDON_DEPLOYMENT -o yaml
View current configuration
kubectl get configmap -n kube-system $ADDON_NAME-config -o yaml
By default the configuration is empty:
kind: ConfigMap
apiVersion: v1
data:
NannyConfiguration: |-
apiVersion: nannyconfig/v1alpha1
kind: NannyConfiguration
metadata:
[...]
Edit a configuration
Before you edit a configuration, make sure to check the default values. Don’t overwrite addons configuration with value lower than defaults, otherwise you may cause some Kubernetes components to stop working. If the configuration is missing, empty or incorrect, Addon Resizer will fall back to default configuration.
kubectl edit configmap -n kube-system $ADDON_NAME-config -o yaml
Set values for CPU and memory configuration using predefined options (they are specified as NannyConfiguration API):
baseCPU
cpuPerNode
baseMemory
memoryPerNode
Example of edited configuration:
kind: ConfigMap
apiVersion: v1
data:
NannyConfiguration: |-
apiVersion: nannyconfig/v1alpha1
kind: NannyConfiguration
baseCPU: 100m
cpuPerNode: 1m
baseMemory: 200Mi
metadata:
[...]
Restart the addon. One way to do it is to delete addon deployment and wait for controller manager to re-create it:
kubectl delete deployment -n kube-system $ADDON_DEPLOYMENT
Reset a configuration to default values
To reset a configuration, just remove it and let it be recreated by addon manager:
kubectl delete configmap -n kube-system $ADDON_NAME-config
Then reset the addon itself using the same method:
kubectl delete deployment -n kube-system $ADDON_DEPLOYMENT