Msgpack是按字段顺序进行序列化和反序列化的,优点是速度快,缺点是无法改变字段顺序。

因此,在两边不同时升级的情况下,字段兼容规则如下:(包括Bean和枚举)

  1. 不要调整原有字段顺序,不能删减字段,除非是删最后一个字段。
  2. 新加的字段必须在字段最后面(只是字段顺序,不是文件最后面,getter/setter方法等随意)。
  3. 父类的字段不能变。因为父类一变相当于子类的中间插入一个字段。

满足上面规则,服务端和客户端哪边先升级都无所谓。

如果是需要父类加字段,或者中间加减字段这种,则需要服务端和调用端同时升级

posted on 2019-10-29 09:46  vow007  阅读(9)  评论(0编辑  收藏  举报  来源