ASP.NET Core之跨平台的实时性能监控
最后卖了个小关子,是关于如何监控ASP.NET Core的.
今天我们就来讲讲如何监控它,下面上效果图:
阅读本文需要了解的相关技术与内容:
InfluxDb(分布式时序数据库,开源)(注:分布式部分已商业化最新的分布式版本已不在开源,单例的继续开源)
Grafana(开源的,功能齐全的度量仪表盘和图形编辑器)
App Metrics(主角,开源的支持.NET Core的监控插件,采用管道注入的方式,对代码的***性极小)
本文测试环境为Windows64位,当然 这个方案全部都可以在linux上实现(甚至windows才应该是备用方案 - -,尴尬.)
所以本文分为3个步骤1.安装InfluxDb,并创建数据库2.安装Grafana,并添加相关配置3.在ASP.NET Core中使用App Metrics下面我们正式开始
正文
1.安装InfluxDb,并创建数据库App.Metrics支持的库很多,有InfluxDB、Graphite、Prometheus.
今天我们主要已InfluxDb为例子.
首先下载,InfluxDb
知道你们懒得找..地址如下:https://portal.influxdata.com/downloads#influxdb
下载你需要的对应的系统的版本.这里我就直接下载Windows Binaries (64-bit)
linux的安装步骤我就不多说了,网上一大把..讲一下windows安装InfluxDb的注意事项(..这玩意对liunx的支持比windows好的多)..
解压后打开influxdb.conf,因为influxdb的默认配置全是针对linux配置的..所以我们要修改一下配置文件.
修改下面3个liunx的路径,改为winodws路径如下:
[meta]#Wherethemetadata/raftdatabaseisstoreddir="D:/influxdb/meta"
[data]#ThedirectorywheretheTSMstorageenginestoresTSMfiles.dir="D:/influxdb/data"
#ThedirectorywheretheTSMstorageenginestoresWALfiles.wal-dir="D:/influxdb/wal"
然后修改网页图形化管理界面配置,端口如下:
[admin]#Determineswhethertheadminserviceisenabled.enabled=true#Thedefaultbindaddressusedbytheadminservice.bind-address=":8083"
最后cmd运行,进入到你的解压目录,执行命令:
influxd-configinfluxdb.conf
得到如图效果:
我们就安装完成了.
我们进入管理界面的监听端口:http://localhost:8083/,会看到如下界面:
然后我们输入SQL语句 CREATE DATABASE "你的库名"
看到下图,就是执行成功了.
我们查一下看是不是真的,输入SQL语句:SHOW DATABASES
如图:
除了默认的第一个库以外,还有你自己添加的库名,就说明是加成功了,好了,安装就到此结束
2.安装Grafana,并添加相关配置然后我们安装Grafana,
下载地址:https://grafana.com/get
我们解压后进入bin目录,如图:
直接运行grafana-server.exe即可.
Grafana默认会监听3000的端口,所以我们进入http://localhost:3000,
会让你登陆,直接输入本地的管理员帐户即可,帐户:admin 密码:admin,进入后如图:
安装完成之后,我们下载相关的仪表模版.
地址如下:ht t p s: / / g r a f a n a . c om / d a s h b oa r d s / 2 140 (是个json文件)
然后我们导入我们的仪表:如图操作即可:
然后,添加我们上面的数据源.
如图:
选择Add DataSource,然后操作如下:
这样,我们就完成了Grafana的安装配置和添加数据源
3.在ASP.NET Core中使用App Metrics接下来就是我们的重头戏了,在ASP.NET Core中使用AppMetrics.
我们随便创建一个ASP.NET Core MVC项目,如图:
用nuget包添加引用:
核心程序:
管道注入的扩展:
ASP.NET Core MVC的扩展:
其他相关要用到的库:(注:我们这里的数据源是influxDB所以用的这个库,其他的库请搜索其他库的后缀)
我们回到我们熟悉的C#代码,在Startup中我们编写注入代码如下:
首先修改ConfigureServices方法,如下:
publicvoidConfigureServices(IServiceCollectionservices){vardatabase="TestData";varuri=newUri("http://127.0.0.1:8086");services.AddMetrics(options=>{options.GlobalTags.Add("app","sampleapp");options.GlobalTags.Add("env","stage");}).AddHealthChecks().AddJsonSerialization().AddReporting(factory=>{factory.AddInfluxDb(newInfluxDBReporterSettings{InfluxDbSettings=newInfluxDBSettings(database,uri),ReportInterval=TimeSpan.FromSeconds(5)});}).AddMetricsMiddleware(options=>options.IgnoredHttpStatusCodes=new[]{404});//Addframeworkservices.services.AddMvc();}
加入我们influxDB相关配置,其中database就是你自己输入的数据库名.uri就是你数据库的地址.
然后我们需要在程序启动的时候就注入我们的Metrics监控,所以修改Configure代码如下:
publicvoidConfigure(IApplicationBuilderapp,IHostingEnvironmentenv,ILoggerFactoryloggerFactory,IApplicationLifetimelifetime){loggerFactory.AddConsole(Configuration.GetSection("Logging"));app.UseMetrics();app.UseMetricsReporting(lifetime);//loggerFactory.AddDebug();if(env.IsDevelopment()){app.UseDeveloperExceptionPage();app.UseBrowserLink();}else{app.UseExceptionHandler("/Home/Error");}app.UseStaticFiles();app.UseMvc(routes=>{routes.MapRoute(name:"default",template:"{controller=Home}/{action=Index}/{id?}");});}
其中app.UseMetrics(); app.UseMetricsReporting(lifetime) ,是我们的注入代码..
其他的地方.不用动一丝一毫..怎么样 是不是几乎没有什么***性~.
最后,我们跑起来.
随便在home中点击几下页面,或者调用一下..
然后进入到Grafana的监控页面中,就可以看到如下信息:
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。