在Minnow Max上运行Ubuntu试图在单声道应用程序中使用log4net,Udp appender不会登录到远程位置。在具有相同配置的Raspberry Pi 2上运行相同的应用程序,Udp appender正确记录。当我启用log4net日志记录时,没有错误,并且两台计算机上的日志输出相同。我使用了nmap和Wire Shark来验证Udp端口是否打开并发送数据包。 Minnow上的文件追加器正确记录。
C#代码
private static readonly ILog Logger = LogManager.GetLogger($"Drake.Mfg.DCS.{Environment.MachineName}");
public static LogLevel ConsoleLevel { get; set; }
public static void LogToNet(string message, LogLevel logLevel)
{
try
{
switch (logLevel)
{
case LogLevel.None:
break;
case LogLevel.Trace:
Logger.Trace(message);
break;
case LogLevel.Debug:
Logger.Debug(message);
break;
case LogLevel.Info:
Logger.Info(message);
break;
case LogLevel.Warn:
Logger.Warn(message);
break;
case LogLevel.Error:
Logger.Error(message);
break;
case LogLevel.Fatal:
Logger.Fatal(message);
break;
case LogLevel.AlwaysLog:
Logger.Info(message);
break;
default:
throw new ArgumentOutOfRangeException(nameof(consoleLevel), consoleLevel, null);
}
Console.WriteLine($"{message}");
Console.ResetColor();
}
Log4Net.Config
<?xml version="1.0" encoding="utf-8"?>
<log4net>
<appender name="Main" type="log4net.Appender.RollingFileAppender">
<file value="dcsLog.log" />
<appendToFile value="true" />
<maximumFileSize value="1GB" />
<maxSizeRollBackups value="3" />
<encoding value="utf-8" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%utcdate{ISO8601} %-8level %-28logger %message%newline" />
</layout>
</appender>
<appender name="UdpAppender" type="log4net.Appender.UdpAppender">
<remoteAddress value="192.168.10.53" />
<remotePort value="7071" />
<layout type="log4net.Layout.XmlLayoutSchemaLog4j" />
<encoding value="utf-8" />
</appender>
<root>
<level value="Debug" />
<appender-ref ref="Main" />
</root>
<logger name="Drake.Mfg.DCS.DEI80021">
<level value="Debug" />
<appender-ref ref="UdpAppender" />
</logger>
</log4net>
单
Mono JIT编译器版本4.3.0(master / 844fc33 Tue Oct 20 14:21:50 EDT 2015)版权所有(C)2002-2014 Novell,Inc,Xamarin Inc和 贡献者。 www.mono-project.com TLS:__thread SIGSEGV:altstack 通知:epoll 架构:amd64 禁用:无 杂项:softdebug LLVM:支持,未启用。 GC:sgen
log4net的
1.2.15
答案 0 :(得分:1)
Log4Net配置区分大小写,因为xml是。 Minnow的主机名是小写的,我正在寻找上层。因为我没有单独控制主机名,所以我使用了To Upper。
ILog logger = LogManager.GetLogger($"Drake.Mfg.DCS.{Environment.MachineName.ToUpper()}");
现在和将来修复它。