错误案例
现象描述:某天发布后,发现旺铺不能访问了;最后经过开发工程师和架构师一起的跟踪发现,原因是从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的原理可以参看:http://wangduowu.javaeye.com/blog/319297
正确用法
正确用法:
public class MyClass implements Serializable { //生成新的UID,eclipse既有这功能 private static final long serialVersionUID = - 6525971244576446994L; private String memberId; private Boolean flag;//新加的属性 …… }
UID重新生成后,反序列化就不成功,这时你的程序会走else的分支,一般是到数据库拿数据,再放入cache.
测试关注点
如果你的需求涉及到cache,一定要测试到cache已有数据的情况下,程序是否做到兼容。