k8s面试题总结(十二)

1.简述ETCD适应的场景?

  1. 适用于数据高一致性的场景,确保分布式环境中的数据是一致的。
  2. 适用于服务高可用时的场景。
  3. 适用于多节点数据分布式存储的场景。
  4. 适用于服务之间协调和交互使用的场景。

2.Etcd集群之间是怎么同步数据的?

在etcd集群中,节点之间通过Raft一致性算法实现数据同步。

Raft保证了数据的高可用性和一致性,确保在集群中的节点保持相同的数据状态。

3.静态pod的适用场景

静态pod通常用于在k8s启动前启动一些核心服务(如网路插件CNI,DNS服务等),它能确保这些关键服务在kubelet启动时运行,不受API-Server服务的可用性以及网络故障的影响。

4.简述k8s中pod的常见调度方式?

  1. Pod的优选和预选调度:根据优选和预选机制,淘汰不符合的node节点,进行调度。
  2. 节点亲和性和反亲和性:通过设置规则,将需要部署在一起的pod部署在同一节点,不需要的分开进行部署。
  3. 资源限制和请求:设置资源需求和限制来影响pod被调度到哪个节点。

5.简述一下k8s中删除pod的流程。

  1. 触发删除请求:用户或控制器(如Deployment,StatefulSet)发出删除pod的请求,可通过命令行工具kubectl或通过API请求来完成删除命令。
  2. API-Server更新状态:API-Server收到删除请求后,会更新pod的状态,将其标记为Terminating(终止中)。
  3. 发送终止信号:k8S向pod中的每个容器发送终止信号(SIGTERM),这通知容器需要优雅的关闭。
  4. 等待终止期限:k8s等待一个预定义的终止期限(默认30秒),在这段时间内,容器可以完成它们的清理工作。
  5. 强制终止:如果容器在终止期限内没有终止,k8s会发送强制终止信号(SIGKILL),但可能导致数据丢失。
  6. 资源释放:当所有容器都成功终止并清理,k8s会释放与pod相关的资源。
  7. 从etcd中删除对象:k8s会从etcd中删除pod的对象记录。
相关推荐
这个DBA有点耶1 小时前
云上运维新挑战:当数据库不再“看得见摸得着”
数据库·sql·程序人生·云原生·运维开发·学习方法·dba
gsls2008083 小时前
JVM 堆内存参数 & Docker 容器适配,一次讲清楚
jvm·docker·容器
Lumbrologist4 小时前
【零基础部署】Docker 部署 AutoGen 多 Agent 对话框架保姆级教程
运维·docker·容器
做个文艺程序员6 小时前
第02篇:K8s 存储与配置管理:ConfigMap、Secret、PV/PVC 实战——Java SaaS 多租户配置最佳实践
java·容器·kubernetes
Plastic garden7 小时前
Docker compose ruoyi示例
运维·docker·容器
qq_452396237 小时前
第十四篇:《Docker Swarm 生产实践:堆栈部署与配置管理》
运维·docker·容器
qq_452396238 小时前
第十三篇:《Docker Swarm 集群基础》
运维·docker·容器
张忠琳8 小时前
【kubevirt】(virt-launcher Part 6)virt-launcher 设备/网络/存储/外设层
云原生·架构·kubernetes·kubevirt
取经蜗牛10 小时前
docker环境中redis连接三种场景配置指南,物理机、wsl、docker
redis·docker·容器
qq_3564086610 小时前
Kubernetes Loki 日志收集系统部署文档 (读写分离模式 + Ceph S3 + Nginx 日志分离)
ceph·nginx·kubernetes