ASP.Net MVC 之如何写Log

ASP.Net MVC 之如何写Log

    日志(Log)对于一个程序的重要性不言而喻。操作系统的代码bootloader之后,就必须要实现串口打印log,因为你根本没有办法debug,这是早期移植Windows CE 5.0到6.0的经验,直到现在还是受用。集成开发环境,特别是Visual studio提供了强大的debug环境,特别是C#,Java等高级语言很容易发现NullReferenceException之类的异常,但对于C++等程序来说,没有Log简直没法做。其实对于线上环境来说,log还是很重要,因为你不可能很方便地重现环境。特别是对于facebook之类的公司,甚至利用log进行用户行为分析,这算是使用log的上乘了,我们先利用好log做好基本工作吧。

1.Log写在哪儿

      1. 函数入口写上Log,并且要把参数也写上(我认为是必须 )

      2. 异常处写上Log(我认为是必须)

      3. 计算特别复杂,没有把握的地方写上(视自己的情况而定 )

      下面有代码例子:

            public ActionResult Index(int Id)

        {

            _logger.DebugFormat(


Comment load single comment by commentId :{0}

, Id);
            
            

try

            {

                var comment 

=
 _commentService.Get(Id);
                

return
 FormatResult(comment); 
            }
            

catch
(Exception e)
            {

                _logger.Error(e.Message);
            }

            
return
 FormatResult(InCityErrorMessage.INCITY_COMMENT_LOAD_FAILED);
        }

      

2.正确使用Log的级别

      1. 函数入口处的Log和一般调试的Log使用debug级别,如上面的代码片段.

            _logger.DebugFormat(Comment load single comment by commentId :{0}, Id);

           

      2. 执行某项操作之后,使用info级别。例如支付成功,注册用户等。

      _logger.InfoFormat(Add order complete, orderId{0}, tradeNo:{1}, buyCount:{2}, unitPrice:{3}, orderDate:{4}, orderState:{5}, orderContract.Id, orderContract.TradeNo, orderContract.BuyCount, orderContract.Price, orderContract.OrderDate, orderContract.OrderStateText);        

      3. 异常处使用Error,或者明显出错的地方

          _logger.Error(e.Message);

      

      4. 发生严重地错误,导致破坏业务流程,例如短信发送或者订单处理,或者程序Crash.

public virtual bool Send(BaseSMSContract contract)

        {            

            
try

            {

                _logger.Debug(


In SMSService Send

);
                //…….


            }
            

catch
 (Exception e)
            {

                _logger.Fatal(e.Message);
            }

            
return 
false
;

        }          

 

3.根据级别不同使用将Log输出到文件,数据库

       能够利用现有的框架来写log那是非常方便了。我们项目中使用的是asp.net mvc框架,使用和Log4net很好地实现了log。

       下面介绍下具体的步骤: 

       

       1.下载Common.Logging,Common.Logging.Log4net,log4net三个dll, 并在项目中引用它们。

  ASP.Net MVC 之如何写Log 

ASP.Net MVC 之如何写Log 

       2.Web.config (App.config同理)需要两个地方配置,一个是在configSections中配置

  <sectionGroup name=”common”>

      

<
section 
name
=”logging”
 type
=”Common.Logging.ConfigurationSectionHandler, Common.Logging”
/>

    

</
sectionGroup
>

    <section name=”log4net” type=”log4net.Config.Log4NetConfigurationSectionHandler, log4net”/>          

        

       3.另一个是配置common/logging和log4net. 

          


 <common>
    
<
logging
>

      

<
factoryAdapter 
type
=”Common.Logging.Log4Net.Log4NetLoggerFactoryAdapter, Common.Logging.Log4Net”
>

        

<
arg 
key
=”configType”
 value
=”INLINE”
/>

      

</
factoryAdapter
>

    

</
logging
>

  

</
common
>

  

<
log4net
>

    
    

<!–
输出到Visual studio输出窗口
–>

    

<
appender 
name
=”TraceAppender”
 type
=”log4net.Appender.TraceAppender”
>

      

<
layout 
type
=”log4net.Layout.PatternLayout”
>

        

<!–
格式
–>

        

<
conversionPattern 
value
=”%date [%thread] %-5level %logger [%property{NDC}] – %message%newline”
/>

      

</
layout
>

    

</
appender
>

    
    

<!–
输出到文件
–>

    

<
appender 
name
=”RollingFileAppender”
 type
=”log4net.Appender.RollingFileAppender”
>

      
<!–
文件名
–>

      

<
file 
value
=”incity_api.log”
/>

      
<!–
追加方式写
–>

      

<
appendToFile 
value
=”true”
/>

      

<
rollingStyle 
value
=”Size”
/>

      
<!–
每次写10个文件后覆盖
–>

      

<
maxSizeRollBackups 
value
=”10″
/>

      
<!–
每个文件做大500k
–>

      

<
maximumFileSize 
value
=”500KB”
/>

      

<
staticLogFileName 
value
=”true”
/>

      
<!–
格式
–>

      

<
layout 
type
=”log4net.Layout.PatternLayout”
>

        

<
conversionPattern 
value
=”%date [%thread] %-5level %logger [%property{NDC}] – %message%newline”
/>

      

</
layout
>

    

</
appender
>

    
<!–
Ado net数据库,需要建立表eventlog,字段是ID, log(varchar), createTime(datetime), level(int)
–>

    

<
appender 
name
=”AdoNetAppender”
 type
=”log4net.Appender.AdoNetAppender”
>

      
<!–
log到了512个字节才会输出到数据库 
–>

      

<
bufferSize 
value
=”512″
/>

      
      

<!–
只有级别在INFO上的才会写Log
–>

      

<
filter 
type
=”log4net.Filter.LevelRangeFilter”
>

        

<
param 
name
=”LevelMin”
 value
=”INFO”
/>

        

<
param 
name
=”LevelMax”
 value
=”FATAL”
/>

      

</
filter
>

      

<
connectionType 
value
=”System.Data.SqlClient.SqlConnection, System.Data, Version=2.0.0.0, Culture=Neutral, PublicKeyToken=b77a5c561934e089″
/>

      
<!–
数据库连接 
–>

      

<
connectionString 
value
=”server=.\SQLEXPRESS;database=incity;integrated security=false;persist security info=True;UID=sa;PWD=cry.cap.fox-999″
/>

      
<!–
执行的数据库命令 
–>

      

<
commandText 
value
=”INSERT INTO eventlog ([log],[createTime],[level]) VALUES (@log, @createTime, @level)”
/>

      
<!–
数据库参数 
–>

      

<
parameter
>

        

<
parameterName 
value
=”@createTime”
/>

        

<
dbType 
value
=”DateTime”
/>

        

<
layout 
type
=”log4net.Layout.RawTimeStampLayout”
/>

      

</
parameter
>

      
      

<
parameter
>

        

<
parameterName 
value
=”@log”
/>

        

<
dbType 
value
=”String”
/>

        

<
size 
value
=”1024″
/>

        

<
layout 
type
=”log4net.Layout.PatternLayout”
>

          

<
conversionPattern 
value
=”%message”
/>

        

</
layout
>

      

</
parameter
>

      
      

<
parameter
>

        

<
parameterName 
value
=”@level”
/>

        

<
dbType 
value
=”String”
/>

        

<
size 
value
=”50″
/>

        

<
layout 
type
=”log4net.Layout.PatternLayout”
>

          

<
conversionPattern 
value
=”%level”
/>

        

</
layout
>

      

</
parameter
>

    

</
appender
>

    
    

<
root
>

      

<
level 
value
=”DEBUG”
/>

      

<
appender-ref 
ref
=”TraceAppender”
/>

      

<
appender-ref 
ref
=”RollingFileAppender”
/>

      

<
appender-ref 
ref
=”AdoNetAppender”
/>

    

</
root
>

  

</
log4net
>

    

    上述的配置主要实现了下面的功能: 

 

  • log同时输出到了文件,数据库,Visual Studio输出(其实还可以有udp网络等等),主要都是靠 log4net不同的Appender实现。
  • log输出到文件的时候,是追加方式写,每个日志文件最大500k,写了10个后又从第一个开始覆盖
  • 只有info级别以上的log才会写到数据库中,不是每次写日志都会写数据库,只有到了512个字节才会flush到数据表eventlog中,eventlog需要自己先创建好,数据库会记录时间,级别,内容等信息。

 

 4.代码中使用

下面的代码片段讲述了如何使用log4net,OK,快去看看你的日志吧。

 

using Common.Logging;



namespace
 InCity.Restful.Controllers
{

    

public
 
class
 CommentController : BaseController
    {

        

private
 
readonly
 CommentService _commentService;
        

private
 
readonly
 UserService _userService;
        

private
 
readonly
 ILog _logger 
=
 LogManager.GetCurrentClassLogger();

        
public
 CommentController(CommentService commentService, 
                                 UserService userService)
        {

            _commentService 

=
 commentService;
            _userService 

=
 userService;
        }

        
public
 ActionResult Index(
int
 Id)
        {

            _logger.DebugFormat(


Comment load single comment by commentId :{0}

, Id);
            
            

try

            {

                var comment 

=
 _commentService.Get(Id);
                

return
 FormatResult(comment); 
            }
            

catch
(Exception e)
            {

                _logger.Debug(e.Message);
            }

            
return
 FormatResult(InCityErrorMessage.INCITY_COMMENT_LOAD_FAILED);

        }

 

转载于:https://www.cnblogs.com/enjoyeclipse/archive/2011/07/15/2106951.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/110593.html原文链接:https://javaforall.net

(0)
上一篇 2021年8月12日 下午1:00
下一篇 2021年8月12日 下午2:00


相关推荐

  • 基于stm32门禁系统_老式门禁

    基于stm32门禁系统_老式门禁0、前言RC522射频门禁识别模块非常常用,某宝卖家提供的程序基本都是使用软件模拟SPI的方式进行驱动的,但是实测使用软件模拟SPI识别速率、准确性没有硬件SPI驱动时高,因此本篇博客用于记录使用STM32硬件SPI驱动RC522门禁模块。1、硬件连接单片机:STM32F103RCT6硬件接口:SPI2MISO->PB14(主机输入,从机输出)MOSI->PB15(主机输出,从机输入)SCK->PB13(时钟信号SCLK)SDA->PC

    2025年12月10日
    6
  • access 注入

    0x00前言现在access的站,比较少,有的话也是小型网站在用,因为access的性能比较差,多人访问都能卡死,所以很多网站都很少会采用access的数据库搭建。但是该学的我们还是得学。0x0

    2021年12月11日
    59
  • linux 设备树

    linux 设备树linux设备树参考地址http://blog.csdn.net/green1900/article/details/45646095http://www.cnblogs.com/xiaojiang1025/p/6131381.htmlhttp://blog.csdn.net/21cnbao/article/details/84575461.为什么要使用设备树(DeviceTree

    2022年6月15日
    36
  • 什么叫分销商_分销是什么意思「详细介绍」带你秒懂[通俗易懂]

    什么叫分销商_分销是什么意思「详细介绍」带你秒懂[通俗易懂]很多创业者在创业的道路上可能都会遇到一个问题那就是分销,但是很多创业者却又不懂分销是什么意思。今天我们抖音创业网大家详细地介绍一下关于分析的意思,绝对让你看完以后秒懂。分销是什么意思解释其实简单来说分销就是我们帮助别人销售商品,但是我们销售出去以后我们可以得到一定的分成,同时在我们的利润允许的情况下我们还可以继续拉下线,让其他的人成为我们的销售员工。分销实际案例模拟假如现在有一个苹果,供货商说这…

    2022年5月16日
    59
  • pycharm如何远程连接服务器_py服务端软件

    pycharm如何远程连接服务器_py服务端软件通过pycharm远程连接服务器首先确定你连接服务器的方式软件准备验证软件是否安装成功pycharm远程连接服务器上传自己的project到Ubuntu上传完以后,开始给自己的项目配置服务器的python解释器如何使用路由器,开启外网映射通过路由器的底部的网址进入管理员页面选择应用管理进入虚拟服务器在虚拟服务器中添加需要把内网映射到外网的IP地址查看自己映射出去的外网IP地址至此大功告成!!!您可以通过外网来访问您学校的服务器啦!首先确定你连接服务器的方式一般连接服务器需要服务器的ip地址,IP地址分为

    2022年8月28日
    9
  • mysql 索引类型以及使用场景[通俗易懂]

    mysql 索引类型以及使用场景[通俗易懂] 关于MySQL索引的好处,如果正确合理设计并且使用索引的MySQL是一辆兰博基尼的话,那么没有设计和使用索引的MySQL就是一个人力三轮车。对于没有索引的表,单表查询可能几十万数据就是瓶颈,而通常大型网站单日就可能会产生几十万甚至几百万的数据,没有索引查询会变的非常缓慢。还是以WordPress来说,其多个数据表都会对经常被查询的字段添加索引,比如wp_comments表中针对5个字段设计了B…

    2022年6月7日
    39

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号