利用Jactor提升日志系统的性能
2013-03-19 02:36
120 查看
在大型应用系统中,logger是必不可少的,但是在性能要求很高的多线程系统中,logger的I/O有时候成为性能杀手。我们简单的用一个例子说明,在10个线程中跑100次,每次记录1000行日志到文件中,
代码如下:
结果如下
显然,对我们的性能产生很大的影响。下面让我们看看Jactor怎么帮我们优化性能,我们把log4j的日志加入jactor,而logback保留不变
再看测试结果
可以看到testJactor所需要的I/O完全被分离出来了,不再影响我们的核心代码运行。 阅读更多
代码如下:
@Test(invocationCount=100,threadPoolSize=10)
public void testLog4j()
{
for(int i=0;i<1000;i++)
logger.info("log4j I am ok "+i+" at thread"+Thread.currentThread().getId());
}
@Test(invocationCount=100,threadPoolSize=10)
public void testLogback(){
for(int i=0;i<1000;i++)
logback.info("logba I am ok "+i+" at thread"+Thread.currentThread().getId());
}
结果如下
显然,对我们的性能产生很大的影响。下面让我们看看Jactor怎么帮我们优化性能,我们把log4j的日志加入jactor,而logback保留不变
@Test(invocationCount = 100, threadPoolSize = 10)
public void testJactor() throws Exception {
for (int i = 0; i < 1000; i++) {
jactorLogger.log("actor I am ok " + i + " at thread" + Thread.currentThread().getId());
}
}
@Test(invocationCount = 100, threadPoolSize = 10)
public void testLogback() {
for (int i = 0; i < 1000; i++)
logback.info("logba I am ok " + i + " at thread" + Thread.currentThread().getId());
}
再看测试结果
可以看到testJactor所需要的I/O完全被分离出来了,不再影响我们的核心代码运行。 阅读更多
相关文章推荐
- 通过log4j日志异步化大幅提升系统性能
- log4j日志异步化大幅提升系统性能
- 利用Alluxio系统提升按需数据分析服务的性能
- log4j【5】( log4j日志异步化大幅提升系统性能 )
- log4j日志异步化大幅提升系统性能
- 小记:利用单例模式的提升系统整体性能 推荐
- log4j日志异步化大幅提升系统性能
- log4j日志异步化大幅提升系统性能
- log4j日志异步化大幅提升系统性能
- 利用Python入库性能日志到MySQL
- 利用开源架构ELK构建分布式日志系统
- 利用原生js提升jquery选择器的性能
- centos7利用ssd固态盘作为缓存盘提升磁盘IO性能
- OLTP系统的Oracle RAC性能调优,索引分区极大提升提交性能
- linux系统初始化--提升网络可用性或性能(双网卡捆绑)
- 如何提升系统整体性能
- KAOII 系统性能提升的始末之(一)spring 配置 proxool 数据源
- Windows 7系统开启AHCI 提升硬盘性能
- 应用OSCache提升J2EE系统运行性能
- 性能优化(一)Hibernate 利用缓存(一级、二级、查询)提高系统性能