Web项目中使用NLog记录日志,利用单件模式控制整个项目只有一个Logger对象的问题...

   在web项目中利用NLog记录一些项目运行的状态信息:异常、标示数据等
   设计此类最初的目的是提高性能,利用单件模式控制整个项目只有一个NLog.Logger日志操作对象。
   考虑到web项目的多用户访问问题,此设计会不会出现什么问题?控制NLog.Logger的对象是否有必要?NLog记录日志有什么需要注意的地方?望知情者不吝赐教。
   代码如下:

using  System;
using  System.Data;
using  System.Configuration;
using  System.Web;
using  System.Web.Security;
using  System.Web.UI;
using  System.Web.UI.WebControls;
using  System.Web.UI.WebControls.WebParts;
using  System.Web.UI.HtmlControls;
using  NLog;

/**/ /// <summary>
/// 管理本Web项目使用的日志记录对象
/// 单件模式复合运用,保证整个项目只有一个NLog.Logger对象
/// </summary>

public   class  CsmLog
{
    
"确保CsmLog只有一个对象"#region "确保CsmLog只有一个对象"
    
private CsmLog()
    
{
        
//初始化唯一一个CsmLog对象时,给予其一个Logger对象
        _csmLogger = LogManager.GetCurrentClassLogger();
    }

    
public static CsmLog GetInstance()
    
{
        
return NestedCsmLog.instance;
    }

    
/**//// <summary>
    
/// 实现CsmLog延迟初始化嵌套类
    
/// </summary>

    class NestedCsmLog
    
{
        
static NestedCsmLog()
        
{
        }

        
internal static readonly CsmLog instance = new CsmLog();
    }

    
#endregion

    
"得到一个Logger(日志对象)"#region "得到一个Logger(日志对象)"
    
private  Logger _csmLogger;
    
public Logger CsmLogger
    
{
        
get
        
{
            
return _csmLogger;
        }

    }

    
#endregion

    
Invalid Code#region Invalid Code
    
//public static Logger getLogger()
    
//{
    
//    //private static Logger logger = NLog.LogManager.GetCurrentClassLogger(); 
    
//    return NLog.LogManager.GetCurrentClassLogger();
    
//}
#endregion
   
}



 

转载于:https://www.cnblogs.com/xdp/archive/2008/01/08/1030826.html

在.NET Core,`Microsoft.Extensions.Logging`提供了一个基础的日志系统,而`NLog`是一个强大的第三方日志库。虽然它们各自独立,但可以结合起来使用。要让`Microsoft.Extensions.Logging.Logger`能够接收`NLog`的`LogEventInfo`,你需要通过所谓的"包装器"(Wrapper)或间件(Middleware)将两者连接起来。 首先,你需要创建一个适配器,比如一个实现了`ILoggerProvider`接口的类,它可以从NLog的事件源获取`LogEvent`并转换为`LogEntry`(`Microsoft.Extensions.Logging`使用日志条目)。以下是一个简单的示例: ```csharp public class NLogToMELAdapter : ILoggerProvider { private readonly NLog.Logger _nLogLogger; public NLogToMELAdapter(NLog.Logger nLogLogger) { _nLogLogger = nLogLogger; } // 其他必要的方法实现,包括CreateLogger和 dispose public IDisposable CreateLogger(string categoryName) { return new NLogToMELLoggerAdapter(_nLogLogger, categoryName); } } public class NLogToMELLoggerAdapter : ILogger { private readonly NLog.Logger _nLogLogger; private readonly string _categoryName; public NLogToMELLoggerAdapter(NLog.Logger nLogLogger, string categoryName) { _nLogLogger = nLogLogger; _categoryName = categoryName; } // 实现 ILogger 接口的方法,如 LogDebug, LogError 等,将 NLog 的 LogEvent 转换为 MEL 的 LogEntry public void Log<TState>(LogLevel logLevel, EventId eventId, TState state, Exception exception, Func<TState, Exception, string> formatter) { var nLogEvent = _nLogLogger.Log(logLevel.ToString(), () => formatter(state, exception)); // 将 NLogEvent 转换为 LogEntry 并提交给 MEL 的日志系统 } } ``` 然后,在应用程序启动时配置`Microsoft.Extensions.DependencyInjection`服务,将`NLogToMELAdapter`注册为日志提供者: ```csharp services.AddSingleton<ILoggerProvider, NLogToMELAdapter>(); ``` 现在,你已经成功地扩展了`Microsoft.Extensions.Logging.Logger`,使其能够处理NLog产生的`LogEventInfo`。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值