ASP.NET Core微服务之基于App.Metrics+InfluxDB+Grafana实现统一性能监控
Tip: 此篇已加入.NET Core微服务基础系列文章索引
一、关于App.Metrics+InfluxDB+Grafana
1.1 App.Metrics
App.Metrics是一款开源的支持.NET Core的_监控_插件,它还可以支持跑在.NET Framework上的应用程序(版本 >= 4.5.2)。官方文档地址:https://www.app-metrics.io/
1.2 InfluxDB
InfluxDB是一款开源的分布式_时序、时间和指标_数据库,使用go语言编写,无需外部依赖。官网地址:https://portal.influxdata.com
1.3 Grafana
Grafana是一个可视化面板(_Dashboard_),有着非常漂亮的图表和布局展示,功能齐全的度量仪表盘和图形编辑器,支持Graphite、zabbix、InfluxDB、Prometheus和OpenTSDB作为数据源。官网地址:https://grafana.com/
二、InfluxDB的安装与配置
2.1 Linux下的安装
请参考focus-lei的文章《.NET Core使用App.Metrics + InfluxDB + Grafana进行APM监控》,我这里只是做demo,所以选择了在我的Windows Server虚拟机中安装,快速一点。当然,你可以通过docker拉取influxdb的镜像创建一个容器,这样更快。
docker pull tutm/influxdb
2.2 Windows下的安装
(1)下载Windows版本(64位),下载地址:https://dl.influxdata.com/influxdb/releases/influxdb-1.5.2_windows_amd64.zip
(2)解压之后放到你想要放置的位置,然后编辑influxdb.conf配置文件:(因为其默认配置是针对Linux的)
[meta]
Where the metadata/raft database is stored
dir = "C:/APM/influxdb/meta"
[data]
The directory where the TSM storage engine stores TSM files.
dir = "C:/APM/influxdb/data"
The directory where the TSM storage engine stores WAL files.
wal-dir = "C:/APM/influxdb/wal"
(3)进入cmd,以命令模式运行influxd:
cmd >> .influxd -config influxdb.conf
(4)然后新开一个cmd,连上influxdb,然后创建一个database
cmd >> .influx -host 127.0.0.1 -port 8086 -username "admin" -password "edisonchou"
关于influxdb的更多命令,可以浏览参考资料关于influxdb的InfluxDB入门教程。
三、Grafana的安装与配置
2.1 Linux下的安装
同1.1部分,不再赘述。
2.2 Windows下的安装
(1)下载Windows版本(64位),下载地址:https://s3-us-west-2.amazonaws.com/grafana-releases/release/grafana-5.2.2.windows-amd64.zip
(2)直接运行grafana-server.exe即可,默认绑定3000端口号。
(3)浏览器打开serverip:3000,使用默认账号admin/admin(账号密码都是admin)登录,主界面如下图所示:
(4)为InfluxDB添加数据源
在Configuration中点击Add data source按钮,进入如下图所示的添加界面,输入你安装的InfluxDB数据库信息
(5)为Grafana添加InfluxDB的Dashboard仪表盘的JSON文件
这里有两种方式:一种是直接给URL=>https://grafana.com/dashboards/2125,另一种是我们手动下载这个URL的JSON,然后把JSON粘贴过来。
(6)导入之后,查看这个Dashboard:
四、App.Metrics的使用与API网关集成
注意:__以下的配置和代码都只是在API网关(Ocelot)中做的,至于具体API服务中不需要做配置。
4.1 安装App.Metrics
通过NuGet安装以下几个package:
4.2 集成API网关
(1)添加配置文件关于InfluxDB的部分
"AppMetrics": { "IsOpen": true, "DatabaseName": "AppMetricsDB", "ConnectionString": "http://192.168.80.71:8086", "UserName": "admin", "Password": "edisonchou", "App": "MSAD", "Env": "Development" }
(2)修改StartUp类,注入AppMetrics并设置
public void ConfigureServices(IServiceCollection services) { ...... // AppMetrics bool isOpenMetrics = Convert.ToBoolean(Configuration["AppMetrics:IsOpen"]); if (isOpenMetrics) { string database = Configuration["AppMetrics:DatabaseName"]; string connStr = Configuration["AppMetrics:ConnectionString"]; string app = Configuration["AppMetrics:App"]; string env = Configuration["AppMetrics:Env"]; string username = Configuration["AppMetrics:UserName"]; string password = Configuration["AppMetrics:Password"]; var uri = new Uri(connStr); var metrics = AppMetrics.CreateDefaultBuilder().Configuration.Configure(options => { options.AddAppTag(app); options.AddEnvTag(env); }).Report.ToInfluxDb(options => { options.InfluxDb.BaseUri = uri; options.InfluxDb.Database = database; options.InfluxDb.UserName = username; options.InfluxDb.Password = password; options.HttpPolicy.BackoffPeriod = TimeSpan.FromSeconds(30); options.HttpPolicy.FailuresBeforeBackoff = 5; options.HttpPolicy.Timeout = TimeSpan.FromSeconds(10); options.FlushInterval = TimeSpan.FromSeconds(5); }).Build(); services.AddMetrics(metrics); services.AddMetricsReportScheduler(); services.AddMetricsTrackingMiddleware(); services.AddMetricsEndpoints(); } } // This method gets called by the runtime. Use this method to configure the HTTP request pipeline. public void Configure(IApplicationBuilder app, IHostingEnvironment env) { ...... // AppMetrics bool isOpenMetrics = Convert.ToBoolean(Configuration["AppMetrics:IsOpen"]); if (isOpenMetrics) { app.UseMetricsAllEndpoints(); app.UseMetricsAllMiddleware(); } // Ocelot app.UseOcelot().Wait(); }
五、运行效果展示
这时我们把API网关、ClientService和ProductService同时启动起来,然后通过浏览器不停的请求这两个服务的某个API接口。
请求一段时间后,我们进入Grafana的Dashboard来查看:
可以看到,原本空荡荡的仪表盘已经满血复活,各种曲线和数据出来了。这里Error有数据是因为我的程序中有bug,出现了异常。
我们也也可以设置Grafana的Alerting设置,让其可以为我们发送告警邮件(可以选择Include Image),当然你事先得改一下Grafana的配置文件,贴上你的SMTP服务器和账号密码信息。
六、小结
本篇首先简单介绍了一下App.Metrics、InfluxDB与Grafana,然后介绍了如何安装和配置这套开源监控组合,最后通过与API网关Ocelot的集成,让我们的ASP.NET Core程序可以跑在监控平台之下,并可以通过Grafana的Dashboard实时查看性能数据。当然,本篇只是一个简单的Quick Start,很多细节没有深究,有兴趣的园友可以通过参考资料去仔细研究。
参考资料
(1)顾镇印,《ASP.NET Core之跨平台的实时监控》
(2)老衲平僧,《InfluxDB+Grafana+AppMetrics监控系统》
(3)landon,《.NET Core 2.0+InfluxDB+Grafana+AppMetrics实现跨平台的实时性能监控》
(4)focus-lei,《.net core使用App.Metrics+InfluxDB+Grafana进行APM监控》
(5)桂素伟,《Ocelot监控》
(6)仰望星空脚踏实地,《InfluxDB入门教程》
(7)JackyRoc,《InfluxDB使用说明》
(8)InfluxDB官方文档:http://docs.influxdata.com/influxdb/v1.6/
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
ASP.NET Core微服务之基于Exceptionless实现分布式日志记录
Tip: 此篇已加入.NET Core微服务基础系列文章索引 一、Exceptionless极简介绍 Exceptionless 是一个开源的实时的日志收集框架,它可以应用在基于 ASP.NET,ASP.NET Core,Web API,Web Forms,WPF,Console,ASP.NET MVC 等技术开发的应用程序中,并且提供了REST接口可以应用在 Javascript,Node.js 中。它将日志收集变得简单易用并且不需要了解太多的相关技术细节及配置,对于微服务架构的应用程序来说,统一的日志收集系统的建立更是有必要。 二、Quick Start 2.1 官方创建一个账号 2.2 创建项目 2.3 得到ApiKey 2.4 安装Exceptionless.AspNetCore并进行配置 NuGet>Install-Package Exceptionless.AspNetCore *.目前最新版本是4.3.2004 在你要进行Logging的项目(MVC,WebAPI等)中注册APIKey,这里以ASP.NET Core WebAPI项目为例: public void ...
- 下一篇
ASP.NET Core微服务之基于Apollo实现统一配置中心
Tip: 此篇已加入.NET Core微服务基础系列文章索引 一、关于统一配置中心与Apollo 在微服务架构环境中,项目中配置文件比较繁杂,而且不同环境的不同配置修改相对频繁,每次发布都需要对应修改配置,如果配置出现错误,需要重新打包发布,时间成本较高,因此需要做统一的配置中心,能做到自动更新配置文件信息,解决以上问题。 Apollo(阿波罗)是携程框架部门研发的配置管理平台,能够集中化管理应用不同环境、不同集群的配置,配置修改后能够实时推送到应用端,并且具备规范的权限、流程治理等特性。其服务端基于Spring Boot和Spring Cloud开发,打包后可以直接运行,不需要额外安装Tomcat等应用容器。 Apollo目前在国内开发者社区比较热,在Github上有超过5k颗星,在国内众多互联网公司有落地案例,可以说Apollo是目前配置中心产品领域No.1的产品,其成熟度和企业级特性要远远强于Spring Cloud体系中的Spring Cloud Config产品。 目前有针对Java和.Net的两个客户端供使用: Java客户端不依赖任何框架,能够运行于所有Java运行时环境...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Hadoop3单机部署,实现最简伪集群
- CentOS8编译安装MySQL8.0.19
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- Eclipse初始化配置,告别卡顿、闪退、编译时间过长
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Mario游戏-低调大师作品
- CentOS6,CentOS7官方镜像安装Oracle11G