Sunday, June 27, 2021

Kubernetes DaemonSet (ds)

 Overview of DaemonSets

Kubernetes DaemonSet is one of the controllers which are at the Kubernetes Master node.

A DaemonSet ensures that all or some nodes run a Pod

As nodes are added to the Kubernetes cluster, Pods have added accordingly for each node as per the DaemonSet defined.

As nodes are removed or drained from the Kubernetes cluster, they are GC. Deleting a DaemonSet will clean up those Pods it created on each node

The DaemonSet Controller creating pods on each nodes


Where we can use this DaemonSet?

When a Kubernetes cluster running many microservices with multi-nodes there will be a need for Monitoring the system resources with collecting metrics and Logging should be enabled for the application level or database level to collect respective access and server-specific logs.

Some example daemon pods can be:

  • Collectd, Node exporter -- Monitoring daemon on nodes for Prometheus
  • Fluentd, logstash – log collection daemon for ELK, EFK stacks
  • Ceph, glusterd – Storage daemon for Cloud storages 

Running your DaemonSet

First, check that how many nodes in the cluster and what are their status.

  kubectl get nodes

Creating DaemonSet


Defining the DaemonSet in YAML for fluentd Image.
 apiVersion: apps/v1
kind: DaemonSet
metadata:
    name: fluentd-ds
spec:
  selector:
    matchLabels:
      name: fluentd
  template:
    metadata:
      labels:
        name: fluentd
    spec:
      tolerations: # Tolerations
      - key: node-role.kubernetes.io/master
        effect: NoSchedule
      containers:
      - name: fluentd-con
        image: quay.io/fluentd_elasticsearch/fluentd:v2.5.2


 kubectl create -f fluentd-daemonset.yaml

List the pods with wide option
kubectl get po -o wide

Get the DaemonSet object

kubectl get daemonset -o wide
The output of the above command is:
ds



Observe that DaemonSet created pod ControlledBy line it will be under control of DaemonSet.
  kubectl describe ds
  



Describe the DaemonSet


Cleanup DaemonSet

   kubectl delete ds fluentd-ds
  

Confirm that DaemonSet is detleted by checking the list ds
 kubectl get ds

References:

No comments:

Categories

Kubernetes (24) Docker (20) git (13) Jenkins (12) AWS (7) Jenkins CI (5) Vagrant (5) K8s (4) VirtualBox (4) CentOS7 (3) docker registry (3) docker-ee (3) ucp (3) Jenkins Automation (2) Jenkins Master Slave (2) Jenkins Project (2) containers (2) docker EE (2) docker private registry (2) dockers (2) dtr (2) kubeadm (2) kubectl (2) kubelet (2) openssl (2) Alert Manager CLI (1) AlertManager (1) Apache Maven (1) Best DevOps interview questions (1) CentOS (1) Container as a Service (1) DevOps Interview Questions (1) Docker 19 CE on Ubuntu 19.04 (1) Docker Tutorial (1) Docker UCP (1) Docker installation on Ubunutu (1) Docker interview questions (1) Docker on PowerShell (1) Docker on Windows (1) Docker version (1) Docker-ee installation on CentOS (1) DockerHub (1) Features of DTR (1) Fedora (1) Freestyle Project (1) Git Install on CentOS (1) Git Install on Oracle Linux (1) Git Install on RHEL (1) Git Source based installation (1) Git line ending setup (1) Git migration (1) Grafana on Windows (1) Install DTR (1) Install Docker on Windows Server (1) Install Maven on CentOS (1) Issues (1) Jenkins CI server on AWS instance (1) Jenkins First Job (1) Jenkins Installation on CentOS7 (1) Jenkins Master (1) Jenkins automatic build (1) Jenkins installation on Ubuntu 18.04 (1) Jenkins integration with GitHub server (1) Jenkins on AWS Ubuntu (1) Kubernetes Cluster provisioning (1) Kubernetes interview questions (1) Kuberntes Installation (1) Maven (1) Maven installation on Unix (1) Operations interview Questions (1) Oracle Linux (1) Personal access tokens on GitHub (1) Problem in Docker (1) Prometheus (1) Prometheus CLI (1) RHEL (1) SCM (1) SCM Poll (1) SRE interview questions (1) Troubleshooting (1) Uninstall Git (1) Uninstall Git on CentOS7 (1) Universal Control Plane (1) Vagrantfile (1) amtool (1) aws IAM Role (1) aws policy (1) caas (1) chef installation (1) create deployment (1) create organization on UCP (1) create team on UCP (1) docker CE (1) docker UCP console (1) docker command line (1) docker commands (1) docker community edition (1) docker container (1) docker editions (1) docker enterprise edition (1) docker enterprise edition deep dive (1) docker for windows (1) docker hub (1) docker installation (1) docker node (1) docker releases (1) docker secure registry (1) docker service (1) docker swarm init (1) docker swarm join (1) docker trusted registry (1) elasticBeanStalk (1) global configurations (1) helm installation issue (1) mvn (1) namespaces (1) promtool (1) service creation (1) slack (1)