RemotingAppender问题。 Conn创建但没有附加任何内容

时间:2015-08-15 23:48:59

标签: log4net remoting log4net-appender

我一直在学习log4net,并希望将来某个时候使用远程处理程序将消息记录到服务器上。为此,我首先尝试创建一个本地.Net远程处理服务器并附加到它。在我看来,服务器已创建,但我无法收到这些消息。 (为了检查这一点,我尝试在运行我的程序之前和之后在我的浏览器中输入localhost:portnumber来访问服务器。它之前失败并稍后接受连接。有没有更好的方法来调试它?) 无论如何,这是代码。我将不胜感激任何帮助。 PS:我可以看到文件&控制台appender工作。

客户端代码的App.config

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="log4net" type="log4net.onfig.Log4NetConfigurationSectionHandler, log4net"/>
  </configSections> 
  <log4net>
    <appender name="Console" type="log4net.Appender.ColoredConsoleAppender">
      <mapping>
        <level value="DEBUG"/>
        <foreColor value="Red, HighIntensity"/>
      </mapping>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%class %date [%level] - %message%newline"/>
      </layout>
    </appender>

    <appender name="File" type="log4net.Appender.FileAppender">
      <file value="logfile.txt"/>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%class %date [%level] - %message%newline"/>
      </layout>
    </appender>

      <appender name="RemotingAppender" type="log4net.Appender.RemotingAppender">
        <sink value="tcp://localhost:8086/RemoteLogger"/>
        <lossy value="false"/>
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%class %date [%level] - %message%newline"/>
         </layout>
      <bufferSize value="1"/>
      <onlyFixPartialEventData value="true"/>
      </appender>

    <root>
      <level value="ALL"/>
      <appender-ref ref="Console"/>
    <appender-ref ref="RemotingAppender"/>
    <appender-ref ref="File"/>
    </root>


  </log4net>

   <startup> 
        <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
    </startup>
</configuration>

服务器代码Appconfig

<?xml version="1.0" encoding="utf-8" ?>
<configuration>

      <system.runtime.remoting>
        <application name="RemoteLogger">
          <channels>
            <channel name="logging sink" ref="tcp server" port="8086"/>
          </channels>
        </application>
      </system.runtime.remoting>

</configuration>

服务器代码

namespace RemoteAPP
{
    class Program
    {
        static void Main(string[] args)
        {
            Console.WriteLine("Listening");
            var _sink = new RemoteSink();
            _sink.EventsReached += (s,a)=> AddLog(a.LoggingEvents);
            RemotingConfiguration.Configure("RemoteAPP.exe.config", false);
            //RemotingConfiguration.RegisterWellKnownServiceType(new WellKnownServiceTypeEntry(typeof(RemoteSink), "RemoteLogger", WellKnownObjectMode.SingleCall));

            RemotingServices.Marshal(_sink, "RemoteLogger");
            Console.ReadLine();
        }

        private static void AddLog(IEnumerable<LoggingEvent> enumerable)
        {
            var Logevents = enumerable.ToList();
            foreach(var logevent in Logevents)
            {
                Console.WriteLine(logevent);
            }
        }
    }

    public class RemoteSink:MarshalByRefObject,RemotingAppender.IRemoteLoggingSink
    {
        public class LoggingArgs:EventArgs
        {
            public IEnumerable<LoggingEvent> LoggingEvents;
        }
        public EventHandler<LoggingArgs> EventsReached;

        void RemotingAppender.IRemoteLoggingSink.LogEvents(LoggingEvent[] events)
        {
            var ev = EventsReached;
            if(ev==null)
            {
                ev.Invoke(this, new LoggingArgs{LoggingEvents = events});
            }
        }
    }
}

客户代码

class Program
    {
        static void Main(string[] args)
        {
            Thread.Sleep(10000);

            log4net.ILog log = log4net.LogManager.GetLogger(typeof(Program));
            for (int i = 0; i < 1000;i++ )
            {
                log.Info("Hello world");
                log.Debug("This is Debug");
                log.Warn("This is Warn");
            }

1 个答案:

答案 0 :(得分:0)

那么, 我找到了答案。上面的代码是正确的。事实证明,Log4net的客户端和服务器端之间存在一些不兼容性。虽然我从同一个源(Nuget)安装了两个,但两个引用之间发生了一些变化。将log4net的内部调试器属性设置为true后,我偶然发现了这条日志消息。

log4net:ERROR [RemotingAppender] ErrorCode: GenericFailure. Failed in SendBufferCallback

谷歌搜索它让我here,这是我怀疑有些不对劲的地方。简而言之,删除了RemoteAPP中对log4net的所有引用,并通过Nuget重新安装。

现在有效。如果有人知道这是怎么发生的,请继续讨论。