可用SyslogAppender等等。
SocketAppender
将log event输出到一个远程server上(需指定server名和port号),数据能够以随意指定的格式经由TCP或UDP协议发送。 SocketAppender中比較重要的參数有: ⑴ host,String。指定server的主机名。(必需) ⑵ immediateFlush,boolean,是否马上flush。还是等待缓存到一定大小后在flush。 ⑶ layout。Layout,log event输出的格式。 ⑷ port。integer,远程server坚挺log event的应用的端口号。 ⑸ protocol,String,发送log event所使用的协议。"TCP" 或"UDP"。 ⑹ reconnectionDelay,integer,当连接断开时,延迟等待的ms数。 ⑺ name,String 。Appender的名称。 ⑻ protocol,String,通讯协议 默认TCP。可选值 "TCP" (default), "SSL" or "UDP".
⑼ SSL。SslConfiguration,包括密钥存储库和信任存储库的配置. ⑽ filter,Filter。一个过滤器来确定事件应该由这个Appender。 不止一个过滤器 能够通过使用一个CompositeFilter。 ⑾ immediateFail。boolean,设置为true时,日志事件不会等待尝试又一次连接,将马上假设失败 套接字是不可用的。 ⑿ immediateFlush,boolean。 当该值设置成真时,默认情况下,每一个写将冲洗。这将保证写的数据 到磁盘,但可能会影响性能。
⒀ layout,Layout,LogEvent ,布局使用格式。 缺省值是SerializedLayout。 ⒁ reconnectionDelay。integer ,假设设置为值大于0,一个错误后SocketManager将尝试又一次连接 在指定的毫秒数后的server。 假设连接失败 将抛出一个异常(能够被应用程序假设ignoreExceptions是 设置为假)。 ⒂ ignoreExceptions。boolean,默认值是真正的加入事件时,遇到了引起异常 内部记录,然后忽略。 当设置为假将传播到异常 调用者。你必须设置这个假当包装这个AppenderFailoverAppender。
日志server代码(main方法):
package com.herman.log4j2.server;import java.io.IOException;import java.net.ServerSocket;import java.net.Socket;public class TestServer { public static void main(String[] args) throws IOException { ServerSocket socket = new ServerSocket(5000); while (true) { Socket client = socket.accept(); Thread t = new Thread(new LogRunner(client)); t.start(); } }}日志服务器代码(Runnable线程):
package com.herman.log4j2.server;import java.io.IOException;import java.io.InterruptedIOException;import java.io.ObjectInputStream;import java.net.Socket;public class LogRunner implements Runnable{ private ObjectInputStream ois; public LogRunner(Socket client) { try { this.ois = new ObjectInputStream(client.getInputStream()); } catch (Exception e) { e.printStackTrace(); } } public void run() { try { while (true) { Object obj= ois.readObject(); System.out.println(obj.toString()); } } catch(java.io.EOFException e) { //读取的时候到达尾端抛出的异常,屏蔽掉 } catch(java.net.SocketException e) { } catch(InterruptedIOException e) { Thread.currentThread().interrupt(); } catch(IOException e) { } catch (Exception e) { e.printStackTrace(); } finally { } }}客户端xml配置(log4j2.xml):
xml version="1.0" encoding="UTF-8"?> <Configuration> <!-- Appenders 输出目的地 --> <Appenders> <!-- 配置日志输出文件名称字 追加读写 host地址 端口 --> <Socket name="A1" host="localHost" port="5000"> <!-- 输出格式 序列布局--> <SerializedLayout/> </Socket> <!-- 控制台输出 --> <Console name="STDOUT" target="SYSTEM_OUT"> <!-- 输出格式 布局--> <PatternLayout pattern="%d %-5p [%t] %C{2} (%F:%L) - %m%n"/> </Console> </Appenders> <Loggers> <!-- debug级别 --> <Root level="debug"> <AppenderRef ref="A1"/> <AppenderRef ref="STDOUT"/> </Root> </Loggers> </Configuration>
客户端測试代码:package com.herman.log4j2.test;import org.apache.logging.log4j.LogManager;import org.apache.logging.log4j.Logger;/** * @see log4j 2.0 简单的配置使用一个文件Appender * @author Herman.Xiong * @date 2014年7月21日 14:32:55 */public class Test2 { /** * 配置日志级别为debug,输出位置为控制台和文件 */ private static Logger log = LogManager.getLogger(Test2.class); public static void main(String[] args) { log.trace("trace"); log.debug("debug"); log.info("info"); log.warn("warn"); log.error("error"); log.fatal("fatal"); log.trace("trace"); log.debug("debug"); log.info("info"); log.warn("warn"); log.error("error"); log.fatal("fatal"); log.exit(); }}输出效果:
Logger=com.herman.log4j2.test.Test2 Level=DEBUG Message=debugLogger=com.herman.log4j2.test.Test2 Level=INFO Message=infoLogger=com.herman.log4j2.test.Test2 Level=WARN Message=warnLogger=com.herman.log4j2.test.Test2 Level=ERROR Message=errorLogger=com.herman.log4j2.test.Test2 Level=FATAL Message=fatalLogger=com.herman.log4j2.test.Test2 Level=DEBUG Message=debugLogger=com.herman.log4j2.test.Test2 Level=INFO Message=infoLogger=com.herman.log4j2.test.Test2 Level=WARN Message=warnLogger=com.herman.log4j2.test.Test2 Level=ERROR Message=errorLogger=com.herman.log4j2.test.Test2 Level=FATAL Message=fatal欢迎大家关注我的个人博客!
!!!
如有不懂,疑问或者欠妥的地方。请加QQ群:135430763 进行反馈,共同学习!
版权声明:本文博客原创文章,博客,未经同意,不得转载。