Msgpack是按字段顺序进行序列化和反序列化的,优点是速度快,缺点是无法改变字段顺序。
因此,在两边不同时升级的情况下,字段兼容规则如下:(包括Bean和枚举)
- 不要调整原有字段顺序,不能删减字段,除非是删最后一个字段。
- 新加的字段必须在字段最后面(只是字段顺序,不是文件最后面,getter/setter方法等随意)。
- 父类的字段不能变。因为父类一变相当于子类的中间插入一个字段。
满足上面规则,服务端和客户端哪边先升级都无所谓。
如果是需要父类加字段,或者中间加减字段这种,则需要服务端和调用端同时升级。