错误案例
现象描述:某天发布后,发现旺铺不能访问了;最后经过开发工程师和架构师一起的跟踪发现,原因是从cache取出来的member对象对应的旺铺标志没有了。
是否拥有旺铺的标志是存放到member表multi_sign的一个字段中
错误分析
现在我们使用cache的地方有很多了,一般放入cache的value都是经过序列化的对象,万一哪天有个需求,需要修改一下这个对象,增加一个属性,而你忘记更新serialVersionUID,灾难来临了。
public class MyClass implements Serializable {
private static final long serialVersionUID = -6849794470754667710L;
private String memberId;
……
}
经过需求增加了一个属性flag
public class MyClass implements Serializable {
//增加属性后
private static final long serialVersionUID = -6849794470754667710L;
private String memberId;
private Boolean flag;//增加了属性
……
}
增加属性后,UID没有变化,导致已有cache的数据还可以反序列化成功,但是flag字段赋值是空的,导致程序异常。 serialVersionUID的原理可以参看:https://blog.csdn.net/daobuxinzi/article/details/115073854
正确用法
正确用法:
public class MyClass implements Serializable {
//生成新的UID,eclipse既有这功能
private static final long serialVersionUID = - 6525971244576446994L;
private String memberId;
private Boolean flag;//新加的属性
……
}
UID重新生成后,反序列化就不成功,这时你的程序会走else的分支,一般是到数据库拿数据,再放入cache.
测试关注点
如果你的需求涉及到cache,一定要测试到cache已有数据的情况下,程序是否做到兼容。
原文链接:https://blog.csdn.net/Rubenyu/article/details/6591808