博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
windows服务-log4net的使用
阅读量:4474 次
发布时间:2019-06-08

本文共 2813 字,大约阅读时间需要 9 分钟。

本文转自http://www.cnblogs.com/puzi0315/archive/2012/08/08/2628966.html

Log4net监控服务状态

对于比较复杂的逻辑,可以使用log4net来记录程序的执行过程中的关键数据,以此来监控服务的逻辑是否完备。

1.在项目中引入log4net.dll组件;

2.在App.congfig中做如下修改

在<configSections></configSections>加入如下内容:

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

在根结点下加入如下内容:

3.新建LogHelp.cs文件using System;using System.Collections.Generic;using System.Text;using log4net;using System.Diagnostics;using System.Reflection; namespace WinService{

public class LogHelper

{
private static readonly ILog logInfo = LogManager.GetLogger("Log");
private static readonly ILog logErr = LogManager.GetLogger("Err");
/// <summary>
/// 记录正常的消息
/// </summary>
/// <param name="msg">消息内容</param>
public static void info(string msg)
{
logInfo.Info(msg);
}
/// <summary>
/// 记录异常信息
/// </summary>
/// <param name="msg">异常信息内容</param>
public static void error(string msg)
{
StackTrace stackTrace = new StackTrace();
StackFrame stackFrame = stackTrace.GetFrame(1);
MethodBase methodBase = stackFrame.GetMethod();
logErr.Error("类名:" + methodBase.ReflectedType.Name + " 方法名:" + methodBase.Name + " 信息:" + msg);
}
}

}

重新生成项目,在项目的关键地方可以使用LogHelper.info()函数记录正常执行的关键信息,用LogHelper.error()函数记录抛出的异常信息。

比如:

 

protectedoverridevoid OnStart(string[] args)        {            // TODO: 在此处添加代码以启动服务。            try            {                theTimer.Start();                timespan = Convert.ToDouble(System.Configuration.ConfigurationManager.AppSettings["timespan"]);                theTimer.Interval = timespan * 60 * 1000;//间隔时间为五分钟,取前后2.5分钟                LogHelper.info("WinService服务启动:" + DateTime.Now.ToString());            }            catch (Exception ex)            {                LogHelper.error("WinService服务启动错误:"+ex.Message);            }                    }

在项目的bin\Debug目录下可以看到两个文件夹:WindowsServiceErr和WindowsServiceLog,分别存放信息日志和错误日志,结合相关日志可以帮助分析系统运行是否正常。如果看不到两个文件夹,可以在项目的Properties\AssemblyInfo.cs文件中加入如下内容:

    [assembly: log4net.Config.XmlConfigurator(Watch = true)]

转载于:https://www.cnblogs.com/tongdengquan/p/6090469.html

你可能感兴趣的文章
ispy 编译笔记
查看>>
bzoj1067——SCOI2007降雨量(线段树,细节题)
查看>>
day 1
查看>>
洛谷P1282 多米诺骨牌【线性dp】
查看>>
数据类型的提升(promotion)
查看>>
Thead是不能返回值的,但是作为更高级的Task当然要弥补一下这个功能。
查看>>
Android呼叫转移跳转到拨号盘 “#”号显示不出来
查看>>
Python中的生成器与yield
查看>>
JQuery 的Bind()事件
查看>>
Maven 常用配置
查看>>
Objects源码解析
查看>>
video
查看>>
栈的c语言顺序实现(动态申请空间)
查看>>
【转】 Pro Android学习笔记(六七):HTTP服务(1):HTTP GET
查看>>
获取子iframe框架的元素
查看>>
WordCount bug修复录
查看>>
承载进程 (vshost.exe)
查看>>
[转]WPF MVVM 实战
查看>>
[转载] Python 标准库 urllib2 的使用细节
查看>>
Silverlight使用DataGrid的模板列(DataGridTemplateColumn)实现类似TreeListView控件的效果
查看>>