当前位置: 首页 > news >正文

[面试] 15道最典型的k8s面试题

文章目录

    • 在 Kubernetes 中,有以下常见的资源对象:
    • 1.什么是 Kubernetes?它的主要特点是什么?
    • 2. Kubernetes 中的 Pod 是什么?它的作用是什么?
    • 3.Kubernetes 中的 Deployment 和 StatefulSet 有何区别?
    • 4.什么是 Kubernetes 中的 Service?它的作用是什么?
    • 5.请解释一下 Kubernetes 中的水平扩展(Horizontal Pod Autoscaling)是什么,以及它是如何工作的?
    • 6. Kubernetes 中的 ConfigMap 和 Secret 有何区别,分别用于什么目的?
    • 7.如何在 Kubernetes 中进行滚动更新(Rolling Update)?
    • 8.什么是命名空间(Namespace),以及它在 Kubernetes 中的作用是什么?
    • 9.如何在 Kubernetes 中使用存储卷(Volume)?
    • 10.Kubernetes 中的调度器(Scheduler)负责什么任务?
    • 11.解释一下 Kubernetes 中的亲和性调度(Affinity Scheduling)和反亲和性调度(Anti-Affinity Scheduling)。
    • 12.什么是 DaemonSet?它在 Kubernetes 集群中的作用是什么?
    • 13.Kubernetes 中的控制器(Controller)有哪些类型?请举例说明。
    • 14.如何进行 Kubectl 命令行工具的安装和配置?
    • 15.分享你在使用 Kubernetes 过程中遇到的一个挑战以及你如何解决它。
  • 更多


在 Kubernetes 中,有以下常见的资源对象:

  1. Pod(Pod):容器的最小调度单位,可以包含一个或多个相关容器。
  2. Deployment(部署):用于控制 Pod 的创建、更新和删除,确保应用的稳定运行。
  3. Service(服务):为一组具有相同标签的 Pod 提供统一访问入口,并提供负载均衡能力。
  4. Ingress(入口):通过定义规则来管理从外部访问集群内 Service 的流量。
  5. ConfigMap(配置映射):存储应用程序的配置数据,以键值对的形式提供给容器。
  6. Secret(密钥):用于存储敏感数据,如密码、令牌等,并将其安全地传递给容器。
  7. Volume(卷):在容器之间共享和持久化数据的抽象概念。
  8. StatefulSet(有状态副本集):管理有状态应用程序的创建、更新和删除,确保每个 Pod 都有唯一的网络标识和稳定的持久化存储。
  9. DaemonSet(守护进程集):确保集群中的每个节点都运行一个 Pod 实例,用于在整个集群中运行系统级任务。
  10. Job(作业):用于创建一次性任务,会运行一个或多个 Pod 直到完成指定的工作。
  11. CronJob(定时作业):根据用户定义的时间表定期运行 Job。
  12. Namespace(命名空间):用于在集群内部分隔资源,实现多租户的隔离和资源管理。
  13. ServiceAccount(服务账户):与 Pod 关联的身份验证信息,并授予 Pod 访问其他资源的权限。

除了上述常见的资源对象之外,Kubernetes 还支持许多其他类型的资源对象,如 PersistentVolume、PersistentVolumeClaim、ReplicaSet、HorizontalPodAutoscaler 等。每个资源对象都有不同的用途和特点,可以根据实际需求选择适合的资源对象来管理和部署应用程序。


1.什么是 Kubernetes?它的主要特点是什么?

Kubernetes 是一个开源的容器编排系统,用于自动化部署、扩展和管理容器应用程序。它可以帮助我们更轻松地部署和管理容器化应用程序,并提供高可用性、弹性、自动化和安全性等特性。


2. Kubernetes 中的 Pod 是什么?它的作用是什么?

Pod 是 Kubernetes 最小的可部署单元,它可以包含一个或多个紧密耦合的容器。Pod 的主要作用是提供一个环境,让容器可以共享网络和存储资源,并且它还提供了容器间通信和生命周期管理等功能。


3.Kubernetes 中的 Deployment 和 StatefulSet 有何区别?

Deployment 用于部署无状态应用程序,而 StatefulSet 用于部署有状态应用程序。StatefulSet 可以保证应用程序的唯一性和顺序性,同时支持有状态服务的动态扩展和缩减等操作。


4.什么是 Kubernetes 中的 Service?它的作用是什么?

Service 是 Kubernetes 中的一种资源对象,它负责为 Pod 提供一个固定的 IP 地址和 DNS 记录,并将请求转发给相应的 Pod。Service 的主要作用是提供网络访问和负载均衡。


5.请解释一下 Kubernetes 中的水平扩展(Horizontal Pod Autoscaling)是什么,以及它是如何工作的?

水平扩展是一种根据应用程序的负载自动调整 Pod 数量的方法。Kubernetes 的 Horizontal Pod Autoscaling(HPA) 功能可以根据 CPU 利用率、内存利用率等指标自动调整 Pod 数量,从而实现负载均衡和避免资源浪费。


6. Kubernetes 中的 ConfigMap 和 Secret 有何区别,分别用于什么目的?

ConfigMap 和 Secret 都用于将配置信息注入到容器中。其中,ConfigMap 主要用于保存配置文件、环境变量等普通字符串类型的配置信息,而 Secret 则主要用于保存敏感信息如密码、证书等加密数据。


7.如何在 Kubernetes 中进行滚动更新(Rolling Update)?

使用 Rolling Update 可以在不中断服务的情况下逐步更新应用程序。在 Kubernetes 中,可以通过修改 Deployment 的版本号等方式来进行滚动更新。通过逐步替换旧的 Pod 实例来达到更新的效果。


8.什么是命名空间(Namespace),以及它在 Kubernetes 中的作用是什么?

命名空间是 Kubernetes 中用于隔离资源的一种机制。它可以将不同的资源组织到不同的命名空间中,以便更好地管理和隔离这些资源。命名空间还提供了一定的访问控制机制,可以限制用户和应用程序对资源的访问权限。


9.如何在 Kubernetes 中使用存储卷(Volume)?

在 Kubernetes 中,可以通过声明式方式或者命令式方式来定义和管理存储卷。通过存储卷,可以将数据持久化到某种外部存储设备中,如云盘、本地磁盘等。


10.Kubernetes 中的调度器(Scheduler)负责什么任务?

调度器是 Kubernetes 中的一个核心组件,它负责选择合适的节点来运行 Pod。调度器根据节点的资源利用率、节点标签、Pod 的要求等因素来做出决策,以便将 Pod 调度到最优的节点上运行。


11.解释一下 Kubernetes 中的亲和性调度(Affinity Scheduling)和反亲和性调度(Anti-Affinity Scheduling)。

亲和性调度和反亲和性调度是 Kubernetes 中常用的 Pod 调度策略。亲和性调度可以将 Pod 调度到拥有特定标签的节点上,反亲和性调度则可以避免将多个相似的 Pod 调度到同一个节点上,以确保高可用性和容错性。

12.什么是 DaemonSet?它在 Kubernetes 集群中的作用是什么?

DaemonSet 是一个特殊的控制器,它负责将 Pod 在集群中的每个节点上启动和管理。DaemonSet 的主要作用是在所有节点上部署后台服务或者特定的网络代理。


13.Kubernetes 中的控制器(Controller)有哪些类型?请举例说明。

在 Kubernetes 中,常见的控制器类型包括 Deployment、StatefulSet、DaemonSet、Job 等。Deployment 可以进行滚动更新、回滚等操作,StatefulSet 可以保证有状态应用程序的唯一性和顺序性,DaemonSet 负责管理每个节点上的 Pod,而 Job 则可以运行一次性任务。


14.如何进行 Kubectl 命令行工具的安装和配置?

Kubectl 是 Kubernetes 命令行工具,可以用于管理 Kubernetes 集群。可以通过下载二进制文件或者使用 apt 或 yum 包管理器来安装和配置 Kubectl。


15.分享你在使用 Kubernetes 过程中遇到的一个挑战以及你如何解决它。

k8s容器不断重启的可能原因和解决方案

  1. 资源不足:如果节点的资源(如 CPU、内存)不足以支持容器正常运行,容器可能会频繁重启。解决方案是检查节点资源使用情况,并确保节点上有足够的资源供容器使用。

  2. 配置错误:配置错误可能导致容器无法启动或崩溃,从而触发重启。解决方案是仔细检查容器的配置文件、环境变量和命令等,确保它们正确无误。

  3. 存储问题:如果容器依赖的存储卷出现问题,如挂载失败、权限问题等,容器可能无法正常运行而重启。解决方案是检查存储卷的状态,确保存储卷正常挂载,并正确配置权限。

  4. 镜像问题:容器使用的镜像可能存在问题,如权限错误、缺少依赖等,导致容器无法启动或崩溃。解决方案是确保容器镜像可用并符合要求,可以尝试使用其他版本的镜像或重新构建镜像。

  5. 网络问题:网络配置错误、端口冲突等问题可能导致容器无法正常通信,从而触发重启。解决方案是检查容器的网络配置,确保端口映射、IP 地址分配等正确配置,并避免网络冲突。

  6. 健康检查失败:容器的健康检查如果失败,将被 Kubernetes 识别为故障容器并自动重启。解决方案是检查健康检查配置,确保容器内的应用程序能够正常响应健康检查请求。

  7. 日志分析:通过查看容器的日志可以帮助定位问题,例如错误日志或异常堆栈信息。从日志中可以获取更多关于容器崩溃的线索,进而解决问题。


更多

2023高薪必备:K8S面试题

在这里插入图片描述

相关文章:

[面试] 15道最典型的k8s面试题

文章目录 在 Kubernetes 中,有以下常见的资源对象:1.什么是 Kubernetes?它的主要特点是什么?2. Kubernetes 中的 Pod 是什么?它的作用是什么?3.Kubernetes 中的 Deployment 和 StatefulSet 有何区别&#x…...

lintcode 552 · 创建最大数 【算法 数组 贪心 hard】

题目 https://www.lintcode.com/problem/552/description 描述 给出两个长度分别是m和n的数组来表示两个大整数&#xff0c;数组的每个元素都是数字0-9。从这两个数组当中选出k个数字来创建一个最大数&#xff0c;其中k满足k < m n。选出来的数字在创建的最大数里面的位置…...

ModbusTCP服务端

1在Device下&#xff0c;添加设备net&#xff1a; 公交车。 2在net下添加 ModbusTCP...

Middleware ❀ Hadoop功能与使用详解(HDFS+YARN)

文章目录 1、服务概述1.1 HDFS1.1.1 架构解析1.1.1.1 Block 数据块1.1.1.2 NameNode 名称节点1.1.1.3 Secondary NameNode 第二名称节点1.1.1.4 DataNode 数据节点1.1.1.5 Block Caching 块缓存1.1.1.6 HDFS Federation 联邦1.1.1.7 Rack Awareness 机架感知 1.1.2 读写操作与可…...

Matlab图像处理-从RGB转换为HSV

从RGB转换为HSV HSV彩色系统基于圆柱坐标系。从RGB转换为HSV需要开发将(笛卡儿坐标系中的)RGB值映射到圆柱坐标系的公式。多数计算机图形学教材中已详细推导了这一公式&#xff0c;故此处从略。 从RGB转换为HSV的MATLAB函数是rgb2hsv&#xff0c;其语法为&#xff1a; hsv_imag…...

iOS Error Domain=PHPhotosErrorDomain Code=3300

AVCapturePhoto的数据保存到 PHPhotoLibrary的时候报错Error DomainPHPhotosErrorDomain Code3300解决代码&#xff08;也可以使用addResourceWithType:data:options:来添加数据到request&#xff0c;JEPG的实测可以&#xff0c;raw的不确定&#xff09;&#xff1a; [PHPhoto…...

LeetCode(力扣)435. 无重叠区间Python

LeetCode435. 无重叠区间 题目链接代码 题目链接 https://leetcode.cn/problems/non-overlapping-intervals/ 代码 class Solution:def eraseOverlapIntervals(self, intervals: List[List[int]]) -> int:if not intervals:return 0intervals.sort(keylambda x: x[0])co…...

opencv c++实现鼠标框选区域并显示选择的图片区域

OpenCV可以使用setMouseCallback设置鼠标事件的回调函数,从而然后根据需要进行处理。 setMouseCallback原型为: void cv::setMouseCallback(const cv::String& windowName, MouseCallback onMouse, void* userData = 0); 其中,参数说明如下:windowName:窗口名称 onMo…...

Python实现自主售卖机

1 问题 在python中我们常常使用到条件判断&#xff0c;if语句时常见的条件判断语句之一。那么如何使用if语句实现根据情况自动选择商品进行售卖呢&#xff1f; 2 方法 根据if语句执行时从上往下执行的特点&#xff0c;使用if语句、dict和list来实现整个流程。 代码清单 1 drink…...

任务复杂度与人机

任务复杂度计算是指根据任务的难易程度和需要的资源投入来评估任务的复杂程度。一般来说&#xff0c;任务复杂度计算会考虑以下几个因素&#xff1a; 难度程度&#xff1a;任务的难度程度是指完成任务所需要的知识、技能和经验等的要求。较高的难度程度会增加任务的复杂度。任务…...

Windows关闭zookeeper、rocketmq日志输出以及修改rocketmq的JVM内存占用大小

JDK-1.8zookeeper-3.4.14rocketmq-3.2.6 zookeeper 进入到zookeeper的conf目录 清空配置文件&#xff0c;只保留下面这一行。zookeeper关闭日志输出相对简单。 log4j.rootLoggerOFFrocketmq 进入到rocketmq的conf目录 logback_broker.xml <?xml version"1.0&q…...

Convai:让虚拟游戏角色更智能的对话AI人工智能平台

【产品介绍】​ 名称 Convai​ 具体描述​ Convai是一款专为虚拟世界而设计的对话人工智能平台&#xff0c;它可以让你为你的游戏或应用中的角色 赋予人类般的对话能力。Convai利用了最先进的生成式对话人工智能技术&#xff0c;让你的角色可以…...

【送书活动】大模型赛道如何实现华丽的弯道超车

文章目录 导读前言AI/ML 模型训练任务对数据平台的需求01 具备对海量小文件的频繁数据访问的 I/O 效率02 提高 GPU 利用率&#xff0c;降低成本并提高投资回报率03 支持各种存储系统的原生接口04 支持单云、混合云和多云部署 核心密码01 通过数据抽象化统一数据孤岛02 通过分布…...

opencv dnn模块 示例(16) 目标检测 object_detection 之 yolov4

博客【opencv dnn模块 示例(3) 目标检测 object_detection (2) YOLO object detection】 测试了yolov3 及之前系列的模型&#xff0c;有在博客【opencv dnn模块 示例(15) opencv4.2版本dnn支持cuda加速&#xff08;vs2015异常解决&#xff09;】 说明了如何使用dnn模块进行cuda…...

Python提取JSON数据中的键值对并保存为.csv文件

本文介绍基于Python&#xff0c;读取JSON文件数据&#xff0c;并将JSON文件中指定的键值对数据转换为.csv格式文件的方法。 在之前的文章Python提取JSON文件中的指定数据并保存在CSV或Excel表格文件内&#xff08;https://blog.csdn.net/zhebushibiaoshifu/article/details/132…...

使用IDEA开发Servlet

一、新建工程 二、填写新工程的基本信息 javaee8的项目可以运行在tomcat9 三、配置tomcat 1、编辑server信息 “On frame deactivation”的意思是idea窗口发生切换时。 2、编辑部署信息 war exploded方式&#xff0c;这种方式是以文件夹方式部署的&#xff0c;支持热加载。 …...

腾讯mini项目-【指标监控服务重构】2023-07-21

今日已办 当在Docker容器中运行程序时&#xff0c;可能会遇到使用os.Getpid()函数时出现异常的情况。这是因为Docker容器中的进程隔离机制与宿主机器不同&#xff0c;容器内部的进程可能无法访问宿主机器的进程信息。 要解决这个问题&#xff0c;可以尝试&#xff1a; 使用do…...

Spring MVC里的DispatchServlet(结合Spring官网翻译)

Spring MVC里的DispatchServlet 前言1.Spring Web MVC1.1 DispatcherServlet&#xff08;中央调度器&#xff09;1.1.1 Context Hierarchy&#xff08;上下文层次结构&#xff09;1.1.2 Special Bean Types&#xff08;特定的bean类型&#xff09;1.1.3 Web MVC Config1.1.4 Se…...

数据分享|R语言武汉流动人口趋势预测:灰色模型GM(1,1)、ARIMA时间序列、logistic逻辑回归模型...

全文链接&#xff1a;http://tecdat.cn/?p32496 人口流动与迁移&#xff0c;作为人类产生以来就存在的一种社会现象&#xff0c;伴随着人类文明的不断进步从未间断&#xff08;点击文末“阅读原文”获取完整代码数据&#xff09;。 相关视频 人力资源是社会文明进步、人民富裕…...

解决 Axios 跨域问题,轻松实现接口调用

跨域是指访问另外一个域的资源&#xff0c;由于浏览器的同源策略&#xff0c;默认情况下使用 XMLHttpRequest 和 Fetch 请求时是不允许跨域的。跨域的根本原因是浏览器的同源策略&#xff0c;这是由浏览器对 JavaScript 施加的安全限制。 Axios 跨域常见报错 跨域请求被阻止 (…...

Layui快速入门之第十节 表单

目录 一&#xff1a;基本用法 二&#xff1a;输入框 普通输入框 输入框点缀 前置和后置 前缀和后缀 动态点缀 密码显隐 内容清除 自定义动态点缀 点缀事件 三&#xff1a;复选框 默认风格 标签风格 开关风格 复选框事件 四&#xff1a;单选框 普通单选框 自…...

Linux之yum/git的使用

目录 一、yum 1、关于yum 2、yum的操作 ①、yum list ②、yum install ③、yum remove 二、git 1、Linux中连接gitee 2、git的操作 ①git add [文件] ②git commit -m "提交日志" ③git push 3、可能出现的问题 ①配置用户名、邮箱 ②出现提交冲突 ③…...

使用ExcelJS快速处理Node.js爬虫数据

什么是ExcelJS ExcelJS是一个用于处理Excel文件的JavaScript库。它可以让你使用JavaScript创建、读取和修改Excel文件。 以下是ExcelJS的一些主要特点&#xff1a; 支持xlsx、xlsm、xlsb、xls格式的Excel文件。可以创建和修改工作表、单元格、行和列。可以设置单元格样式、字…...

轻量级的Python IDE —— Thonny

现在的开发工具太多了&#xff0c;而且每个开发工具都致力于做成最好用最智能的工具&#xff0c;所以功能越堆越多&#xff0c;越怼越智能。安装这些开发工具比较烧脑&#xff0c;经常需要经过许多配置步骤。作为一个 Python 开发者来说&#xff0c;好多人光是这些配置都要弄半…...

java设计模式之观察者模式

. 基本概念 观察者&#xff08;Observer&#xff09;模式中包含两种对象&#xff0c;分别是目标对象和观察者对象。在目标对象和观察者对象间存在着一种一对多的对应关系&#xff0c;当这个目标对象的状态发生变化时&#xff0c;所有依赖于它的观察者对象都会得到通知并执行它…...

掌动智能分享:性能压力测试的重要性与优势

在当今数字化时代&#xff0c;应用程序的性能对于用户体验和业务成功至关重要。为了保证应用程序的高性能和稳定性&#xff0c;性能压力测试成为了不可或缺的环节。在这个领域&#xff0c;掌动智能作为一家专业的性能压力测试公司&#xff0c;正以其卓越的技术与服务&#xff0…...

C# ppt文件转换为pdf文件

使用第三方插件 Office 实现转换 1.Application方式转换 /// <summary>/// Microsoft.Office.Interop.PowerPoint/// 使用第三方软件 office/// </summary>/// <param name"pptPath">需要转换的ppt文件路径</param>/// <param name"…...

使用Pyarmor保护Python脚本不被反向工程

Python可读性强&#xff0c;使用广泛。虽然这种可读性有利于协作&#xff0c;但也增加了未授权访问和滥用的风险。如果未采取适当的保护&#xff0c;竞争对手或恶意攻击者可以复制您的算法和专有逻辑&#xff0c;这将对您软件的完整性和用户的信任产生负面影响。 实施可靠的安…...

STM32单片机——串口通信(轮询+中断)

STM32单片机——串口通信&#xff08;轮询中断&#xff09; 串口通信相关概念HAL库解析及CubeMX工程配置与程序设计常用函数介绍CubeMX工程配置HAL库程序设计&#xff08;轮询中断&#xff09;轮询数据收发中断收发数据 固件库程序设计及实现固件库配置流程结构体配置及初始化程…...

Python if语句的嵌套应用

视频版教程 Python3零基础7天入门实战视频教程 有时候业务上有多维度复杂条件判断&#xff0c;我们需要用到if语句的嵌套来实现。 举例&#xff1a;我们在一些游戏网站活动充值的时候&#xff0c;冲100送 20 冲200送50 但是vip用户的话&#xff0c;冲100送 30 冲200送70 代码…...

做网站不如做公众号/电子商务网站建设规划方案

背景 随着智能网联汽车的发展&#xff0c;车辆的互联性大幅提高&#xff0c;与之相伴的则是大大上升的汽车网络安全风险。根据工信部车联网动态监测情况显示&#xff0c;2020年以来发现整车企业车联网信息服务服务提供商等相关企业和平台的恶意攻击达到280余万次&#xff0c;平…...

做网上推广/seo关键词优化的技巧

最短Hamilton路径 给定一张 n 个点的带权无向图&#xff0c;点从 0~n-1 标号&#xff0c;求起点 0 到终点 n-1 的最短Hamilton路径。 Hamilton路径的定义是从 0 到 n-1 不重不漏地经过每个点恰好一次。 输入格式 第一行输入整数n。 接下来n行每行n个整数&#xff0c;其中第i…...

做古玩生意哪些网站好/中央常委成员名单

点击上方“Java基基”&#xff0c;选择“设为星标”做积极的人&#xff0c;而不是积极废人&#xff01;每天 14:00 更新文章&#xff0c;每天掉亿点点头发...源码精品专栏 原创 | Java 2021 超神之路&#xff0c;很肝~中文详细注释的开源项目RPC 框架 Dubbo 源码解析网络应用框…...

怎么去掉wordpress加载动画/什么是seo营销

公众号迁移的话就是是公众号A可以向公众号B实现功能上的迁移和部分内容选择性转移。公众号不支持直接变更主体。公众平台推出帐号迁移功能&#xff0c;通过此功能可将A账号的粉丝、文章素材(可选)、违规记录、以及带有的留言功能、原创保护功能迁移至B帐号。帐号A迁移至B&#…...

个人可以做商城网站/新网站排名优化怎么做

可以在游戏中添加或者删除物品及方块&#xff0c;包括mod附加的东西。保存和读取某个时间点背包机身上的东西。创建一个可以无限使用的物品和工具。可以用来检测mod的功能&#xff0c;创建巨大的用来生存的世界。控制界面开关&#xff1a;在背包界面按“o”可以控制TMI界面的开…...

网站开发时保证用户登陆的安全/百度快速排名工具

HANA 语法什么的看这里&#xff0c;懒得写博客了 HANA语法参考&#xff1a;SAP HANA Reference 分类数据类型日期时间类型( Date time&#xff09;DATE, TIME, SECONDDATE, TIMESTAMP数字类型( Numeric)TINYINT, SMALLINT, INTEGER, BIGINT, SMALLDECIMAL,DECIMAL, REAL, DO…...