Estoy buscando, por ejemplo, configuración sobre cómo obtener el registro de Log4net en un servidor Syslog. Cualquier ayuda sera bienvenida.Log4net: SysLog Appender Ejemplo
Respuesta
<appender name="UdpAppender" type="log4net.Appender.UdpAppender">
<param name="RemoteAddress" value="127.0.0.1" />
<param name="RemotePort" value="514" />
<layout type="log4net.Layout.PatternLayout, log4net">
<conversionPattern value="%-5level %logger [%property{NDC}] - %message%newline" />
</layout>
</appender>
lugar de utilizar el UDP appender de nivel inferior, podría intentar log4net.Appender.RemoteSyslogAppender. Puede encontrar un ejemplo en la entrada del blog Simon WhittemoreCentralised Application logging via Log4Net.
<appender name="RemoteSyslogAppender" type="log4net.Appender.RemoteSyslogAppender">
<layout type="log4net.Layout.PatternLayout" value="%date{dd/MM/yyyy hh:mm:ss,fff} | %thread | %level | %logger | %username | %P{log4net:HostName} | dev | %message | %exception | "/>
<remoteAddress value="LOGSERVER" />
<filter type="log4net.Filter.LevelRangeFilter">
<levelMin value="ALL" />
</filter>
</appender>
No he encontrado la entrada de Simon Whittemore muy útil, esto es lo que tiene mi appender producir "adecuados" mensajes remotos de registro del sistema:
<appender name="RemoteSyslogAppender" type="log4net.Appender.RemoteSyslogAppender">
<identity value="HepeManok" />
<layout type="log4net.Layout.PatternLayout" value="%-5p %type: %m%n"/>
<remoteAddress value="syslog.lameserver.net" />
</appender>
La "clave" [sic] es el identidad parámetro, que produce la salida correcta (o correcta) - Estoy usando rsyslog en Debian, YMMV.
definitivamente no necesita o desea enviar la fecha (como en el blog de Simon Whittemore), ya que syslogd agregará la fecha para usted, utilizando la zona horaria del servidor.
Aquí hay un mensaje recibido de mi log4net aplicación activada, seguido de un mensaje real:
Jun 21 09:58:40 vs2008.local HepeManok: INFO Irc: irc_OnConnected
Jun 21 09:42:45 chips30 kernel: [10210014.974069] device eth0 entered promiscuous mode
Como se puede ver, el formato básico de "Fecha Hora de host del servicio: mensaje" está todo bien, a diferencia de
Jun 21 09:38:57 WARN Irc [(null)] - OnQuit#015
o un ejemplo de lo que produciría configuración de Simon:
Jun 21 09:56:42 Hepe Manok.vshost.exe: 21/06/2012 07:54:44,828 | 6 | INFO | Irc | WIN-2008-DEV\Administrator | WIN-2008-DEV | dev | irc_OnConnecting | |
Excelente, gracias por mejorar mi respuesta! –
Tengo mis servidores iniciando sesión en un servidor ubuntu que ejecuta syslog-ng. Con el fin de obtener el nombre de host mostrando correctamente, he usado esto:
<appender name="RemoteSyslogAppender" type="log4net.Appender.RemoteSyslogAppender">
<facility value="local7" />
<identity value=" %date{yyyy-MM-ddTHH:mm:ss.ffffffzzz} %P{log4net:HostName} %P{app}" />
<RemoteAddress value="192.168.1.248" />
<layout type="log4net.Layout.PatternLayout" value="	%P{pid}:%logger %m%n"/>
<RemotePort value="516" />
</appender>
También podría dar syslog4net intentarlo. syslog4net funciona creando un diseño de log4net personalizado que escribe mensajes en RFC5424 standard format de Syslog. A continuación, puede conectarlo a cualquier apéndice log4net. Puede escribir fácilmente en un daemon de Syslog, splunk o cualquier agregador de datos de máquina conectando nuestra clase SyslogLayout con UdpAppender de log4net o TcpAppender personalizado de syslog4net.
La documentación, el uso y los ejemplos están disponibles en el sitio github del proyecto.
- 1. Logyser Syslog Appender
- 2. Log4net appender cuestión nombre
- 3. tema de depuración con logback syslog appender no actualizar syslog
- 4. Log4net - smtp appender no funciona
- 5. Log4net: Rolling appender Archivo, definir la extensión
- 6. hilos log4net + + rodando múltiples appender archivo
- 7. ¿Cuál es el appender más rápido para log4Net?
- 8. Log4net - conecta dinámicamente el appender entre AdoNetAppender y RollingFileAppender
- 9. ¿Puedo pasar argumentos a un constructor de Appender log4net personalizado?
- 10. pruebas log4net y nunit, el ejemplo más básico
- 11. ¿Existe el LogonNet Http Appender?
- 12. Appender diferente por método
- 13. Muy simple registro appender archivo no trabaja
- 14. Log4net: Múltiples madereros
- 15. Log4Net no puede encontrar el nombre de usuario% propiedad cuando nombro el archivo en mi appender
- 16. log4Net config transform
- 17. log4Net XmlHierarchyConfigurator
- 18. log4net MemoryAppender no funciona
- 19. Configurar Log4Net para no usar smtp appender si ejecuta una determinada máquina
- 20. log4net ADO.NET Appender funciona en Dev Fabric, pero falla silenciosamente en Azure
- 21. Log4Net performance
- 22. use log4net sin web.config
- 23. log4net un archivo por ejecución
- 24. Log4J Swing Appender
- 25. Configurar Log4net en aplicación web
- 26. Cómo rastrear los problemas de log4net
- 27. Log4net configurando programáticamente un adoAppender
- 28. Log4Net: Log con tiempos UTC
- 29. log4net no leerá desde app.config
- 30. inicialización de log4net
Solo para completar esta entrada: Syslog (http://en.wikipedia.org/wiki/Syslog) usa un puerto UDP asignado estándar 514 –