k8s初级实战04--DaemonSet Static Pod

2024-05-31 00:08

本文主要是介绍k8s初级实战04--DaemonSet Static Pod,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

k8s初级实战04--DaemonSet & Static Pod

  • 1 基础概念
  • 2 常见用法
    • 2.1 DaemonSet
    • 2.2 Static Pod
  • 3 注意事项
  • 4 说明

1 基础概念

  1. DaemonSet
    DaemonSet 保证在每个 Node 上都运行一个容器副本,常用来部署一些集群的日志、监控或者其他系统管理应用。典型的应用包括:
    日志收集,比如 fluentd,logstash 等;
    系统监控,比如 Prometheus Node Exporter,collectd,New Relic agent,Ganglia gmond 等;
    系统程序,比如 kube-proxy, kube-dns, glusterd, ceph 等。

  2. Static Pod
    Static Pod 可以让每台机器上运行指定的 Pod,这需要 kubelet 在启动的时候指定 manifest 目录,然后将所需要的 Pod 定义文件放到指定的 manifest 目录中。

2 常见用法

2.1 DaemonSet

  1. 创建 ds

    vim dpl-my-web-ds.yaml 
    apiVersion: apps/v1
    kind: DaemonSet
    metadata:labels:app: my-web-dsname: my-web-ds
    spec:selector:matchLabels:app: my-web-dstemplate:metadata:labels:app: my-web-dsspec:containers:- image: nginx:1.19.4name: nginx-ds
    $ kubectl apply -f dpl-my-web-ds.yaml 
    daemonset.apps/my-web-ds created创建 fluentd-elasticsearch DaemonSet
    $ kubectl apply -f https://k8s.io/examples/controllers/daemonset.yaml
    部署完整的efk 可以参考链接 cluster/addons/fluentd-elasticsearch
    

    cluster/addons/fluentd-elasticsearch

  2. 查看 ds

    $ kubectl get ds 或 kubectl get daemonset
    NAME        DESIRED   CURRENT   READY   UP-TO-DATE   AVAILABLE   NODE SELECTOR   AGE
    my-web-ds   2         2         2       2            2           <none>          83s
    
  3. 删除 ds

    $ kubectl delete daemonsets my-web-ds 
    daemonset.apps "my-web-ds" deleted
    或者
    $ kubectl delete -f dpl-my-web-ds.yaml
    

2.2 Static Pod

  1. 创建static pod
    vim  pod-my-web-sp.yaml 
    apiVersion: v1
    kind: Pod
    metadata:labels:run: my-web-spname: my-web-sp
    spec:containers:- image: nginx:1.19.4name: my-web-spports:- containerPort: 80
    拷贝该pod到  /etc/kubernetes/manifests/ 目录,过一会儿指定节点会自动拉起该pod
    cp pod-my-web-sp.yaml /etc/kubernetes/manifests/
    
    如下图,该pod的控制器为Node,而普通的pod控制器为ReplicaSet。
    在这里插入图片描述
  2. 查看static pod
    和查看正常pod一样查看static pod即可
    $ kubectl get pod|grep sp
    my-web-sp-kmaster   1/1     Running   1          4s
    pod 名称为 yaml中pod名称-节点名称
    
  3. 删除static pod
    $ kubectl delete pod my-web-sp-kmaster  
    提示 pod NotFound,因此无法对该pod执行任何操作;
    rm /etc/kubernetes/manifests/pod-my-web-sp.yaml 后,该pod过一会自动删除;
    

3 注意事项

  1. 静态 Pod 不能通过 API Server 来删除,但可以通过删除 manifest 文件来自动删除对应的 Pod。

4 说明

Concepts->Workloads->Workload Resources->DaemonSet
Kubernetes 指南-DaemonSet

这篇关于k8s初级实战04--DaemonSet Static Pod的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1017117

相关文章

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

90、k8s之secret+configMap

一、secret配置管理 配置管理: 加密配置:保存密码,token,其他敏感信息的k8s资源 应用配置:我们需要定制化的给应用进行配置,我们需要把定制好的配置文件同步到pod当中容器 1.1、加密配置: secret: [root@master01 ~]# kubectl get secrets ##查看加密配置[root@master01 ~]# kubectl get se

滚雪球学Java(87):Java事务处理:JDBC的ACID属性与实战技巧!真有两下子!

咦咦咦,各位小可爱,我是你们的好伙伴——bug菌,今天又来给大家普及Java SE啦,别躲起来啊,听我讲干货还不快点赞,赞多了我就有动力讲得更嗨啦!所以呀,养成先点赞后阅读的好习惯,别被干货淹没了哦~ 🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,助你一臂之力,带你早日登顶🚀,欢迎大家关注&&收藏!持续更新中,up!up!up!! 环境说明:Windows 10

native和static native区别

本文基于Hello JNI  如有疑惑,请看之前几篇文章。 native 与 static native java中 public native String helloJni();public native static String helloJniStatic();1212 JNI中 JNIEXPORT jstring JNICALL Java_com_test_g

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP

取得 Git 仓库 —— Git 学习笔记 04

取得 Git 仓库 —— Git 学习笔记 04 我认为, Git 的学习分为两大块:一是工作区、索引、本地版本库之间的交互;二是本地版本库和远程版本库之间的交互。第一块是基础,第二块是难点。 下面,我们就围绕着第一部分内容来学习,先不考虑远程仓库,只考虑本地仓库。 怎样取得项目的 Git 仓库? 有两种取得 Git 项目仓库的方法。第一种是在本地创建一个新的仓库,第二种是把其他地方的某个

【Kubernetes】K8s 的安全框架和用户认证

K8s 的安全框架和用户认证 1.Kubernetes 的安全框架1.1 认证:Authentication1.2 鉴权:Authorization1.3 准入控制:Admission Control 2.Kubernetes 的用户认证2.1 Kubernetes 的用户认证方式2.2 配置 Kubernetes 集群使用密码认证 Kubernetes 作为一个分布式的虚拟