文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Kubernetes 存活、就绪探针

2024-12-24 15:38

关注

当应用程序可以快速从故障中恢复时,它便具有弹性。

云原生应用程序通常设计为使用微服务架构,其中每个组件都位于容器中。为了确保Kubernetes托管的应用程序高可用,在设计集群时需要遵循一些特定的模式,其中有“健康探测模式”。应用 高可观察性原则 (HOP)可确保您的应用程序收到的每个请求都能及时找到响应。

The High Observability Principle (HOP)

高可观察性原则是基于容器的应用程序设计原则之一。微服务体系要求每个服务不关心(也不应该关心)被调用方如何处理请求。

HOP原则要求每个服务必须公开几个API端点,其意义在于揭示服务健康状态,Kubernetes调用这些端点,决定下一步的路由和负载平衡。

设计良好的云原生程序应将日志事件记录到STDERR和STDOUT,由logstash、Fluent等日志摄取服务将这些日志运送到集中式监控(例如Prometheus)和日志聚合系统(例如ELK)。下图说明了云原生应用程序如何遵守健康状况探测模式和高可观察性原则。

 

How to Apply Health Probe Pattern in Kubernetes?

我之前写过ASP.NetCore + Docker健康检查的原创:[web程序暴露http健康检查端点,平台轮询探测], Kubernetes针对不同场合细化了探针,更为强大的是给出对应决策。

Liveness Probes

使用[存活探针]判断什么时候重启容器。

使用存活探针检查容器本身是否无响应、死锁, 有时候重启容器常常能解决此类问题。

我们以kubernetes官方demo为例:

  1. apiVersion: v1 
  2. kind: Pod 
  3. metadata: 
  4.   labels: 
  5.     test: liveness 
  6.   name: liveness-exec 
  7. spec: 
  8.   containers: 
  9.   - name: liveness 
  10.     image: busybox 
  11.     args: 
  12.     - /bin/sh    - -c    - touch /tmp/healthy; sleep 30; rm -rf /tmp/healthy; sleep 600 
  13.     livenessProbe: 
  14.       exec
  15.         command: 
  16.         - cat 
  17.         - /tmp/healthy 
  18.       initialDelaySeconds: 5   # 指示kubectl等待5s才执行首次探测 
  19.       periodSeconds: 5         # 间隔5秒轮询 

这个探针会体现到 kubectl get pod 的 RESTARTS 列

 

Readiness Probes

使用[就绪探针]判断容器是否就绪,是否可以接受流量。

Pod内所有容器ready,则该Pod被认为ready,当pod没有ready,将会从服务负载均衡中移除。

有些时候,应用程序临时不可用(加载大量数据或者依赖外部服务),这个时候,重启这个Pod无济于事,同时你也不希望请求被发送到该Pod

下面的应用强依赖mongodb,我们针对这些依赖项设置了readiness探针

  1. services.AddHealthChecks() 
  2.     .AddCheck(nameof(MongoHealthCheck), tags: new[] { "readyz" }); 
  3. // ---------------------- 
  4. app.UseHealthChecks("/readyz", new HealthCheckOptions 
  5.         Predicate = (check) => check.Tags.Contains("readyz"
  6. }); 

以下是探测Mongodb的连通性

  1. sealed class MongoHealthCheck : IHealthCheck 
  2.     {        private readonly IMongoDatabase _defaultMongoDatabase; 
  3.         public MongoHealthCheck(IDefaultMongoDatabaseProvider defaultMongoDatabaseProvider) 
  4.         {            _defaultMongoDatabase = defaultMongoDatabaseProvider.GetDatabase();        }        public async Task CheckHealthAsync(HealthCheckContext context, CancellationToken cancellationToken = default
  5.         {            var doc = await _defaultMongoDatabase.RunCommandAsync( 
  6.                 new BsonDocumentCommand
  7.                     new BsonDocument() { 
  8.                         { "ping""1" } 
  9.                     }),                 cancellationToken: cancellationToken);            var ok = doc["ok"].ToBoolean(); 
  10.             if (ok) 
  11.             {                return HealthCheckResult.Healthy("OK"); 
  12.             }            return HealthCheckResult.Unhealthy("NotOK"); 
  13.         }    } 

对于依赖项的探测,探测周期和超时时间可以设置的稍长一点

  1. readinessProbe: 
  2.   httpGet: 
  3.     path: /readyz 
  4.     port: 80 
  5.   initialDelaySeconds: 5 
  6.   periodSeconds: 60     # 60s探测一次 
  7.   timeoutSeconds: 30    # 每次探测30s超时,与应用建立与依赖项的连接超时时间一致 
  8.   failureThreshold: 3   # 连续3次探测失败,该Pod会被标记为`Unready` 

Startup Probes

使用[启动探针]判断容器应用是否已经启动。如果配置了这个探针,则该探针成功之前将会禁用存活和就绪探针。

配置探针

强烈建议根据应用结构合理设置探针参数,避免不切实际的认定失败导致的频繁重启或 Unready。

结论:

就使用方式看:

Kubernetes存活、就绪探针可以极大地提高服务的健壮性和弹性,并提供出色的最终用户体验。

来源:今日头条内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯