最近使用Abp开发了一个项目,对abp有一个大概的了解,第一个小项目接近尾声,新的项目马上开始,针对开发第一个项目中发现的问题及不方便的地方,本人做一些修改,特此记录,请大家多多指正!

本人的开发环境vs2017 ,vs code,使用abp版本为abp3.5 + angular开发,安装过程就免了,另外本人使用的aspnetzero。请大家自觉支持正版,技术支持很给力。
首先,完善下Abp的日志,apb 的日志系统使用Castle Windsor的日志记录工具,它可以和不同的logginh(日志)类库协作:Log4Net、NLog、Serilog等。Castle为所有Logger库提供一个公共接口,所以它独立于logging库,也可以在有需要的时候很容易地替换logging。

ABP模板 默认采用采用Log4Net,进行了简单的配置,主要是文件日志,查看下log4net的配置方法,尝试了其他的配置,例如数据库等,有些可以成功,有些不行:

   <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender" >
<file type="log4net.Util.PatternString" value="App_Data/Logs/Log.txt"/>
<appendToFile value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="10" />
<maximumFileSize value="10000KB" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%-5level %date [%-5.5thread] %-40.40logger - %message%newline" />
</layout>
</appender>

abp默认不在控制台输出日志内容,因此有时候错误没办法找,必须打开日志文件(App_Data/Logs/Log.txt)查找最新的错误,这个有点低端,每次打开文本效率有点低,不符合我一贯能装的性格,有没有其他查看日志的方法:web signalr方式,我能想到的大神们估计都想到了,我这里配置了两个能装逼的:log2consoleexceptionless;完成这个瞬间牛逼了许多。

先说第一个问题,abp日志配置有个问题就是有的配置节点中的layout type不能采用其他格式,主要是xml格式的貌似不支持;

xml配置方式是log2console的默认配置方式

 <appender name="FileAppender" type="log4net.Appender.FileAppender">
<file value="log-file.txt" />
<appendToFile value="true" />
<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
<layout type="log4net.Layout.XmlLayoutSchemaLog4j" />
</appender>

这个配置在abp中是没效果的,是不是我漏掉什么了,大神们给个提示,非常感谢!

exceptionless也是这样,无敌了,叔可忍婶不可忍!

1、log2console

修改log2console源码,添加一个receiver,要做的很简单,复制原来的udp receiver,修改解析方法,首先做一个PatternLayout:

     <layout type="log4net.Layout.PatternLayout">
<conversionPattern value='{"date":"%date","thread":"%-5.5thread","level":"%-5level","logger":"%-40.40logger"} %message' />
</layout>

这个很简单,就是把消息包装成json字符串加上message。

在log2console,Log2Console.Receiver.ReceiverUtils类中添加解析函数:

         public static LogMessage ParsePatternLayoutLogEvent(string logEvent, string defaultLogger)
{
var logMsg = new LogMessage();
var sl = logEvent.Split('}');
if (sl.Length < )
logMsg.Message = logEvent;
else
{
var jo = Newtonsoft.Json.JsonConvert.DeserializeObject<msgObj>(sl[] + "}");
logMsg.TimeStamp = DateTime.Parse(jo.date.Trim().Replace(',','.'));
logMsg.Level = LogLevels.Instance[jo.level.Trim()];
logMsg.LoggerName = jo.logger.Trim();
logMsg.ThreadName = jo.thread.Trim();
logMsg.Message = sl[];
}
return logMsg; }

在receiver中添加新的解析类UdpPatternLayoutReceiver,简单复制udpReceiver,修改几行代码即可,start函数中,修改解析方法:

                    LogMessage logMsg = ReceiverUtils.ParsePatternLayoutLogEvent(loggingEvent, "UdpLogger");

另外修改SampleClientConfig,可以给用户提供个配置提示。

编译生成log2console。

最终生成的log2console界面。

最后一步,在abp项目中添加udp配置:

   <appender name="UdpAppender" type="log4net.Appender.UdpAppender">
<param name="Encoding" value="utf-8" />
<remoteAddress value="10.1.12.188" />
<remotePort value="7071" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value='{"date":"%date","thread":"%-5.5thread","level":"%-5level","logger":"%-40.40logger"} %message' />
</layout>
</appender> <root> ........
<appender-ref ref="UdpAppender" />
<level value="ALL" />
</root>

现在,解决了看日志的问题了。

 2、exceptionless配置

解决了看日志的问题保存日志的问题还是保存在文件里,查看历史不方便,exceptionless很好。

exceptionless的安装按照官方说明安装即可,我是在iis上安装的,安装过程中要注意两点,一是版本es版本要按照说明的版本安装,最新版本不支持。二是,es安装完成后,折腾了好长时间,我安装了head这个插件,进行配置没问题了,觉得安装过程中主要是配置了这个参数:

action.auto_creat_index:true  但没有测试不安装head插件仅配置这个参数是否可用。

es的head插件安装成功界面。

安装完成打开exceptionless,注册一个账号后,配置exceptionless,不允许新用户注册即可:

webconfig中添加或修改:<add key="EnableAccountCreation" value="true" />

exceptionless 安装成功。

配置abp中log 的exceptionless:

  <appender name="exceptionless" type="Exceptionless.Log4net.ExceptionlessAppender,Exceptionless.Log4net">
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%-4timestamp [%thread] %-5level %logger %ndc - %message%newline"/>
</layout>
</appender> <root>
//其他配置
<appender-ref ref="exceptionless" />
<level value="ALL" />
</root>

安装nuget exceptionless的包:exceptionless.aspnetcore

在app.config中配置:

 "Exceptionless": {
"ApiKey": "你的apkkey",
"ServerUrl": "http://你的地址",
"DefaultData": {
"JSON_OBJECT": "{ \"Name\": \"Blake\" }",
"Boolean": true,
"Number": 1,
"Array": "1,2,3"
},
"DefaultTags": [ "xplat" ],
"Settings": {
"FeatureXYZEnabled": false
}
},

最后在host项目的startup的Configure函数中添加:app.UseExceptionless(_appConfiguration);

后续主要有这些方面的完善,敬请期待:

大功告成,谢谢你的打赏!

打造适合你的ABP(1)---- 完善日志系统的更多相关文章

  1. ABP(现代ASP.NET样板开发框架)系列之19、ABP应用层——审计日志

    点这里进入ABP系列文章总目录 基于DDD的现代ASP.NET开发框架--ABP系列之19.ABP应用层——审计日志 ABP是“ASP.NET Boilerplate Project (ASP.NET ...

  2. ABP应用层——审计日志

    ABP应用层——审计日志 点这里进入ABP系列文章总目录 基于DDD的现代ASP.NET开发框架--ABP系列之19.ABP应用层——审计日志 ABP是“ASP.NET Boilerplate Pro ...

  3. 打造适合自己的vim编辑器方法总结

    vim使用方法总结 说明:这是打造适合自己的vim编辑器的进阶方法,关于vim基础知识,请自行百度.也可参考文章末尾推荐blog网址 如果觉得自己打造vim编辑器麻烦,可以从github上面克隆一个, ...

  4. 【转载】scribe、chukwa、kafka、flume日志系统对比

    原文地址:http://www.ttlsa.com/log-system/scribe-chukwa-kafka-flume-log-system-contrast/ 1. 背景介绍许多公司的平台每天 ...

  5. scribe、chukwa、kafka、flume日志系统对比 -摘自网络

    1. 背景介绍许多公司的平台每天会产生大量的日志(一般为流式数据,如,搜索引擎的pv,查询等),处理这些日志需要特定的日志系统,一般而言,这些系统需要具有以下特征:(1) 构建应用系统和分析系统的桥梁 ...

  6. 开源日志系统比较:scribe、chukwa、kafka、flume

    1. 背景介绍 许多公司的平台每天会产生大量的日志(一般为流式数据,如,搜索引擎的pv,查询等),处理这些日志需要特定的日志系统,一般而言,这些系统需要具有以下特征: (1) 构建应用系统和分析系统的 ...

  7. nxlog4go 简介 - 基于log4go的下一代go语言日志系统

    nxlog4go的项目网址: https://github.com/ccpaging/nxlog4go 项目历史 ccpaging's log4go forked from https://githu ...

  8. ELK统一日志系统的应用

    收集和分析日志是应用开发中至关重要的一环,互联网大规模.分布式的特性决定了日志的源头越来越分散, 产生的速度越来越快,传统的手段和工具显得日益力不从心.在规模化场景下,grep.awk 无法快速发挥作 ...

  9. .NET下日志系统的搭建——log4net+kafka+elk

    .NET下日志系统的搭建--log4net+kafka+elk 前言     我们公司的程序日志之前都是采用log4net记录文件日志的方式(有关log4net的简单使用可以看我另一篇博客),但是随着 ...

随机推荐

  1. less初学手记

    less语言学习手记 工具下载 在less学习中,我们都会需要随时编译我们的less文件,查看生成的css样式表是否正确,以及是否符合我们的要求.推荐一款编译软件供大家下载使用:koala,本软件支持 ...

  2. [CodeForces10D]LCIS(最长公共上升子序列) - DP

    Description 给定两个数列,求最长公共上升子序列,并输出其中一种方案. Input&Output Input 第一行一个整数n(0<n<=500),数列a的长度. 第二行 ...

  3. NetSNMP开源代码学习——mib扩展

    扩展MIB库关于MIB库的扩展网络文章非常多,这里我主要参考了http://blog.csdn.net/qq_27204267/article/details/51595708,这篇文章介绍的比较简单 ...

  4. 浅析开源数据库MySQL架构

    数据库是所有应用系统的核心,故保证数据库稳定.高效.安全地运行是所有企业日常工作的重中之重.数据库系统一旦出现问题无法提供服务,有可能导致整个系统都无法继续工作.所以,一个成功的数据库架构在高可用设计 ...

  5. php实现记住密码自动登录的功能

    $username=trim($_POST['username']); $password=md5(trim($_POST['password'])); $ref_url=$_GET['req_url ...

  6. js中闭包的讲解

    一.变量的作用域 要理解闭包,首先必须理解Javascript特殊的变量作用域. 变量的作用域无非就是两种:全局变量和局部变量. Javascript语言的特殊之处,就在于函数内部可以直接读取全局变量 ...

  7. 定点分析: MySQL InnoDB是如何保证系统异常断电情况下的数据可靠性?

    MySQL支持事务,所以保证数据可靠的前提是对数据的修改事务已经成功提交 这个问题可以解释为'MySQL InnoDB是如何保证事务C(一致性)D(持久性)性的?' 可能出现的两种情况: (一致性)数 ...

  8. java8接口定义增强

    java1.7之前,接口中只允许有全局常量和抽象方法,而1.8之后允许在接口中扩充default修饰的普通方法和static修饰的静态方法 其目的是在修改接口中方法的时候,子类就不必去一一修改 pac ...

  9. [HNOI2010]MATRIX 矩阵

    Description Input 第一行包含三个正整数N M P表示矩阵的行数列数以及每个数的范围,接下来N行每行包含M个非负整数,其中第i行第j个数表示以格子(i,j)为右下角的2*2子矩阵中的数 ...

  10. [POI2016]Nim z utrudnieniem

    Description A和B两个人玩游戏,一共有m颗石子,A把它们分成了n堆,每堆石子数分别为a[1],a[2],...,a[n],每轮可以选择一堆石子,取掉任意颗石子,但不能不取.谁先不能操作,谁 ...