数据库|分布式、微服务必须配个日志管理系统才优秀,Exceptionless走起
前言 在真实的项目中,不管是功能日志、错误日志还是异常日志,已经是项目的重要组成部分。在原始的单体架构,通常看日志的方式简单粗暴,直接登录到服务器,把日志文件拷贝下来进行分析;而如今分布式、微服务架构盛行,如果每个节点服务器都去拷贝一次,估计还没等你拷贝完,Boss就要炸锅了;特别是遇到线上问题,肯定需要快速响应,所以好的日志管理工具真的不能少,这里就来说说Excetpionless日志框架。
正文
1. Exceptionless简介 Exceptionless是开源的,可以为 ASP.NET、Web API、WebForms、WPF、控制台项目收集对应的异常、事件和日志信息,并将收集到的信息进行分组归类,有利于问题排查及相关数据统计。使用简单也便捷,主要功能如下:
- 针对关注信息可进行通知提醒;
- 收集信息根据种类进行分组管理;
- 记录详细的错误或异常信息,排查错误更轻松;
- 可以管理用户查看信息;
- 图表形式显示数据更加直观;
- 相关配置轻松设置;
- 收集日志、错误信息等很方便;
文章图片
Exceptionless有两种方式可以进行日志管理:
- 托管方式这种方式只需要在Exceptionless官网(https://exceptionless.com/)注册一个账号即可,存储那些都不用管,比较省心,简单三步走就能完成日志收集,如下:这种方式是把采集到的信息存储到官方的服务器上了,感觉不太好,一是日志信息其实对于一些项目来说很重要,二是要收费啊,免费版其实就是试用版,高级功能用不了,还要限制人数和项目数。
- 自己搭建环境自己搭建环境,服务器都是自己,私有化,爽歪歪;但这种方式,不好的点就是需要花钱买服务器;
2. 托管方式实现 2.1 注册账号并创建组织和项目 直接进入官网(
https://exceptionless.com/)注册一个账号即可,注册账号绝对免费滴;
文章图片
创建组织和项目,如下:
先创建组织
文章图片
再创建项目
文章图片
2.2 引入NuGet包并在Startup.cs注入和使用 这里创建了一个WebAPI项目,引入Exceptionless.AspNetCore 即可;
文章图片
在Startup.cs文件中进行注入相关服务并注册到管道中,如下:
文章图片
2.3 记录日志看效果 这里在API中进行日志记录和异常信息上报,如下:
文章图片
看效果,登录进官网(
https://exceptionless.com/),就会看到对应的异常信息了,如下:
文章图片
3. 自己搭建环境 2.1 安装环境 Exceptionless提供Docker安装版,这里先以Dockerfile形式演示,Docker Compose就一样的道理,只是分开容器部署更方便了。现在先直接下载(
https://github.com/exceptionless/Exceptionless/releases),推荐7.1.0版本,7.1.1的折腾了我好久,要么脚本执行不成功,要么缺少文件;然后拷贝到对应的Docker主机上解压,如下:
# 如果unzip命令找不到,就需要安装
yum install -y unzip zip
# 然后解压
unzip Exceptionless-7.1.0.zip
解压后的信息如下
文章图片
Dockerfile 把对应的Exceptionless UI、Elasticsearch等都安装在内部了,由于我的云服务内存比较小(内存大的可以不改),Dockerfile文件中默认指定了Elasticsearch最小使用内存为1G,如果内存不够,就会报错空间不足,所以稍微改动一下Dockerfile,如下:
文章图片
改好之后就直接构建为镜像,执行如下命令:
docker build -t test333 .
构建成功之后,直接通过镜像启动容器即可,如下命令
docker run -it --name tt3 -p 5000:80 -p 9200:9200 test333
可能由于服务器配置比较低的原因,启动稍微需要点时间。
注:如果对docker还不太熟的,参考docker系列文章;
Excpetionless API和Exceptionless UI 站点部署为一个站点了,如果能如下访问页面并能注册成功,环境就搭建完成。
文章图片
2.2 实操演练 登录Exceptionless UI系统(http://IP:5000/)进去之后就创建组织和项目,和托管的步骤差不多:
文章图片
下一步就是针对选择自己的项目类型,集成就行了(这步托管的也有,只是没截图),如下:
文章图片
稍微改改Startup.cs文件,其他不用动,如下:
文章图片
好了,这样就改完了,其他代码不动,运行访问一下API ,看日志效果:
文章图片
2.3 Exceptionless 还提供接口调用 不管是托管还是自己搭建环境,都有提供对应的API进行调用,所以可以通过API的形式自己搞一个个性化的UI出来,也可以在其他系统中集成显示日志,反正接口在手,爱咋玩就咋玩;实在不行就改源代码,嘿嘿嘿~~~。
文章图片
Exceptionless的使用还是很简单的,只是搭建的时候的花点心思。
总结 【数据库|分布式、微服务必须配个日志管理系统才优秀,Exceptionless走起】关于上面只是演示Exceptionless的使用,包含托管和自己搭建环境,基本上小伙伴都会选择自己搭建;搭建过程需要花点心思,比如ES要不要集群,要不要支持APM,邮件通知配置等等,不过现在可以通过Docker-compose一键安装,最多就是需要等待一会。还有如果想搞点个性化的,也可以在Exceptionless的源代码上做操作;后续细节再单独汇总吧;
推荐阅读
- Docker应用:容器间通信与Mariadb数据库主从复制
- 一个人的碎碎念
- 野营记-第五章|野营记-第五章 讨伐梦魇兽
- Shell-Bash变量与运算符
- 清明,是追思、是传承、是感恩。
- 牛人进化+|牛人进化+ 按自己的意愿过一生
- 七老修复好敏感、角质层薄、红血丝
- 华为旁!大社区、地铁新盘,佳兆业城市广场五期!
- 标签、语法规范、内联框架、超链接、CSS的编写位置、CSS语法、开发工具、块和内联、常用选择器、后代元素选择器、伪类、伪元素。
- 螃蟹和这些食物同吃,轻则腹泻、重则中毒!要小心哦~