K8S对象-DaemonSet

1. 概念

1.1 功能

  • 维护、管理pod的生命周期
  • 每个适合的节点上运行一个该pod 。

说明:当节点加入到K8S集群中,pod会被(DaemonSet)调度到该节点上运行,当节点从K8S集群中被移除,被DaemonSet调度的pod会被移除。

1.2 一般应用

日志收集、监控采集、分布式存储守护进程、ingress等

1.3 比较

对象是否有状态POD数量
Deployment按副本数
DaemonSet(适合节点)每节点一个
StatefulSet按副本数

相关文档
《K8S-Deployment》
《k8s-StatefulSet》

2. 完整示例

apiVersion: apps/v1
kind: DaemonSet
metadata:
  name: fluentd-elasticsearch
  namespace: kube-system
  labels:
    k8s-app: fluentd-logging
spec:
  selector:
    matchLabels:
      name: fluentd-elasticsearch
  template:
    metadata:
      labels:
        name: fluentd-elasticsearch
    spec:
      tolerations:
      - key: node-role.kubernetes.io/master
        effect: NoSchedule
      containers:
      - name: fluentd-elasticsearch
        image: k8s.gcr.io/fluentd-elasticsearch:1.20
        resources:
          limits:
            memory: 200Mi
          requests:
            cpu: 100m
            memory: 200Mi
        volumeMounts:
        - name: varlog
          mountPath: /var/log
        - name: varlibdockercontainers
          mountPath: /var/lib/docker/containers
          readOnly: true
      terminationGracePeriodSeconds: 30
      volumes:
      - name: varlog
        hostPath:
          path: /var/log
      - name: varlibdockercontainers
        hostPath:


在这里插入图片描述

您好!要在Kubernetes中使用DaemonSet部署Zabbix,您可以按照以下步骤进行操作: 1. 配置Zabbix容器镜像:首先,您需要创建一个包含Zabbix Server或Zabbix Agent的容器镜像。您可以使用Zabbix官方提供的Docker镜像或自定义镜像,根据您的需求选择合适的镜像。 2. 编写DaemonSet配置文件:创建一个名为`zabbix-daemonset.yaml`的配置文件,并在其中定义DaemonSet对象的规格。这个配置文件将指定Zabbix容器镜像、挂载卷、环境变量等配置。 以下是一个示例的`zabbix-daemonset.yaml`文件: ```yaml apiVersion: apps/v1 kind: DaemonSet metadata: name: zabbix-daemonset labels: app: zabbix spec: selector: matchLabels: app: zabbix template: metadata: labels: app: zabbix spec: containers: - name: zabbix image: your-zabbix-image:tag env: - name: ZBX_SERVER_HOST value: zabbix-server # 添加其他所需的环境变量 volumeMounts: - name: zabbix-data mountPath: /var/lib/zabbix volumes: - name: zabbix-data # 配置持久化数据存储 # 添加其他所需的挂载卷配置 ``` 请根据您的环境和需求修改这个示例配置文件。 3. 应用配置文件:使用kubectl命令将配置文件应用到Kubernetes集群中: ```shell kubectl apply -f zabbix-daemonset.yaml ``` Kubernetes将会创建一个DaemonSet对象,并在每个节点上创建一个Zabbix容器副本。 请注意,在部署之前,您需要确保在Kubernetes集群中已经配置好了Zabbix Server,并且能够通过`zabbix-server`的主机名进行访问。您还可以根据需要添加其他环境变量和挂载卷的配置。 希望这些信息对您有所帮助!如果有任何其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

玄德公笔记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值