使用 NLog 在 Mongo 数据库中存储日志
Storing Logs in a Mongo database using NLog
我一直在尝试使用 NLog.Mongo 和 NLog.MongoDB 将日志写入 Mongo 数据库。但是,我不断收到一条错误消息 "This is an invalid xsi:type 'http://www.nlog-project.org/schemas/NLog.xsd:MongoDB"。我使用的代码如下:
<?xml version="1.0" encoding="utf-8" ?>
<nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.nlog-project.org/schemas/NLog.xsd NLog.xsd"
autoReload="true"
throwExceptions="false"
internalLogLevel="Off" internalLogFile="c:\temp\nlog-internal.log">
<extensions>
<add assembly="NLog.MongoDB"/>
</extensions>
<targets>
<target xsi:type="MongoDB" name="mongo" database="NLog">
<field name="timestamp" layout="${date}"/>
<field name="level" layout="${level}"/>
<field name="message" layout="${message}"/>
</target>
</targets>
<rules>
<logger name="*" minlevel="Trace" writeTo="mongo"/>
</rules>
</nlog>
我正在寻找此错误的解决方案或可以执行此操作的其他方法。我搜索了所有我能想到的地方,只找到了未回答的问题,例如:
NLog xsi:type not working with custom target
Nlog with MongoDB connection and target
出现的错误只是指定它不是可识别的 NLog 类型。该扩展确实有效,事实证明上面代码的问题是由于未指定 connectionString。
我已经使用以下方法修复了问题:
<?xml version="1.0" encoding="utf-8" ?>
<nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.nlog-project.org/schemas/NLog.xsd NLog.xsd"
autoReload="true"
throwExceptions="false"
internalLogLevel="Off" internalLogFile="c:\temp\nlog-internal.log">
<extensions>
<add assembly="NLog.Mongo"/>
</extensions>
<targets>
<target xsi:type="Mongo" name="mongo" databaseName="NLog" collectionName="Test" connectionString="mongodb://localhost/NLog"/>
</targets>
<rules>
<logger name="*" minlevel="Trace" writeTo="mongo"/>
</rules>
</nlog>
我一直在尝试使用 NLog.Mongo 和 NLog.MongoDB 将日志写入 Mongo 数据库。但是,我不断收到一条错误消息 "This is an invalid xsi:type 'http://www.nlog-project.org/schemas/NLog.xsd:MongoDB"。我使用的代码如下:
<?xml version="1.0" encoding="utf-8" ?>
<nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.nlog-project.org/schemas/NLog.xsd NLog.xsd"
autoReload="true"
throwExceptions="false"
internalLogLevel="Off" internalLogFile="c:\temp\nlog-internal.log">
<extensions>
<add assembly="NLog.MongoDB"/>
</extensions>
<targets>
<target xsi:type="MongoDB" name="mongo" database="NLog">
<field name="timestamp" layout="${date}"/>
<field name="level" layout="${level}"/>
<field name="message" layout="${message}"/>
</target>
</targets>
<rules>
<logger name="*" minlevel="Trace" writeTo="mongo"/>
</rules>
</nlog>
我正在寻找此错误的解决方案或可以执行此操作的其他方法。我搜索了所有我能想到的地方,只找到了未回答的问题,例如:
NLog xsi:type not working with custom target
Nlog with MongoDB connection and target
出现的错误只是指定它不是可识别的 NLog 类型。该扩展确实有效,事实证明上面代码的问题是由于未指定 connectionString。
我已经使用以下方法修复了问题:
<?xml version="1.0" encoding="utf-8" ?>
<nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.nlog-project.org/schemas/NLog.xsd NLog.xsd"
autoReload="true"
throwExceptions="false"
internalLogLevel="Off" internalLogFile="c:\temp\nlog-internal.log">
<extensions>
<add assembly="NLog.Mongo"/>
</extensions>
<targets>
<target xsi:type="Mongo" name="mongo" databaseName="NLog" collectionName="Test" connectionString="mongodb://localhost/NLog"/>
</targets>
<rules>
<logger name="*" minlevel="Trace" writeTo="mongo"/>
</rules>
</nlog>