一、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 Configure(IApplicationBuilder app, IHostingEnvironment env, IApplicationLifetime lifetime){......app.UseMvc();        // exceptionlessapp.UseExceptionless(Configuration["Exceptionless:ApiKey"]);        // swagger        ......}

  这里我将ApiKey配置到了json配置文件中:

  "Exceptionless": {    "ApiKey": "Your Api Key from Exceptionless server"}

2.5 简单地封装一个ExceptionlessLogger

  (1)自定义一个ILogger接口

    public interface ILogger{                     void Trace(string message, params string[] args);               void Debug(string message, params string[] args);                void Info(string message, params string[] args);                void Warn(string message, params string[] args);             void Error(string message, params string[] args);}

  (2)实现ILogger接口:ExceptionlessLogger

    public class ExceptionLessLogger : ILogger{             /// <summary>/// Trace                /// </summary>public void Trace(string message, params string[] tags){ExceptionlessClient.Default.CreateLog(message, LogLevel.Trace).AddTags(tags).Submit();}        /// <summary>/// Debug        /// </summary>public void Debug(string message, params string[] tags){ExceptionlessClient.Default.CreateLog(message, LogLevel.Debug).AddTags(tags).Submit();}        /// <summary>/// Info        /// </summary>public void Info(string message, params string[] tags){ExceptionlessClient.Default.CreateLog(message, LogLevel.Info).AddTags(tags).Submit();}        /// <summary>/// Warn        /// </summary>public void Warn(string message, params string[] tags){ExceptionlessClient.Default.CreateLog(message, LogLevel.Warn).AddTags(tags).Submit();}        /// <summary>/// Error        /// </summary>public void Error(string message, params string[] tags){ExceptionlessClient.Default.CreateLog(message, LogLevel.Error).AddTags(tags).Submit();}}

2.6 注入ExceptionlessLogger

    public IServiceProvider ConfigureServices(IServiceCollection services){        // IoC - Loggerservices.AddSingleton<ILogger, ExceptionLessLogger>();......}

2.7 在你想要Logging的地方调用

  比如我们要记录一个User登录的日志:

    public class LoginController : Controller{         public ILogger Logger { get; }    

         public LoginController(ILogger logger){Logger = logger;}[HttpGet("{id}")]                  public string Get(int id){Logger.Info($"User {id} Login Successfully. Time:{DateTime.Now.ToString()}", "Tag1", "Tag2");            return "Login Success.";}}

  测试结果:

  

2.8 记录你程序中的各种Exception

  这里模拟一个空指针的异常,这里借助Exceptionless针对Exception类的扩展方法去进行写异常信息。

    [HttpGet]       public string Get(){                 try{         string str = null;str.ToString();}                 catch (Exception ex){ex.ToExceptionless().Submit();}        return "Unknown Error!";}

  测试结果:

  

2.9 Check你的日志与异常记录

  (1)Check 日志

  在Log Messages 或 AllEvents菜单中选择Dashboard,即可看到当前项目所有的Log Message了。(如果选择的是AllEvents,可能还会包含其他类型的信息,比如Exception)

  

  在最近的Log中可以看到我们刚刚的测试中记录的一跳日志:

  

  点击超链接,即可进入详细页面:

  Overview:可以看到一些项目和日志的基本信息,比如Event Type,Level以及标签Tags

  

  Environment:可以看到记录日志所在的项目所处的一些软硬件环境信息

  

  下面是一些额外的信息,比如Framework Version以及Runtime Framework

  

  通过对这些日志的查看和分析,我们可以方便地在一个地方对所有服务中的日志进行查看和分析。But,在线版本对项目和日志数量有限制,建议在生产环境使用本地部署版本,它是开源的。

  (2)Check 异常

  在Exception菜单下选择Dashboard:

  

  在最近的异常信息中找到刚刚记录的:

  

  同样,通过超链接查看详细信息:

  Overview:可以看到这个异常的基本信息,比如Error Type以及Stack Trace,这些都是可以帮准我们快速定位错误的信息

  

  Exception:如果基本信息不够,那就查看详情,你可能需要看看加载了哪些Modules

  

  最后是Environment,跟Log的Environment差不多,这里就不再贴图了。

三、本地部署

  我们说到Exceptionless是一款强大的开源框架,那么我们可以下载下来根据需要进行独立部署,可以不受一些用户、项目、Event数量的限制。这里我暂时不会去做其独立部署的实践,但是园子里已经有很多的独立部署实践的分享了,有兴趣的朋友可以看看下面几篇:

  花儿笑弯了腰,《Self Host 使用Exceptionless实时监控程序运行日志服务》

  罗曼缇克,《.Net 开源异常日志ExceptionLess搭建》

  平凡网客,《Exceptionless 本地部署》

  当然,官方的独立部署Wiki也是一个绝佳的参考资料:https://github.com/exceptionless/Exceptionless/wiki/Self-Hosting

  以下是测试环境的要求:

  

  以下是Production环境的要求,我们可以看到在Production环境中,强烈推荐使用ELK的ElasticSearch,如果有不知道ELK的朋友也可以百度/Google一下,ELK也是我后续的学习计划。

  

四、小结

  本篇主要简单的介绍了一下开源的分布式日志框架Exceptionless,并通过两个小例子介绍了如何快速的在ASP.NET Core中进行使用,最后通过在Exceptionless平台中Check我们在程序中记录的日志/异常信息了解Exceptionless的强大。此外,通过引入园友和官方的Wiki文档介绍了Exceptionless的另一种使用模式:本地部署,有兴趣的朋友可以去看看,这里我就不再去实践了(对我现阶段而言,去做独立部署的优先级不高)。本篇没有过多的语言介绍,更多的是贴code以及贴图片,因此不能算是很好的介绍文章,不过结合列出的参考资料应该可以对Exceptionless做个快速入门  

  一些朋友问我后续的分享计划,这里小小透漏一下:Ocelot+IdentityServer的结合做统一验证和授权,Ocelot+Butterfly的结合(目前Ocelot已集成Butterfly)做分布式追踪,基于AppMetrics+InfluxDB+Grafana的性能监控,数据一致性(可能会使用几个EventBus框架)初探,基于Apollo做配置中心,ASP.NET Core on Docker与K8S结合等等。等到POC初步研究后,可能还会去看看微软的微服务架构官方高级版大Demo-eShopOnContainers(微软有一本pdf大家可以去下载,点我下载)。这些计划可能需要花费我很多时间,不过我相信这样的学习和实践是值得的,也是值得分享的,如果你也有这样的计划,那就一起加油吧!

    

参考资料

Exceptionless Github:https://github.com/exceptionless/Exceptionless

savorboard(杨晓东),《免费开源分布式系统日志收集框架 Exceptionless》

编程梦,《ExceptionLess新玩法 — 记日志》

编程梦,《ExceptionLess新玩法 -- 审计日志》

花儿笑弯了腰,《Self Host 使用Exceptionless实时监控程序运行日志服务》

罗曼缇克,《.Net 开源异常日志ExceptionLess搭建》

平凡网客,《Exceptionless 本地部署》

原文地址:

https://www.cnblogs.com/edisonchou/p/exceptionless_foundation_and_quick_start.html

.NET社区新闻,深度好文,欢迎访问公众号文章汇总 http://www.csharpkit.com

.NET Core微服务之基于Exceptionless实现分布式日志记录相关推荐

  1. .NET Core微服务之基于Ocelot实现API网关服务(续)

    Tip: 此篇已加入.NET Core微服务基础系列文章索引 一.负载均衡与请求缓存 1.1 负载均衡 为了验证负载均衡,这里我们配置了两个Consul Client节点,其中ClientServic ...

  2. .NET Core微服务之基于IdentityServer建立授权与验证服务(续)

    上一篇<.NET Core微服务之基于IdentityServer建立授权与验证服务>我们基于IdentityServer4建立了一个AuthorizationServer,并且继承了Qu ...

  3. .NET Core微服务之基于Ocelot实现API网关服务

    一.啥是API网关? API 网关一般放到微服务的最前端,并且要让API 网关变成由应用所发起的每个请求的入口.这样就可以明显的简化客户端实现和微服务应用程序之间的沟通方式.以前的话,客户端不得不去请 ...

  4. .NET Core微服务之基于Consul实现服务治理

    一.Consul基础介绍 Consul是HashiCorp公司推出的开源工具,用于实现分布式系统的服务发现与配置.与其他分布式服务注册与发现的方案,比如 Airbnb的SmartStack等相比,Co ...

  5. .NET Core微服务之基于MassTransit实现数据最终一致性(Part 1)

    Tip: 此篇已加入.NET Core微服务基础系列文章索引 一.预备知识:数据一致性 关于数据一致性的文章,园子里已经有很多了,如果你还不了解,那么可以通过以下的几篇文章去快速地了解了解,有个感性认 ...

  6. .NET Core微服务之基于Ocelot+IdentityServer实现统一验证与授权

    Tip: 此篇已加入.NET Core微服务基础系列文章索引 一.案例结构总览 这里,假设我们有两个客户端(一个Web网站,一个移动App),他们要使用系统,需要通过API网关(这里API网关始终作为 ...

  7. .NET Core微服务之基于Consul实现服务治理(续)

    Tip: 此篇已加入.NET Core微服务基础系列文章索引 上一篇发布之后,很多人点赞和评论,不胜惶恐,这一篇把上一篇没有弄到的东西补一下,也算是给各位前来询问的朋友的一些回复吧. 一.Consul ...

  8. .NET Core微服务之基于EasyNetQ使用RabbitMQ消息队列

    Tip: 此篇已加入.NET Core微服务基础系列文章索引 一.消息队列与RabbitMQ 1.1 消息队列 "消息"是在两台计算机间传送的数据单位.消息可以非常简单,例如只包含 ...

  9. .NET Core微服务之基于IdentityServer建立授权与验证服务

    一.IdentityServer的预备知识 要学习IdentityServer,事先得了解一下基于Token的验证体系,这是一个庞大的主题,涉及到Token,OAuth&OpenID,JWT, ...

最新文章

  1. 1418 This function has none of DETERMINISTIC,NO SQL,or R
  2. 在 iOS 应用中实现飞行模式提醒
  3. shell+飞信实现网站监控
  4. android 复制文件到指定文件夹_按指定名称批量新建文件夹,其实并不难
  5. .Net——使用DataContractJsonSerializer进行序列化及反序列化基本操作
  6. Internet信息服务找不到
  7. c语言最长公共子序列_序列比对(二十四)——最长公共子序列
  8. python groupby 不保留源index、_Python数据分析 I 全国旅游景点分析案例,哪里好玩一目了然...
  9. Linux 查看 硬件配置
  10. [独家]MIT课程笔记:数据可视化会撒谎
  11. pyqt创建窗口没有句柄_Python GUI之tkinter窗口视窗教程大集合(看这篇就够了)
  12. android图案解锁忘了怎么解,安卓手机解锁图案忘了怎么办?手机解锁密码忘了怎么办?...
  13. Flutter 淡入淡出与逐渐出现动画
  14. spring JDBCTemplate实现批量插入及返回id
  15. 存储器读写c语言程序,单片机IIC接口存储器AT24C04的读写和显示程序(详细注释)...
  16. 杨绛与钱钟书,人世间最理想的婚姻
  17. 雨崩徒步游记--三月的梅里雪山
  18. 计算机毕业设计nodejsLIN广告设计网站系统
  19. 个人计算机的基本配置显卡,计算机最基本配置之一显卡bios是怎样设置的?
  20. 跨考计算机之路,2014考研心得:零基础跨考之路

热门文章

  1. 神经网络- receptive field
  2. RabbitMQ详解(三)
  3. Oracle 之 管理
  4. 进入51cto之后的发展方向
  5. centos 6.0安装杀毒软件clamAV 0.98
  6. 【个人笔记】关于IO类中流的整理
  7. 开源 免费 java CMS - FreeCMS1.3-数据对象-mail
  8. 诺基亚首款Windows Phone智能手机将在年内推出
  9. 值得永久收藏的 C# 设计模式套路(一)
  10. 解决 WPF 绑定集合后数据变动界面却不更新的问题(使用 ObservableCollection)