tnblog
首页
视频
资源
登录

.net core 3.1 服务承载【依赖注入】

5556人阅读 2021/2/2 21:59 总访问:3663893 评论:0 收藏:0 手机
分类: .net后台框架

.netcore

.net core 3.1 服务承载【依赖注入】

目录

https://www.tnblog.net/hb/article/details/5591 ,请结合我上一篇的来看,上一篇连接地址:https://www.tnblog.net/hb/article/details/5568

前言

大概做的调整如图所示,这样做的好处就是:
(1) 通过依赖注入,性能指标的来源可以是不同的地方获得的
(2) 处理的具体方式也可以是不同的实现进行的处理

项目内容

接口的代码

  1. // 网络,内存,CPU性能接口
  2. public interface IMemoryMetricsCollector
  3. {
  4. long GetUsage();
  5. }
  6. public interface INetworkMetricsCollector
  7. {
  8. long GetThroughput();
  9. }
  10. public interface IProcessorMetricsCollector
  11. {
  12. int GetUsage();
  13. }
  14. // 处理接口
  15. public interface IMetricsDeliverer
  16. {
  17. Task DeliverAsync(PerformanceMetrics performanceMetrics);
  18. }

实现性能的接口

  1. public class FakeMetricsCollector :
  2. IProcessorMetricsCollector,
  3. INetworkMetricsCollector,
  4. IMemoryMetricsCollector
  5. {
  6. public long GetThroughput() => PerformanceMetrics.Create().Network;
  7. public long GetUsage() => PerformanceMetrics.Create().Memory;
  8. int IProcessorMetricsCollector.GetUsage() => PerformanceMetrics.Create().Processor;
  9. }

实现对指标的操作

  1. public class FakeMetricsDeliverer : IMetricsDeliverer
  2. {
  3. public Task DeliverAsync(PerformanceMetrics performanceMetrics)
  4. {
  5. Console.WriteLine($"[{DateTimeOffset.Now}]:{performanceMetrics}");
  6. return Task.CompletedTask;
  7. }
  8. }

修改PerformanceMetricsCollector

  1. public sealed class PerformanceMetricsCollector : IHostedService
  2. {
  3. private readonly IProcessorMetricsCollector _processorMetricsCollector;
  4. private readonly INetworkMetricsCollector _networkMetricsCollector;
  5. private readonly IMetricsDeliverer _metricsDeliverer;
  6. private readonly IMemoryMetricsCollector _memoryMetricsCollector;
  7. private IDisposable _scheduler;
  8. public PerformanceMetricsCollector(
  9. IProcessorMetricsCollector processorMetricsCollector,
  10. INetworkMetricsCollector networkMetricsCollector,
  11. IMetricsDeliverer metricsDeliverer,
  12. IMemoryMetricsCollector memoryMetricsCollector
  13. )
  14. {
  15. _processorMetricsCollector = processorMetricsCollector;
  16. _networkMetricsCollector = networkMetricsCollector;
  17. _metricsDeliverer = metricsDeliverer;
  18. _memoryMetricsCollector = memoryMetricsCollector;
  19. }
  20. /// <summary>
  21. /// 启动服务
  22. /// </summary>
  23. /// <param name="cancellationToken"></param>
  24. /// <returns></returns>
  25. public Task StartAsync(CancellationToken cancellationToken)
  26. {
  27. // 需要调用的方法 需要传入的对象 多久后启动 间隔时长执行一次
  28. _scheduler = new Timer(Callback,null,TimeSpan.FromSeconds(5),TimeSpan.FromSeconds(5));
  29. return Task.CompletedTask;
  30. }
  31. private async void Callback(object state)
  32. {
  33. // 通过不同
  34. var performanceMetrics = new PerformanceMetrics() {
  35. Memory = _memoryMetricsCollector.GetUsage(),
  36. Network = _networkMetricsCollector.GetThroughput(),
  37. Processor = _processorMetricsCollector.GetUsage()
  38. };
  39. await _metricsDeliverer.DeliverAsync(performanceMetrics);
  40. }
  41. /// <summary>
  42. /// 关闭服务
  43. /// </summary>
  44. /// <param name="cancellationToken"></param>
  45. /// <returns></returns>
  46. public Task StopAsync(CancellationToken cancellationToken)
  47. {
  48. _scheduler?.Dispose();
  49. return Task.CompletedTask;
  50. }
  51. }

通过依赖注入的方式

  1. var fakeMetricsCollector = new FakeMetricsCollector();
  2. new HostBuilder()
  3. .ConfigureServices(svcs => svcs
  4. .AddSingleton<IProcessorMetricsCollector>(fakeMetricsCollector)
  5. .AddSingleton<INetworkMetricsCollector>(fakeMetricsCollector)
  6. .AddSingleton<IMemoryMetricsCollector>(fakeMetricsCollector)
  7. .AddSingleton<IMetricsDeliverer, FakeMetricsDeliverer>()
  8. .AddSingleton<IHostedService, PerformanceMetricsCollector>()
  9. )
  10. .Build()
  11. .Run();

运行测试


欢迎加群讨论技术,1群:677373950(满了,可以加,但通过不了),2群:656732739

评价

.net core 3.1 服务承载承载长时间运行服务

.net core 3.1 服务承载【承载长时间运行服务】[TOC] 目录 https://www.tnblog.net/hb/article/details/5591 前言 当我...

.net core 3.1 服务承载配置选项

.net core 3.1 服务承载【配置选项】[TOC] 目录 https://www.tnblog.net/hb/article/details/5591 配置选项 承载配置 ...

.net core 3.1 服务承载配置文件

.net core 3.1 服务承载【配置文件】[TOC] 目录 https://www.tnblog.net/hb/article/details/5591 内容 在不同的环境需...

.net core 3.1 服务承载目录

.net core 3.1 服务承载【目录】[TOC] 目录如下: 承载长时间运行服务依赖注入配置选项配置文件BackgroundServiceW...

.net core 3.1 服务承载BackgroundService

.net core 3.1 服务承载【BackgroundService】[TOC] 目录 https://www.tnblog.net/hb/article/details/5591 内容 在.ne...

.net core 3.1 服务承载Workservice

.net core 3.1 服务承载【Workservice】[TOC] NET CORE 3.0新增了Worker Services的新项目模板,可以编写长时间运行的后...

我们为何要接吻阅读听力

英语不能丢,音频后面传People kiss for the simple reason that it feels good. Our lips are full of sensitive nerve en...

蛋是如何成色的阅读听力

困得不行How Eggs Get Their ColorEgg DyeDepending on the species, bird eggs can be any color ranging from chicken’s...

大脑为何有那么多沟壑阅读听力

Why The Brain Has So Many Folds&quot;Dear A Moment of Science, I know the human brain is an incredible thing, the m...

记忆与糖的关系阅读听力

Link Between Memory and SugarSugar On The BrainIt’s long been understood that there is a connection between memory...

海盐的形成阅读听力

早早Salty SeasDear A Moment of Science,I know why the ocean is still salty: evaporated water leaves the salt behind...

婚姻与心脏健康的关系阅读听力

Marriage and Heart HealthPlenty of studies have found that being married is generally good for health. One study ze...

喝茶可以预防癌症阅读听力

Drink Tea To Ward Off Cancer?&quot;Dear A Moment Of Science, Can you settle a debate between my friend and me? Sh...

表达式树Expression+反射-实现动态排序

首先 要实现一个传2个参数的方法,进行动态排序在写一个方法接收传过来的数据进行处理返回我们先是拿到sort类型—&gt;想要...

identityServer4 实现单点登录

今天记录一下 NET Core id4的单点登录虽然现在很流行 也很高大上但是第一次玩 还是很多的坑的。简单来讲就是一个项目登录了...
这一世以无限游戏为使命!
排名
6
文章
6
粉丝
16
评论
8
docker中Sware集群与service
尘叶心繁 : 想学呀!我教你呀
一个bug让程序员走上法庭 索赔金额达400亿日元
叼着奶瓶逛酒吧 : 所以说做程序员也要懂点法律知识
.net core 塑形资源
剑轩 : 收藏收藏
映射AutoMapper
剑轩 : 好是好,这个对效率影响大不大哇,效率高不高
ASP.NET Core 服务注册生命周期
剑轩 : http://www.tnblog.net/aojiancc2/article/details/167
ICP备案 :渝ICP备18016597号-1
网站信息:2018-2025TNBLOG.NET
技术交流:群号656732739
联系我们:contact@tnblog.net
公网安备:50010702506256
欢迎加群交流技术