k8s探针详细学习笔记

2024-08-30 00:04

本文主要是介绍k8s探针详细学习笔记,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在 Kubernetes 中,主要有三种类型的探针(Probes),用于检测容器的状态:
1.存活探针(Liveness Probes):
用来检测容器是否存活,即容器是否仍在运行。如果存活探针失败,Kubernetes 会根据容器的重启策略来重启容器。
2.就绪探针(Readiness Probes):
用来检测容器是否已经准备好接收流量。如果就绪探针失败,Kubernetes 会阻止将新的流量发送到该容器,但不会重启容器。
3.启动探针(Startup Probes):
用来检测容器内的应用程序是否在启动期间已经可用。这是 Kubernetes 1.12 版本引入的特性。如果启动探针失败,Kubernetes 会认为容器没有成功启动,并根据重启策略来重启容器。

三者结合使用的顺序是:启动探针——>存活探针——>就绪探针

每种探针都可以通过以下三种方式来实现:

ExecAction:
在容器内执行一个命令,根据命令的退出状态码来判断容器状态。

TCPSocketAction:
对容器的 IP 地址和端口进行 TCP 检查,如果能够建立连接,则认为容器状态正常。

HTTPGetAction:
向容器的 IP 地址和端口发送 HTTP GET 请求,根据响应状态码来判断容器状态。

每种探针都可以配置以下探针配置参数:
initialDelaySeconds:容器启动后等待多少秒再开始执行探针。
periodSeconds:探针的执行频率。
timeoutSeconds:探针超时时间。
successThreshold:探测成功时的阈值。
failureThreshold:探测失败时的阈值。

各个探针示例:
启动探针(Startup Probes)
应用场景:
检测应用程序是否在启动过程中已经可用。
例如,应用程序可能需要较长时间来初始化,在此期间不应接收流量。

startupProbe:httpGet:path: /healthport: 8080failureThreshold: 30periodSeconds: 10

这个配置表示在容器启动后,每 10 秒发送一次 HTTP GET 请求到 http://:8080/health。如果在连续 30 次尝试中都失败,Kubernetes 将重启容器。这个探针可以防止在应用程序完全启动之前接收流量。

存活探针(Liveness Probes)
应用场景:
检测应用程序是否仍在运行,但未响应。
例如,应用程序可能因为某些错误而挂起或停止响应请求。

livenessProbe:exec:command: ["cat", "/tmp/health"]initialDelaySeconds: 15periodSeconds: 20

这个配置表示在容器启动 15 秒后,每 20 秒执行一次 cat /tmp/health 命令。如果命令返回非 0 状态码,Kubernetes 将重启容器。

就绪探针(Readiness Probes)
应用场景:
确定应用程序是否已经完全启动并准备好接收请求。
例如,应用程序可能需要加载大量数据或完成初始化操作。

readinessProbe:httpGet:path: /readyport: 8080initialDelaySeconds: 5periodSeconds: 10

这个配置表示在容器启动 5 秒后,每 10 秒发送一次 HTTP GET 请求到 http://:8080/ready。如果请求返回的 HTTP 状态码不是 200-399 范围内的值,Kubernetes 将不会向该容器发送流量。

这篇关于k8s探针详细学习笔记的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

Spring AI集成DeepSeek的详细步骤

《SpringAI集成DeepSeek的详细步骤》DeepSeek作为一款卓越的国产AI模型,越来越多的公司考虑在自己的应用中集成,对于Java应用来说,我们可以借助SpringAI集成DeepSe... 目录DeepSeek 介绍Spring AI 是什么?1、环境准备2、构建项目2.1、pom依赖2.2

Goland debug失效详细解决步骤(合集)

《Golanddebug失效详细解决步骤(合集)》今天用Goland开发时,打断点,以debug方式运行,发现程序并没有断住,程序跳过了断点,直接运行结束,网上搜寻了大量文章,最后得以解决,特此在这... 目录Bug:Goland debug失效详细解决步骤【合集】情况一:Go或Goland架构不对情况二:

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详

Deepseek R1模型本地化部署+API接口调用详细教程(释放AI生产力)

《DeepseekR1模型本地化部署+API接口调用详细教程(释放AI生产力)》本文介绍了本地部署DeepSeekR1模型和通过API调用将其集成到VSCode中的过程,作者详细步骤展示了如何下载和... 目录前言一、deepseek R1模型与chatGPT o1系列模型对比二、本地部署步骤1.安装oll

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

Spring Boot整合log4j2日志配置的详细教程

《SpringBoot整合log4j2日志配置的详细教程》:本文主要介绍SpringBoot项目中整合Log4j2日志框架的步骤和配置,包括常用日志框架的比较、配置参数介绍、Log4j2配置详解... 目录前言一、常用日志框架二、配置参数介绍1. 日志级别2. 输出形式3. 日志格式3.1 PatternL

Springboot 中使用Sentinel的详细步骤

《Springboot中使用Sentinel的详细步骤》文章介绍了如何在SpringBoot中使用Sentinel进行限流和熔断降级,首先添加依赖,配置Sentinel控制台地址,定义受保护的资源,... 目录步骤 1: 添加 Sentinel 依赖步骤 2: 配置 Sentinel步骤 3: 定义受保护的

本地私有化部署DeepSeek模型的详细教程

《本地私有化部署DeepSeek模型的详细教程》DeepSeek模型是一种强大的语言模型,本地私有化部署可以让用户在自己的环境中安全、高效地使用该模型,避免数据传输到外部带来的安全风险,同时也能根据自... 目录一、引言二、环境准备(一)硬件要求(二)软件要求(三)创建虚拟环境三、安装依赖库四、获取 Dee

MySql9.1.0安装详细教程(最新推荐)

《MySql9.1.0安装详细教程(最新推荐)》MySQL是一个流行的关系型数据库管理系统,支持多线程和多种数据库连接途径,能够处理上千万条记录的大型数据库,本文介绍MySql9.1.0安装详细教程,... 目录mysql介绍:一、下载 Mysql 安装文件二、Mysql 安装教程三、环境配置1.右击此电脑