Kubernetes Metrics Server Operations: Difference between revisions

From NovaOrdis Knowledge Base
Jump to navigation Jump to search
Line 14: Line 14:
{{External|https://github.com/helm/charts/tree/master/stable/metrics-server}}
{{External|https://github.com/helm/charts/tree/master/stable/metrics-server}}


Cloned the repository then built the chart locally with 'helm package ./metrics-server'. Then installed with:
Can be installed directly from the "stable" repository:
 
Alternatively, the chart can be built locally with with 'helm package ./metrics-server', then installed with:
<syntaxhighlight lang='bash'>
<syntaxhighlight lang='bash'>
helm install ms ./metrics-server-2.11.2.tgz -f ./values.yaml
helm install ms ./metrics-server-2.11.2.tgz -f ./values.yaml
Line 27: Line 29:
   - --cert-dir=/tmp
   - --cert-dir=/tmp
</syntaxhighlight>
</syntaxhighlight>
==With Manifest==
==With Manifest==
===Docker Desktop Kubernetes===
===Docker Desktop Kubernetes===

Revision as of 19:26, 15 October 2020

External

Internal

Help

docker run --rm k8s.gcr.io/metrics-server/metrics-server:v0.3.7 --help

Installation

https://github.com/kubernetes-sigs/metrics-server#requirements

With Helm

https://github.com/helm/charts/tree/master/stable/metrics-server

Can be installed directly from the "stable" repository:

Alternatively, the chart can be built locally with with 'helm package ./metrics-server', then installed with:

helm install ms ./metrics-server-2.11.2.tgz -f ./values.yaml

where values.yaml:

image:
  repository: k8s.gcr.io/metrics-server/metrics-server
  tag: v0.3.7
args:
  - --kubelet-insecure-tls
  - --cert-dir=/tmp

With Manifest

Docker Desktop Kubernetes

Install

kubectl apply -f https://github.com/kubernetes-sigs/metrics-server/releases/download/v0.3.7/components.yaml

If configuration needs to be changed, pull the file locally and install it with:

kubectl apply -f ./components.yaml

clusterrole.rbac.authorization.k8s.io/system:aggregated-metrics-reader created
clusterrolebinding.rbac.authorization.k8s.io/metrics-server:system:auth-delegator created
rolebinding.rbac.authorization.k8s.io/metrics-server-auth-reader created
apiservice.apiregistration.k8s.io/v1beta1.metrics.k8s.io created
serviceaccount/metrics-server created
deployment.apps/metrics-server created
service/metrics-server created
clusterrole.rbac.authorization.k8s.io/system:metrics-server created
clusterrolebinding.rbac.authorization.k8s.io/system:metrics-server created

It is deployed in the 'kube-system' namespace.

Configuration

For Docker Desktop Kubernetes, add "--kubelet-insecure-tls", otherwise the pod reads will fail with:

x509: certificate signed by unknown authority
kind: Deployment
metadata:
  name: metrics-server
spec:
  template:
    spec:
      containers:
      - name: metrics-server
        args:
          - --kubelet-insecure-tls
          - --cert-dir=/tmp
          - --secure-port=4443

Uninstall

Uninstall all the Kubernetes API resources. To reconfigure, it is sufficient to uninstall then re-install the deployment.

EKS

https://docs.aws.amazon.com/eks/latest/userguide/horizontal-pod-autoscaler.html

Installation Validation

kubectl top