我有两个应用程序: Application1使用Kryo序列化程序序列化have对象,application2反序列化由application1保存在外部存储上的kryo序列化byte[]。
Application1的类路径中有kryo-shaded-3.0.3.jar,而application2的类路径中有kryo-shaded-4.0.1。
当application2试图反序列化byte[]时,它得到了一个异常: kryo无法使用kryo的类加载器加载类,正在使用current重试。
当我在application1中更改kryo的版本时,也是kryo-shaded-4.0.1。它工作得很好。当序列化程序有不同的版本时为什么会有问题。谁设置了kryo类加载器?
发布于 2018-02-14 12:05:13
当序列化程序有不同的版本时,为什么会有问题?
当Kryo将数据序列化为字节数组时,它会将对象的内容打包成特定的格式。Kryo将数据打包成字节数组的确切方式因Kryo的不同版本而异。因此,如果使用版本3.0.3序列化数据,则格式将与版本4.0.1预期的格式不同。因此,如果您以接收者不理解的格式向接收者发送字节,就不能期望接收者正确地处理数据。
谁设置了kryo类加载器?
我不确定Kryo的内部结构,但我认为它可能使用与默认情况下运行代码的线程相同的类加载器。如果你愿意,你可以设置一个替代的类加载器,但是你必须检查文档。
您观察到的kryo unable to load class with Kryo's classloader retrying with current异常很可能是因为接收器误读了发送给他的字节数组。例如,如果发送方发送了一个内容为com.my.class.TestXXXXXXX的字节数组,其中类名在开头,但接收方希望类名在末尾,并将类名读取为XXXXXXX。然后Kryo将使用类加载器来查找类XXXXXXX,但他将失败,因为没有类XXXXXXX。为什么接收器上的Kryo首先需要查找类?因为他需要实例化您发送的对象,为此,他需要调用对象的Class的no-arg构造函数。
https://stackoverflow.com/questions/48777270
复制相似问题