0

我们正在缓存以下类格式的对象。

公共类 CachedObject {

@javax.persistence.Transient
public List<ObjectA> objectAs;

@javax.persistence.Transient
public Date cacheExpirationDate;

}

我们有一个进程检查缓存对象的过期日期并在过期之前刷新缓存。如果有任何更新,还有另一个进程也使用 replace (spymemcached) 方法更新缓存对象。在我们的情况下,更新通常发生在 objectAs 上。缓存的对象永远不会被驱逐。我们还使用默认的slab (1MB) 大小设置启动了memcached。

问题:当我们获取一些对象时,我们发现缓存对象不为空,但 objectAs 为空。我们随后在尝试对 objectAs 执行任何操作时遇到空指针异常。我检查过,我们总是在缓存/更新之前设置 objectAs 值。我还从 telnet 接口看到了不完整的缓存对象。当我刷新缓存时,它开始显示缓存中的完整对象。

有人可以建议可能出了什么问题吗?

4

1 回答 1

0

在运行了更多测试单元/集成后,我发现了一个将此字段设置为 null 的情况。所以我在问题中所说的问题与memcached缓存服务器无关。这是一个与应用程序相关的问题。

于 2013-02-18T00:04:34.497 回答