Log4j2的Appenders充分考虑输出日志事件、包装和过滤可以被转发,它包含的主要输出到本地文件、输出到远程主机,

文件包、注射。而且,根据该日志文件的时间点、自己主动文件大小的储存条件。

例如,要记录多个不同来源汇集,您可以使用FlumeAppender。想要在LogEvent中注入信息。

能够用RewriteAppender。想要让系统依照设定的时间间隔自己主动封存日志信息。能够用RollingFileAppender

(每隔一定时间自己主动保存一份新增的日志文件,并依照时间戳等指定格式命名);当产生安全级别达ERROR或FATAL的LogEvent时。

给维护人员发送邮件可用SMTPAppender。希望将日志信息写到远程主机的,可用SocketAppender;希望可以依照RFC5424格式向远程主机发送日志信息,

可用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=debug
Logger=com.herman.log4j2.test.Test2 Level=INFO Message=info
Logger=com.herman.log4j2.test.Test2 Level=WARN Message=warn
Logger=com.herman.log4j2.test.Test2 Level=ERROR Message=error
Logger=com.herman.log4j2.test.Test2 Level=FATAL Message=fatal
Logger=com.herman.log4j2.test.Test2 Level=DEBUG Message=debug
Logger=com.herman.log4j2.test.Test2 Level=INFO Message=info
Logger=com.herman.log4j2.test.Test2 Level=WARN Message=warn
Logger=com.herman.log4j2.test.Test2 Level=ERROR Message=error
Logger=com.herman.log4j2.test.Test2 Level=FATAL Message=fatal

欢迎大家关注我的个人博客!

!!!

如有不懂,疑问或者欠妥的地方。请加QQ群:135430763   进行反馈,共同学习!

版权声明:本文博客原创文章,博客,未经同意,不得转载。

最新文章

  1. Java学习笔记 01 基本数据类型、标识符、关键字和运算符
  2. OpenGL学习——基本概念和坐标变换
  3. 应该知道的25个非常有用的CSS技巧
  4. Android应用开发中关于this.context=context的理解
  5. python专题-异常处理(基础)
  6. Algorithm --&gt; 求阶乘末尾0的个数
  7. jQuery使用(十):jQuery实例方法之位置、坐标、图形(BOM)
  8. Django_简介
  9. 成功使Linux服务端和Windows客户端建立socket通信
  10. mysql thread pool
  11. linux环境下mongodb启动操作
  12. B树,B+树,B*树以及R树的介绍
  13. php字符串的拆分截取
  14. unity, particle system Emit from Edge
  15. rs.getMetadata
  16. linux -- Ubuntu 安装搜狗输入法
  17. php多语言截取字符串函数
  18. ubuntu12.04(64位)下安装Adobe Flash Player
  19. ODPS基础
  20. threejs的学习笔记

热门文章

  1. Netty In Action中国版 - 第二章:第一Netty程序
  2. cocos2D(八)---- CCMenu &amp;amp;&amp;amp; CCMenuItem
  3. 在struts2中訪问servletAPI
  4. strchr,wcschr 和strrchr, wcsrchr,_tcschr,_tcsrchr功能
  5. A. Initial Bet(Codeforces Round #273)
  6. Redis c/c++, java client连接
  7. 改动symbol link的owner
  8. android生成apk包出现Unable to add &amp;quot;XXX&amp;quot; Zip add failed问题
  9. hdu1506——Largest Rectangle in a Histogram
  10. ios 多线程开发(一)简介