【微服务部署】03-健康检查

文章目录

    • [1. 探针集成实现高可用](#1. 探针集成实现高可用)
      • [1.1 LivenessProbe](#1.1 LivenessProbe)
      • [1.2 ReadinessProbe](#1.2 ReadinessProbe)
      • [1.3 StartupProbe](#1.3 StartupProbe)
    • [2. 健康检查看板](#2. 健康检查看板)
      • [2.1 组件包](#2.1 组件包)

1. 探针集成实现高可用

  • Liveness
  • Readiness
  • Startup

1.1 LivenessProbe

  • 判断服务是否存活
  • 结束"非存活"状态服务
  • 根据重启策略决定是否重启服务

1.2 ReadinessProbe

  • 判断服务是否"就绪"
  • "就绪"状态的服务可以接收请求
  • 非"就绪"状态的服务将会被从流量负载中摘除

1.3 StartupProbe

  • 检测应用程序是否启动成功

  • 启动探针执行成功后,将不再执行,除非应用重启

  • 当启动探针检测成功后,其它探针才开始工作

  • 适合启动较慢的应用配置

  • Kuberbetes 1.16以后的支持

    // startup
    internal static bool Ready { get; set; } = true;
    internal static bool Live { get; set; } = true;

    public void ConfigureServices(IServiceCollection services)
    {
    ...
    // 注册健康检查
    services.AddHealthChecks()
    .AddMySql(Configuration.GetValue<string>("Mysql"), "mysql", tags: new string[] { "mysql", "live", "all" })// tags标签分组
    .AddRabbitMQ(s =>
    {
    var connectionFactory = new RabbitMQ.Client.ConnectionFactory();
    Configuration.GetSection("RabbitMQ").Bind(connectionFactory);
    return connectionFactory;
    }, "rabbitmq", tags: new string[] { "rabbitmq", "live", "all" })
    .AddCheck("liveChecker", () =>
    {
    return Live ? HealthCheckResult.Healthy() : HealthCheckResult.Unhealthy();
    }, new string[] { "live", "all" })
    .AddCheck("readyChecker", () =>
    {
    return Ready ? HealthCheckResult.Healthy() : HealthCheckResult.Unhealthy();
    }, new string[] { "ready", "all" });
    }

    //
    public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
    {
    ...
    app.UseEndpoints(endpoints =>
    {
    endpoints.MapMetrics();
    endpoints.MapHealthChecks("/live", new HealthCheckOptions { Predicate = registration => registration.Tags.Contains("live") });// 检查标记了live的检查项
    endpoints.MapHealthChecks("/ready", new HealthCheckOptions { Predicate = registration => registration.Tags.Contains("ready") });
    endpoints.MapHealthChecks("/hc", new Microsoft.AspNetCore.Diagnostics.HealthChecks.HealthCheckOptions
    {
    ResponseWriter = HealthChecks.UI.Client.UIResponseWriter.WriteHealthCheckUIResponse
    });// 没有传检查项,检查所有
    endpoints.MapControllers();
    endpoints.MapGrpcService<GeekTime.Ordering.API.Grpc.OrderServiceImpl>();
    });
    }

    // Controller调用
    // 设置Ready的值
    [HttpGet]
    public IActionResult SetReady([FromQuery]bool ready)
    {
    Startup.Ready = ready;
    if (!ready)
    {
    Task.Run(async () =>
    {
    await Task.Delay(60000);
    Startup.Ready = true;
    });
    }
    return Content($"{Environment.MachineName} : Ready={Startup.Ready}");
    }

    // 设置live
    [HttpGet]
    public IActionResult SetLive([FromQuery]bool live)
    {
    Startup.Live = live;
    return Content($"{Environment.MachineName} : Live={Startup.Live}");
    }

    // 程序退出
    [HttpGet]
    public IActionResult Exit([FromServices]IHostApplicationLifetime application)
    {
    Task.Run(async () =>
    {
    await Task.Delay(3000);
    application.StopApplication();
    });
    return Content($"{Environment.MachineName} : Stopping");
    }

2. 健康检查看板

AspNetCore.Diagnostics.HealthCheck项目,开源社区项目插件

2.1 组件包

  • 探针检测端:AspNetCore.HealthChecks.UI

  • 应用端输出:AspNetCore.HealthChecks.UI.Client

  • 应用端检查项:AspNetCore.HealthChecks.Xxx

    // startup
    public void ConfigureServices(IServiceCollection services)
    {
    services.AddMvc();
    services.AddHealthChecks();
    services.AddHealthChecksUI();
    }

    public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
    {
    if (env.IsDevelopment())
    {
    app.UseDeveloperExceptionPage();
    }

    复制代码
         app.UseRouting();
         app.UseEndpoints(endpoints =>
         {
             endpoints.MapHealthChecks("/live");
             endpoints.MapHealthChecks("/ready");
             endpoints.MapHealthChecks("/hc");
             endpoints.MapMetrics();
             endpoints.MapHealthChecksUI();// 使得dashboard生效
             endpoints.MapControllers();
         });
     }

    // 配置文件配置需要检查的项目
    "HealthChecksUI": {
    "HealthChecks": [
    {
    "Name": "geektime-ordering-api",
    "Uri": "http://geektime-ordering-api/hc"
    },
    {
    "Name": "geektime-mobile-apiaggregator",
    "Uri": "http://geektime-mobile-apiaggregator/hc"
    },
    {
    "Name": "geektime-mobile-gateway",
    "Uri": "http://geektime-mobile-gateway/hc"
    }
    ],

相关推荐
qq_297574673 小时前
【实战教程】SpringBoot 集成阿里云短信服务实现验证码发送
spring boot·后端·阿里云
java干货4 小时前
<span class=“js_title_inner“>微服务:把一个简单的问题,拆成 100 个网络问题</span>
微服务·云原生·架构
缺点内向5 小时前
C#编程实战:如何为Word文档添加背景色或背景图片
开发语言·c#·自动化·word·.net
韩立学长5 小时前
【开题答辩实录分享】以《智能大学宿舍管理系统的设计与实现》为例进行选题答辩实录分享
数据库·spring boot·后端
编码者卢布7 小时前
【Azure Storage Account】Azure Table Storage 跨区批量迁移方案
后端·python·flask
学海无涯书山有路8 小时前
async-await异步编程
c#
切糕师学AI8 小时前
ARM 汇编器中的伪指令(Assembler Directives)
开发语言·arm开发·c#
她说..10 小时前
策略模式+工厂模式实现审批流(面试问答版)
java·后端·spring·面试·springboot·策略模式·javaee
梦梦代码精11 小时前
开源、免费、可商用:BuildingAI一站式体验报告
开发语言·前端·数据结构·人工智能·后端·开源·知识图谱
lzhdim11 小时前
C#开发的提示显示例子 - 开源研究系列文章
开发语言·c#