posts - 36, comments - 419, trackbacks - 0, articles - 0
  BlogJava :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理

几种常用JSON库的性能测试。

Posted on 2010-03-11 18:00 BearRui(AK-47) 阅读(6199) 评论(3)  编辑  收藏 所属分类: Java
随着AJAX的火热应用,JSON也越来越被重视,随之而来的就是众多的JSON库,下面对常用的3个JSON库(json-lib,jackson,gson)进行性能测试,看下结果如何:

一. 测试环境
该测试只是在本人电脑上进行测试,每次测试前都重启tomcat,清空缓存,日志等。开的程序也一样,3次测试测试环境相差无几。
json-lib版本:json-lib-2.3-jdk15(最新)
jackson版本 : 1.4.3(最新)
gson : 1.4 (最新)
测试工具:apache带的ab工具

  二. 测试代码
       
1.先定义用于序列化成JSON的Bean,其中字段longTime需要在序列化的过程中被忽略,不输出:
JsonEntity

       2. 因json-lib不能直接设置日期的转换方式,需要写1个Processor的类
DateJsonValueProcessor

       3. 写1个辅助类JsonTestFactory:
public class JsonTestFactory {
    
static JsonConfig jc;
    
static Gson gson;
    
static ObjectMapper mapper;

    
public static ObjectMapper getMapper(){
        
if(mapper == null){
            mapper 
= new ObjectMapper();
            SerializationConfig sc 
= mapper.getSerializationConfig();
            sc.setDateFormat(
new SimpleDateFormat("yyyy-MM-dd"));
            mapper.setSerializationConfig(sc);
        }
        
return mapper;
    }

    
public static Gson getGson(){
        
if(gson == null){
            GsonBuilder gb 
= new GsonBuilder();
            gb.setDateFormat(
"yyyy-MM-dd");
            gb.excludeFieldsWithoutExposeAnnotation();
            gson 
= gb.create();
        }
        
return gson;
    }

    
public static JsonConfig getJsonConfig() {
        
if(jc==null){
            jc 
= new JsonConfig();
            jc.registerJsonValueProcessor(Date.
classnew DateJsonValueProcessor("yyyy-MM-dd"));
            jc.registerPropertyExclusion(JsonEntity.
class,"longTime");
        }
        
return jc;
    }
}

      4、下面是4个JSP页面的代码,json-lib使用了2种不同的方式进行测试:
           jsonlib1.jsp 代码:
            
JsonEntity je 
= new JsonEntity(1);
            
out.println(JSONSerializer.toJSON(je,entity.JsonTestFactory.getJsonConfig()).toString());
%>]]>

          jsonlib2.jsp 代码:

            DateFormat dateFormat 
= new SimpleDateFormat("yyyy-MM-dd");
            JSONObject json 
= new JSONObject();
            JsonEntity je 
= new JsonEntity(1);
            json.element(
"id", je.getId());
            json.element(
"name", je.getName());
            json.element(
"money", je.getMoney());
            json.element(
"date", dateFormat.format(je.getDate()));
            out.println(json.toString());
        
%>]]>

          jackson,jsp

            JsonEntity je 
= new JsonEntity(1);
            out.println(entity.JsonTestFactory.getMapper().writeValueAsString(je));
        
%>]]>

         gson.jsp

            JsonEntity je 
= new JsonEntity(1);
            out.println(entity.JsonTestFactory.getGson().toJson(je));
        
%>]]>

三、测试结果
       测试结果中只需关注Requests per second(平均每秒处理的请求数),Time per request(平均每个请求处理的时间)

1、ab 测试条件: 发送5000个请求,并发数为10。

  jsonlib1.jspjsonlib2.jsp jackson.jsp gson.jsp 
 Concurrency Level 10 10 10 10
 Time taken for tests 3.016 seconds 3.078 seconds 2.859 seconds 3.234 seconds
 Complete requests 5000 5000 5000 5000
 Requests per second 1658.03 [#/sec] 1624.37 [#/sec] 1748.63 [#/sec] 1545.89 [#/sec]
 Time per request 6.031 [ms] 6.156 [ms] 5.719 [ms] 6.469 [ms]

1、ab 测试条件: 发送30000个请求,并发数为50。

  jsonlib1.jspjsonlib2.jsp jackson.jsp gson.jsp 
 Concurrency Level 50 50 10 10
 Time taken for tests11.359 seconds 12.047 seconds 10.922 seconds 13.391 seconds
 Complete requests 30000 30000 30000 30000
 Requests per second 2640.99 [#/sec] 2490.27 [#/sec] 2746.78 [#/sec] 2240.37 [#/sec]
 Time per request 18.932 [ms]20.078 [ms] 18.203 [ms] 22.318 [ms]


google的gson传说性能比较好,不知道为什么这次测试性能这么有问题。jackson的还是非常不错的。

[作者]:BearRui(AK-47)
[博客]: http://www.blogjava.net/bearrui/
[声明]:本博所有文章版权归作者所有(除特殊说明以外),转载请注明出处.
英雄,别走啊,帮哥评论下:  

精彩推荐 好文要顶 水平一般 看不懂 还需努力

评论

# re: 几种常用JSON库的性能测试。  回复  更多评论   

2010-03-12 12:04 by BearRui(AK-47)
@凡客诚品官方网站
没看明白你的意思?

# re: 几种常用JSON库的性能测试。  回复  更多评论   

2010-04-06 22:33 by airfan
这种测法大头都给http连接和输入输出了,json序列化本身开销忽略不计,测个毛

# re: 几种常用JSON库的性能测试。  回复  更多评论   

2013-09-24 15:35 by adsf
没有思考为什么这样

只有注册用户登录后才能发表评论。


网站导航: