本篇是在学习了“编码之道”的Log4net入门(WCF篇)http://www.cnblogs.com/yonghuacui/p/6181864.html之后,总结了一些自认为比较重要的细节。顺便把创建和发布WCF服务的知识也一起巩固一下。

一、创建项目

1、在模板中选择【WCF服务应用程序】,输入项目名称“Log4netWCF”后,点击创建。

2、右键点击“Log4netWCF”项目中的“IService1.cs”文件,将其删除,再展开“Service1.svc”,将子项“Service1.svc.cs”删除。

3、在解决方案中【添加项目】,在模板中选择【WCF服务库】项目,输入项目名称“Log4netWcfServiceLibrary”后,点击创建。

4、在“Log4netWCF”项目中右键点击【引用】-【添加引用】-【项目】,勾选“Log4netWcfServiceLibrary”项目.

5、打开“Log4netWCF”项目的“Service1.svc”文件,修改其中的代码为:

 <%@ ServiceHost Language="C#" Debug="true" Service="Log4netWcfServiceLibrary.Service1" CodeBehind="Service1.cs" %>

6、选择【生成解决方案】,没有报错的话,那我们的WCF服务就算是创建好了。

二、发布服务

1、右键点击“Log4netWCF”项目,选择【发布】。弹出如下对话框。

2、在【配置文件】选择【自定义】,输入配置文件名称“Log4netWCF”,这个随便取,好记就行,点击【下一步】。

3、在【连接】中“Publish method”选择“File System”,“Target location”点击后面的“...”,选择【文件系统】,选择一个合适的目录。我选择“F:\Log4netWCF”这个文件夹,点击【发布】。

 三、在IIS创建网站

1、安装IIS的方法我就不细说了,网上一搜一大把,在【计算机管理】中选择【Internet Information Services(IIS)】-【网站】-【添加网站】。

2、“网站名称”填“Log4netWcfService”,“物理路径”选择刚刚发布WCF时选择的路径“F:\Log4netWCF”,“绑定”里“IP地址”填写“127.0.0.1”,“端口”填写“8081”(填一个没有使用的就行),点击确定。

3、点击右侧“浏览网站”,查看网页有没有报错,没报错的话WCF服务就算是发布成功了。

四、测试WCF服务

1、在解决方案里再添加一个测试用的项目,右键解决方案【添加】-【新建项目】,选择“控制台应用程序”,项目名称“Log4netWCFTest”。

2、在“Log4netWCFTest”项目中,右键点击【引用】-【添加服务引用】。

3、在地址栏输入刚刚发布的WCF服务的地址,后加svc文件的文件名,点击【转到】。服务栏出现了服务,说明已经检测到了WCF服务。然后在“命名空间”中输入名称“Log4netWcfService”,点击确定。

4、把“Log4netWCFTest”设置为启动项目。右键“Log4netWCFTest”项目,选择【设置为启动项目】。

5、在“Log4netWCFTest”项目的Program.cs文件中增加测试代码。

using System;

namespace Log4netWCFTest
{
class Program
{
static void Main(string[] args)
{
Log4netWcfService.Service1Client client = new Log4netWcfService.Service1Client();
Console.WriteLine(client.GetData());
Console.ReadKey();
}
}
}

6、点击启动,查看结果。

7、输出结果为“You entered 5”,证明我们的服务是可以使用的。

五、使用Log4net记录日志

1、终于讲到正题了,在项目“Log4netWcfServiceLibrary”中,右键点击【引用】-【添加引用】。

2、选择【浏览】项,找到Log4net.dll,点击【确定】。

3、在“Log4netWCFServiceLibrary”项目中添加Log4net的配置文件。

4、因为找不到配置文件的类型,我这里文件类型就直接选择“类”,文件名称填写“Log4net.config”。

5、将添加的配置文件中的内容删除,添加如下代码:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
</configSections> <system.web>
<compilation debug="true" targetFramework="4.5.2" />
<httpRuntime targetFramework="4.5.2" />
</system.web> <log4net>
<!-- 将日志以回滚文件的形式写到文件中 -->
<!-- 按日期切分日志文件,并将日期作为日志文件的名字 -->
<appender name="RollingFileAppenderNameByDate" type="log4net.Appender.RollingFileAppender">
<!-- 日志文件存放位置,可以为绝对路径也可以为相对路径 -->
<file value="C:\Logs\" />
<!-- 将日志信息追加到已有的日志文件中-->
<appendToFile value="true" />
<!-- 最小锁定模式,以允许多个进程可以写入同一个文件 -->
<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
<!-- 指定按日期切分日志文件 -->
<rollingStyle value="Date" />
<!-- 日志文件的命名规则 -->
<datePattern value="&quot;WCFLogs_&quot;yyyyMMdd&quot;.log&quot;" />
<!-- 当将日期作为日志文件的名字时,必须将staticLogFileName的值设置为false -->
<staticLogFileName value="false" /> <layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level %logger - %message%newline" />
</layout>
</appender> <root>
<!-- 控制级别,由低到高:ALL|DEBUG|INFO|WARN|ERROR|FATAL|OFF -->
<!-- 比如定义级别为INFO,则INFO级别向下的级别,比如DEBUG日志将不会被记录 -->
<!-- 如果没有定义LEVEL的值,则缺省为DEBUG -->
<level value="ALL" />
<!-- 按日期切分日志文件,并将日期作为日志文件的名字 -->
<appender-ref ref="RollingFileAppenderNameByDate" />
</root>
</log4net>
</configuration>

6、修改“Log4netWCFServiceLibrary”项目中的Service1.cs文件,代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Runtime.Serialization;
using System.ServiceModel;
using System.Text; namespace Log4netWcfServiceLibrary
{
// 注意: 使用“重构”菜单上的“重命名”命令,可以同时更改代码和配置文件中的类名“Service1”。
public class Service1 : IService1
{ private static log4net.ILog log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
public string GetData(int value)
{
log.Debug("这是deBug日志");
log.Info("这是Info日志");
log.Warn("这是Warn日志");
log.Error("这是Error日志");
log.Fatal("这是Fatal日志");
return string.Format("You entered: {0}", value);
} public CompositeType GetDataUsingDataContract(CompositeType composite)
{
if (composite == null)
{
throw new ArgumentNullException("composite");
}
if (composite.BoolValue)
{
composite.StringValue += "Suffix";
}
return composite;
}
}
}

7、在“Log4netWCFServiceLibrary”项目的AssemblyInfo.cs文件最后中添加一行:

[assembly: log4net.Config.XmlConfigurator(ConfigFile = "Log4Net.config", Watch = true)]

8、重新发布一次“Log4netWCF”项目。使用“Log4netWCFTest”项目测试下服务,接着就可以去日志路径查看日志了。日志路径配置在“Log4netWCF”项目的“Log4net.config”文件中,我这里配置的路径为“C:\Logs\”。

注:日志文件路径也可以使用相对路径,如:

<file value="logs\" />

日志会输出到发布WCF服务的路径下。

记录日志好习惯——Log4net入门(WCF篇)的更多相关文章

  1. Log4net入门(WCF篇)

    在上一篇Log4net入门(ASP.NET MVC 5篇)中,我们讲述了如何在ASP.NET MVC 5项目中使用log4net.在这一篇中,我们将讲述如何在WCF应用中使用log4net,为了讲述这 ...

  2. Log4net入门(帮助类篇)

    在前几篇Log4net入门文件的讲述过程中,我们在使用log4net的类中都要编写如下一行代码: private static log4net.ILog log = log4net.LogManage ...

  3. Log4net入门(ASP.NET MVC 5篇)

    在前4篇Log4net入门文章中,我们讲述了log4net的一些简单用法,在这一篇中我们主要讲述如何在ASP.NET MVC 5项目中将日志信息写入SQL Server数据库中. 一.创建最简单的AS ...

  4. Log4net入门(SQL篇)

    我们在Log4net入门(回滚日志篇)中详细讲述了如何将日志信息输出到日志文件中,在这一篇中,我们将讲述如何将日志文件写入SQL Server数据库,以方便我们分析统计日志信息. 首先,我们在SQL ...

  5. Log4net入门(日志文件篇)

    在上一篇Log4net入门(控制台篇)中,我们将日志信息输出到控制台中,在这一篇中,我们将描述如何将日志信息写到文件中.要将日志信息写入文件非常简单,只需要在Log4net.config配置文件中添加 ...

  6. .NET日志记录之——log4net划重点篇

    .NET日志记录之--log4net划重点篇 1.概述 log4net是.Net下一个非常优秀的开源日志记录组件.log4net记录日志的功能非常强大.它可以将日志分不同的等级,以不同的格式,输出到不 ...

  7. 版本控制工具Git工具快速入门-Linux篇

    版本控制工具Git工具快速入门-Linux篇 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.版本管理系统的介绍 1>.版本管理系统的特点 1.1>.自动生成备份: ...

  8. 关于WEB Service&WCF&WebApi实现身份验证之WCF篇(2)

    因前段时间工作变动(换了新工作)及工作较忙暂时中断了该系列文章,今天难得有点空闲时间,就继续总结WCF身份验证的其它方法.前面总结了三种方法(详见:关于WEB Service&WCF& ...

  9. Asp.Net MVC2.0 Url 路由入门---实例篇

    本篇主要讲述Routing组件的作用,以及举几个实例来学习Asp.Net MVC2.0 Url路由技术. 接着上一篇开始讲,我们在Global.asax中注册一条路由后,我们的请求是怎么转到相应的Vi ...

随机推荐

  1. Flash Builder 4.6/4.7 注释以及字体大小修改

    ①修改字体颜色.粗体.斜体.下划线 英文版:windows-preferences-flex-editors-syntex coloring-ActionScript-Comment 汉化版:窗口—首 ...

  2. 三个数组求中位数,以及中位数的中位数----java算法实现

    求三个数组的中位数,以及中位数的中位数.   import java.util.Arrays; public class median { public static void main(String ...

  3. codeforces|CF13C Sequence

    大概的题意就是每次可以对一个数加一或者减一,然后用最小的代价使得原序列变成不下降的序列. 因为是最小的代价,所以到最后的序列中的每个数字肯定在原先的序列中出现过.(大家可以想一下到底是为什么,或者简单 ...

  4. Android应用-底部导航栏的使用

    目录 1. 设计底部导航栏页面 1.1. 创建必须的文件夹 1.2. 设计主页面 2. 设计逻辑函数 3. 项目展示 底部导航栏是基于Bottom Navigation Bar 插件使用的 这个插件包 ...

  5. 苹果软件App上架问题

    0.官方网站 开发者中心 itunes connect 优酷 哔哩哔哩 腾讯视频 1.上架流程 1.1 开发者账号申请 2017年苹果企业开发者账请完号申整指南 iOS开发之苹果开发者账号注册申请流程 ...

  6. 如何在linux上安装使用virt-manager

    环境是centos6.5-64位操作系统. 1.准备yum源: 将CentOS6-Base-163.repo 下载到目标主机的/etc/yum.repos.d/目录. cd /etc/yum.repo ...

  7. C# Winform下一个热插拔的MIS/MRP/ERP框架14(自动更新)

    对于软件来说,启用自动更新是非常必要的. 根据软件的应用场景,我们可以设计不同的更新模型. 目前,IMES框架运行在.Net framework 4.0下面,使用的Win系统版本在Win7,域内管控, ...

  8. ubuntu14.04安装zabbix

    1. apt-get updateapt-get install apache2 mysql-server libapache2-mod-php5 php5-gd php5-mysql php5-co ...

  9. CoreImage 图片处理

    CoreImage 是苹果 iOS5新增的一个 OC 框架,提供了强大的图像处理功能, 用于对基于像素的图像进行操作与分析, 提供了很多滤镜(Filter),形成强大的自定义效果 CIImage 类 ...

  10. java操作html格式数据

    近期在做数据抓取功能,抓取到的数据为html格式,需在后台进行转换后取值,为了避免使用字符串查找方式获取而使用Jsonp完美实现. 1. 引入Jsonp: <dependency> < ...