网站部署上线后, 总是担心网站是否工作正常, 内存压力是否很大, CPU是否超负荷了?当然, 我们有一大套系统, perfromance counter, 监控软件来监视运维生产系统。但是这些第三方软件,不是要钱就是很难用。有时候,我们只是给客户上线一个小网站,完全没有时间,也没有兴趣去搭建一套完整的监控系统。

当然,自己写一个WebAPI, 向外部报告自己内部的状况,已经相关联的第三方软件(如SQL, redis)的状况, 不复杂但也不是一两个小时候就可以写好的,很多时候犯懒就不写了。

HealthAPI一般不希望无关人员查看, 可以通过AspNetCore 限流中间件IpRateLimitMiddleware 介绍 来限制特定IP可以访问。

AspNetCore 2.2中提供了一系列pakcage, 只要几行代码,就可以很简单实现网站健康状况报告,没有理由不提供内部health报告了。而且Docker越来越流行了,Kubernetes管理容器,也许要知道容器是否出现问题需要重启, 也需要提供一个标准方法,告诉外部,容器内部状态。

简单应用

只要注册服务AddHealthChecks, 然后在app.UseHealthChecks("/health"); 开启端点报告内部状态。

  1. public void ConfigureServices(IServiceCollection services)
  2. {
  3. services.AddHealthChecks();
  4. }
  5. public void Configure(IApplicationBuilder app, IHostingEnvironment env)
  6. {
  7. app.UseHealthChecks("/health");
  8. app.Run(async (context) =>
  9. {
  10. await context.Response.WriteAsync(
  11. "Navigate to /health to see the health status.");
  12. });
  13. }

访问端口 /Health 的返回结果为
Healthy
这是最基础的Health端口,好像没什么功能, 稍安勿躁,马上就有更精彩的。。。

报告外部依赖项的健康状况

程序运行需要内存, cpu,需要磁盘空间, 现在的网站更是依赖于各种各样的第三方系统, 比如:数据库, 缓存等等。这些东西如果不正常,我们的网站也不可能正常运行。好消息是, ASPNetCore提供了大量的辅助类型,来提供这些系统是否正常:

首先需要安装下面的nuget包
Install-Package AspNetCore.HealthChecks.System
Install-Package AspNetCore.HealthChecks.Network
Install-Package AspNetCore.HealthChecks.SqlServer
Install-Package AspNetCore.HealthChecks.MongoDb
Install-Package AspNetCore.HealthChecks.Npgsql
Install-Package AspNetCore.HealthChecks.Redis
Install-Package AspNetCore.HealthChecks.AzureStorage
Install-Package AspNetCore.HealthChecks.AzureServiceBus
Install-Package AspNetCore.HealthChecks.MySql
Install-Package AspNetCore.HealthChecks.DocumentDb
Install-Package AspNetCore.HealthChecks.SqLite
Install-Package AspNetCore.HealthChecks.Kafka
Install-Package AspNetCore.HealthChecks.RabbitMQ
Install-Package AspNetCore.HealthChecks.IdSvr
Install-Package AspNetCore.HealthChecks.DynamoDB
Install-Package AspNetCore.HealthChecks.Oracle
Install-Package AspNetCore.HealthChecks.Uris

  1. public void ConfigureServices(IServiceCollection services)
  2. {
  3. services.AddHealthChecks()
  4. //System
  5. .AddPrivateMemoryHealthCheck(1000_000_000L) //最大私有内存不超过1GB
  6. .AddVirtualMemorySizeHealthCheck(1000_000_000L) //最大虚拟内存不超过1GB
  7. .AddWorkingSetHealthCheck(1000_000_000L)//最大工作内存不超过1GB
  8. .AddDiskStorageHealthCheck( x=> x.AddDrive("c",1000_000_000L)) //C盘需要超过1GB自由空间
  9. //network
  10. .AddSmtpHealthCheck(x => { x.Host = "mailserver"; x.Port = 110; x.ConnectionType = SmtpConnectionType.TLS; }) //检查邮件服务器是否正常
  11. //sqlserver
  12. .AddSqlServer("ConnectionStrings");
  13. //redis
  14. .AddRedis("RedisServerLink")
  15. ;
  16. }
  17. public void Configure(IApplicationBuilder app, IHostingEnvironment env)
  18. {
  19. app.UseHealthChecks("/health",
  20. new HealthCheckOptions
  21. {
  22. ResponseWriter = async (context, report) =>
  23. {
  24. var result = JsonConvert.SerializeObject(
  25. new
  26. {
  27. status = report.Status.ToString(),
  28. errors = report.Entries.Select(e => new { key = e.Key, value = Enum.GetName(typeof(HealthStatus), e.Value.Status) })
  29. });
  30. context.Response.ContentType = MediaTypeNames.Application.Json;
  31. await context.Response.WriteAsync(result);
  32. }
  33. });
  34. app.Run(async (context) =>
  35. {
  36. await context.Response.WriteAsync(
  37. "Navigate to /health to see the health status.");
  38. });
  39. }

很棒吧, 一下就可以知道应用是否正常, 如果不正常,是因为什么不正常。 如果是内存, cpu过高, 也许需要重启一下。

自定义健康检查

预定义的health检查器用起来很棒, 但是总是会有一些特殊要求, 比如我们要检查内部工作队列是否太大, 启用的线程是否太多等, 这就需要自己写Health检查器。 好消息是, 只要实现IHealthCheck这个接口就好。

  1. public class WorkQueueHealthCheck : IHealthCheck
  2. {
  3. private readonly IOptionsMonitor<WorkQueueCheckOptions> _options;
  4. public WorkQueueHealthCheck(IOptionsMonitor<WorkQueueCheckOptions> options)
  5. {
  6. _options = options;
  7. }
  8. public string Name => "工作队列检查";
  9. public Task<HealthCheckResult> CheckHealthAsync(
  10. HealthCheckContext context,
  11. CancellationToken cancellationToken = default(CancellationToken))
  12. {
  13. HealthStatus status = HealthStatus.Healthy;
  14. if (staticQueues.Length > 10000)
  15. {
  16. status = HealthStatus.Unhealthy; //待处理的任务太多了, 不健康了。
  17. }else if (staticQueues.Length > 1000)
  18. {
  19. status = HealthStatus.Degraded; //待处理的任务有点多, 降级了。
  20. }
  21. var data = new Dictionary<string, object>()
  22. {
  23. { "当前工作队列长度", staticQueues.Length },
  24. };
  25. return Task.FromResult(new HealthCheckResult(
  26. status,
  27. description: "报告内部工作队列情况",
  28. exception: null,
  29. data: data));
  30. }
  31. }
  32. public static class HealthCheckBuilderExtensions
  33. {
  34. public static IHealthChecksBuilder AddWorkQueueHealthCheck(
  35. this IHealthChecksBuilder builder,
  36. string name,
  37. HealthStatus? failureStatus = null,
  38. IEnumerable<string> tags = null,
  39. long? thresholdInBytes = null)
  40. {
  41. // Register a check of type GCInfo.
  42. builder.AddCheck<WorkQueueHealthCheck>(
  43. name, failureStatus ?? HealthStatus.Degraded, tags);
  44. return builder;
  45. }
  46. }

定义好自己的健康检查扩展以后, 只需要像使用预定义的扩展一样,非常方便。

services.AddHealthChecks()
.AddPrivateMemoryHealthCheck(“workQueue”) //检查工作队列

参考自Health checks in ASP.NET Core

 
 

15人点赞

 
ASPNET

 

AspNetCore 2.2 新特性---HealthCheck的更多相关文章

  1. Asp.net Core中SignalR Core预览版的一些新特性前瞻,附源码(消息订阅与发送二进制数据)

    目录 SignalR系列目录(注意,是ASP.NET的目录.不是Core的) 前言 一晃一个月又过去了,上个月有个比较大的项目要验收上线.所以忙的脚不沾地.现在终于可以忙里偷闲,写一篇关于Signal ...

  2. ASP.NET Core 2.0 Preview 1 中贴心的新特性

    西雅图时间5月10日,微软在 Build 2017 大会上发布了 ASP.NET Core 2.0 Preview 1 ( 详见 Announcing ASP.NET 2.0.0-Preview1 a ...

  3. efcore 新特性 SaveChanges Events

    efcore 新特性 SaveChanges Events Intro 昨天早上看到之前关注的一个 efcore 的 issue 被 closed ,于是看了一眼, ef core 新合并了一个 PR ...

  4. 尝新体验ASP.NET Core 6预览版本中发布的最小Web API(minimal APIS)新特性

    本文首发于<尝新体验ASP.NET Core 6预览版本中发布的最小Web API(minimal APIS)新特性> 概述 .NET开发者们大家好,我是Rector. 几天前(美国时间2 ...

  5. ABP 6.0.0-rc.1的新特性

      2022-07-26官方发布ABP 6.0.0-rc.1版本,本文挑选了几个新特性进行了介绍,主要包括LeptonX Lite默认主题.OpenIddict模块,以及如何将Identity Ser ...

  6. SQL Server 2014 新特性——内存数据库

    SQL Server 2014 新特性——内存数据库 目录 SQL Server 2014 新特性——内存数据库 简介: 设计目的和原因: 专业名词 In-Memory OLTP不同之处 内存优化表 ...

  7. ElasticSearch 5学习(10)——结构化查询(包括新特性)

    之前我们所有的查询都属于命令行查询,但是不利于复杂的查询,而且一般在项目开发中不使用命令行查询方式,只有在调试测试时使用简单命令行查询,但是,如果想要善用搜索,我们必须使用请求体查询(request ...

  8. [干货来袭]C#6.0新特性

    微软昨天发布了新的VS 2015 ..随之而来的还有很多很多东西... .NET新版本 ASP.NET新版本...等等..太多..实在没消化.. 分享一下也是昨天发布的新的C#6.0的部分新特性吧.. ...

  9. CSS3新特性应用之结构与布局

    一.自适应内部元素 利用width的新特性min-content实现 width新特性值介绍: fill-available,自动填充盒子模型中剩余的宽度,包含margin.padding.borde ...

随机推荐

  1. export default 和 export 的主要区别

    export default 和 export 的主要区别 在于对应的import的区别:export 对应的 import 需要知道 export抛出的变量名或函数名 import{a,b}expo ...

  2. applyMiddleware 沉思录

    let newStore = applyMiddleware(mid1, mid2, mid3, ...)(createStore)(reducer, null); 给({ getState, dis ...

  3. ssh ssm ssi 服务器平台架构

    1.spring + springmvc + mybatis 使用maven构建,数据库是oracle,主要是温习mybatis配置以及与spring集成.这种框架目前是使用最广泛的,这里就不多说 2 ...

  4. c++、oc、swift初步评价

    c++是面向对象的多态语言: oc是面向对象的动态语言: swift是面向对象.面向协议.高阶类型.函数式编程语言:

  5. JAVA基础--环境搭建

    概况 系统:win10 企业版 IDE:Eclipse 4.7.3 JDK:jdk1.8.0_171 数据库:SQLServer2012 Oracle,未安装MySQL 安装 JDK与开发工具(Ecl ...

  6. paython基础-格式化输出

    目录 %s %r %d 及其他%... formate f"{变量}" 详细查找:https://docs.python.org/3/library/string.html#for ...

  7. 文件系统EXT3,EXT4和XFS的区别

    1. EXT3 (1)最多只能支持32TB的文件系统和2TB的文件,实际只能容纳2TB的文件系统和16GB的文件 (2)Ext3目前只支持32000个子目录 (3)Ext3文件系统使用32位空间记录块 ...

  8. 在Rancher中添加为中国区优化的k8s应用商店的步骤和方法

    1.停用 rancher 应用商店中的“Rancher官方认证”商店和“社区贡献”商店 2.添加应用商店: 名称             地址                             ...

  9. 使用uiautomator2自动化测试app(二)------操作篇

    提示: 1. 推荐使用python3以上的版本来进行开发 2. 手机使用安卓手机,版本最好不要太老,一根数据线 3. 安装虚拟机(博主使用雷电) 操作: 这里只简单的介绍一些uiautomator2的 ...

  10. dubbo中的Filter链原理及应用

    转载:https://www.jianshu.com/p/f390bb88574d filter在dubbo中的应用非常广泛,它可以对服务端.消费端的调用过程进行拦截,从而对dubbo进行功能上的扩展 ...