【问题标题】:Kryo vs Jackson克里奥 VS 杰克逊
【发布时间】:2014-09-22 11:30:20
【问题描述】:

我正在检查 Java 序列化、Kryo 和 Jackson。

我创建了一些将随机对象序列化 N 次的小代码。我测量序列化和反序列化的时间以及对象的大小。

我对 Kryo 与 Jackson 的大小不太满意,我一直在阅读有关基准的信息,人们在 Kryo 和 Jackson 之间有很大的不同,但是,我在 Kryo 中得到的结果只减少了大约 5-10%。我不知道我是否遗漏了代码中的某些内容。

这是我的 Kryo 代码:

public static byte[] writeAsBytes(final Object oObject) {

        ByteArrayOutputStream bos = new ByteArrayOutputStream();
        Output output = new Output(bos);
        kryo2.register(Event.class, 0);
        kryo2.writeClassAndObject(output, oObject);
        output.close();
        return bos.toByteArray();
    }


    public static <T> T read(final byte[] aObject, final Class<T> clazz) {
        T oObject;
        ByteArrayInputStream is = new ByteArrayInputStream(aObject);
        Input input = new Input(is);
        kryo2.register(clazz, 0);
        oObject = (T) kryo2.readClassAndObject(input);
        input.close();

        return oObject;
    }

我尝试注册对象并且没有注册,我得到相同的大小并且时间也相似。

我怎样才能使用 Kryo 提高尺寸?我得到的尺寸和次数:

Size java:5245
Size jackson:5076
Size kryo:4790
14/09/22 12:18:05 INFO util.TimerUtil: DesSerializar Jackson:25135ms,Counter:10001
14/09/22 12:18:05 INFO util.TimerUtil: DesSerializar Java:2637ms,Counter:10001
14/09/22 12:18:05 INFO util.TimerUtil: DesSerializar Kryo:396ms,Counter:10001
14/09/22 12:18:05 INFO util.TimerUtil: Serializar Jackson:985ms,Counter:10001
14/09/22 12:18:05 INFO util.TimerUtil: Serializar Java:1171ms,Counter:10001
14/09/22 12:18:05 INFO util.TimerUtil: Serializar Kryo:397ms,Counter:10001

我执行了很多次代码,我对 Jackson 的反序列化时间感到惊讶,25000 毫秒???

【问题讨论】:

  • 请包括类定义:如果不知道您正在处理的对象类型,您的问题就毫无意义。例如:如果大部分数据只是Strings,大小(和性能)差异应该很小。对于浮点数等其他数据类型,差异可能会增加。对于性能基准测试,你真的应该看看像jmh 这样的工具来获得可靠的数字。对于 Jackson 反序列化,测试代码本身不仅需要做预热(jmh 可以做到),还要确保始终重用 ObjectMapper 实例。
  • 如果你在对象中有一些字符串,它不会有太大的不同,但是 kryo 有一些压缩支持。你为什么想知道慢杰克逊?它在 json 中序列化,基于文本的序列化总是比二进制慢得多
  • @MarianP 取决于“慢得多”的定义;通常速度会收敛到编码大小的差异;这意味着二进制格式可能快两倍。但实施差异意味着差异很大。

标签: java json serialization jackson kryo


【解决方案1】:

尝试使用kryo.readObject(arg0, arg1) 而不是kryo.readClassAndObject(input); 它可以更有效地在Java 中序列化对象。

【讨论】:

  • 我很好奇结果如何。也许我会试试看。
猜你喜欢
  • 2011-01-23
  • 2017-06-27
  • 2011-08-25
  • 2020-04-12
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多