我在vb.net中有一个全新的控制台应用程序。我想使用log4net,所以我做了以下步骤,它的工作原理。大。雅虎。
但我必须将Log4Net.config与Log4Net.dll和Log4Net.xml一起放在bin / debug中。我尝试过很多东西但没有快乐。或者我没有得到正确的组合。如何将Log4Net.config移动到app root?
从NuGet安装Log4Net。
我添加了
<Assembly: XmlConfigurator(ConfigFile:="Log4Net.config", Watch:=True)>
在AssemblyInfo.vb中。
这就是我所说的:
Public Class Class1
'Save log4net log into SQL Server
Private Shared ReadOnly DBlog As ILog = LogManager.GetLogger("TestLog4Net")
Public Shared Sub Main(ByVal args() As String)
DBlog.Error("Log4Net testing v1")
End Sub
End Class
我的Log4Net.Config:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>
<log4net>
<appender name="AdoNetAppender" type="log4net.Appender.AdoNetAppender">
<bufferSize value="1" />
<connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
<connectionString value="xxxxx" />
<commandText value="xxxxx" />
<parameter>
<parameterName value="@log_date" />
<dbType value="DateTime" />
<layout type="log4net.Layout.RawTimeStampLayout" />
</parameter>
<parameter>
<parameterName value="@thread" />
<dbType value="String" />
<size value="255" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%thread" />
</layout>
</parameter>
<parameter>
<parameterName value="@log_level" />
<dbType value="String" />
<size value="50" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%level" />
</layout>
</parameter>
<parameter>
<parameterName value="@logger" />
<dbType value="String" />
<size value="255" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%logger" />
</layout>
</parameter>
<parameter>
<parameterName value="@message" />
<dbType value="String" />
<size value="4000" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%message" />
</layout>
</parameter>
<parameter>
<parameterName value="@exception" />
<dbType value="String" />
<size value="2000" />
<layout type="log4net.Layout.ExceptionLayout" />
</parameter>
</appender>
<logger name="TestLog4Net">
<level value="ALL" />
<appender-ref ref="AdoNetAppender" />
</logger>
</log4net>
</configuration>
我试过
在我说DBlog.Error("xx")
log4net.Config.XmlConfigurator.Configure()
在app.config中设置它。
<log4net configSource="Log4Net.config" />
将整个Log4Net.config移动到app.config。那没用。
将此设置为某个帖子上建议的人。这也不起作用。
<appSettings>
<add key="log4net.Config" value="log4net.config"/>
<add key="log4net.Config.Watch" value="True"/>
</appSettings>
声明此而不是我正在使用的GetLogger("name")
。也没有快乐。
Private Shared ReadOnly log As ILog = LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType)
答案 0 :(得分:2)
如果您只想将Log4net.config文件移动到bin / Debug,请尝试右键单击解决方案资源管理器中的文件 - &gt; 属性 - &gt; 将复制到输出目录的值更改为 始终复制。我不确定这是不是你想要的。所以,我可能错了。随意纠正我。 ;)
编辑: 另一种方法是编写预构建命令。 在解决方案资源管理器中右键单击项目 - &gt; 属性 - &gt; 转到构建活动标签
假设Log4net.config文件存在于项目目录(存在vb文件的目录)中,可以在预构建事件命令行下给出以下命令,
xcopy "$(ProjectDir)Log4net.config" "$(TargetDir)"
答案 1 :(得分:0)
在我的C#控制台应用程序中,我有以下内容:
<强>的AssemblyInfo.cs 强>
[assembly: log4net.Config.XmlConfigurator(Watch = true)]
<强> App.Config中强>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
</configSections>
<log4net>
<!--
This writes the log information to the console window. It only logs events
that are at least at the INFO level (which would mean that DEBUG events are not
captured.
-->
<appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date{ABSOLUTE} [%thread] %level %logger - %message%newlineExtra Info: %property{testProperty}%newline%exception"/>
</layout>
<filter type="log4net.Filter.LevelRangeFilter">
<levelMin value="INFO"/>
<levelMax value="FATAL"/>
</filter>
</appender>
<!--
This stores information in the mylogfile.txt file. It only captures log events
that contain the key word test or error.
-->
<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
<file value="Logs/file-"/>
<datePattern value="yyyy-MM-dd.lo\g"/>
<appendToFile value="true"/>
<rollingStyle value="Date"/>
<maxSizeRollBackups value="5"/>
<maximumFileSize value="10MB"/>
<staticLogFileName value="false"/>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %level %logger - %message%newline%exception"/>
</layout>
</appender>
<root>
<level value="ALL"/>
<appender-ref ref="RollingFileAppender"/>
<appender-ref ref="ConsoleAppender"/>
</root>
</log4net>
在我的班级里,我有......
private static readonly log4net.ILog Log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
Log.InfoFormat("...");