使用日志可能会让你的应用性能降低20% —— 很难相信吧,可是倒是真的可能。java
本文讨论一些尽量提高日志性能的方法,
2 关键设置缓存
这里经过Junit,使用不一样的Log4j配置来测试。下面会展现测试结果。实际上影响log4j性能的最主要因素有三:网络
immediateFlush
bufferedIO
asycAppender
测试的结果可能和你想的不同。好比,使用asyncAppender会下降本地日志文件的写入性能;bufferedIO不怎么样影响性能除非日志特别多;immediateFlush设为false几乎可使写入时间减半。怎么回事呢?咱们来看!异步
3 就是缓存async
上面三个都是使用缓存,他们分三级。第一级, immediateFlush=false
会开启 java.io.Writer/java.io.OutputStreamWriter
的缓存,消息到达后会缓存最长1024字节。第二级 bufferedIO=true
会把 java.io.Writer
包装成 java.io.BufferedWriter
,缓存默认大小是 1024*8 字节。第三级是 asyncAppender
,会缓存Log4j事件,默认是128条。
通常地,输出流在使用的时候其余写入会被阻塞。使用缓存后能够减小这种阻塞。可是若是原本就没有阻塞(好比在写入本地日志的时候),使用缓存反而会延迟写入。这样讲的话,使用缓存反而没提高性能。因此性能调优要看状况:你使用的是本地日志仍是远程日志,什么会形成资源竞争。性能
4 测试结果测试
这个测试很简单,使用log4j输出2560行,看看不一样的配置使用的时间如何。咱们考察上面的三个因素:
每一个相同的测试咱们跑了三次。前三行结果是log4j的默认配置:同步+无缓存+当即刷入。第一条结果是157毫秒,咱们忽略它,由于它和后两条(63毫秒,62毫秒)差距太大。
接下来三行 (63, 63, 62 milliseconds) 开启了缓存可是仍是当即刷入。你可能想到这没用,当即刷入让缓存无用武之地。因此结果和前面一致仍是60多毫秒。
而后咱们看开启缓存后不当即刷入,也就是 immediateFlush=false
,结果是(31, 32, 31 milliseconds)。差很少是前面的一半,好厉害!
若是关闭缓存不当即刷入呢?这个和上面结果同样。
接下来看异步日志。咱们关闭缓存而且当即刷入,结果是 (78, 78, 94 milliseconds)。异步日志没有改善性能,反而下降了咱们的性能。
最后,咱们使用异步日志结合缓存打开、不当即刷入,结果是 (63, 47, 47 milliseconds) ,依然没有同步的效果好。
恩?咋回事呢?spa
5 总结3d
Log4j性能建议 |
本地日志:
|