サーバーログに、追跡するのが難しいエラーがまれに見られます。このような例外が発生するのではないかと思っているので、コードの何が原因でそれが発生したかを特定できますか? 残念ながら、再現する手順がないため、コード内のどの呼び出しが原因であるかを特定できません。
java.lang.ClassCastException: net.spy.memcached.MemcachedClient$5 cannot be cast to net.spy.memcached.ops.GetOperation$Callback
at net.spy.memcached.protocol.ProxyCallback.addCallbacks(ProxyCallback.java:25)
at net.spy.memcached.protocol.binary.OptimizedGetImpl.addOperation(OptimizedGetImpl.java:28)
at net.spy.memcached.protocol.binary.OptimizedGetImpl.<init>(OptimizedGetImpl.java:21)
at net.spy.memcached.protocol.binary.BinaryMemcachedNodeImpl.optimizeGets(BinaryMemcachedNodeImpl.java:46)
at net.spy.memcached.protocol.binary.BinaryMemcachedNodeImpl.optimize(BinaryMemcachedNodeImpl.java:35)
at net.spy.memcached.protocol.TCPMemcachedNodeImpl.fillWriteBuffer(TCPMemcachedNodeImpl.java:177)
at net.spy.memcached.MemcachedConnection.handleWrites(MemcachedConnection.java:374)
at net.spy.memcached.MemcachedConnection.handleIO(MemcachedConnection.java:326)
at net.spy.memcached.MemcachedConnection.handleIO(MemcachedConnection.java:219)
at net.spy.memcached.MemcachedClient.run(MemcachedClient.java:1591)
更新:これは私の側の問題のあるコードであると確信しています:
Future<CASValue<Object>> profiles;
String userID = "OBFUSCATED";
profiles = memClient.asyncGets("PROFILES_" + userID);
そして、spy memcached で実行する必要があります。
public <T> OperationFuture<CASValue<T>> asyncGets(final String key,
final Transcoder<T> tc) {
final CountDownLatch latch = new CountDownLatch(1);
final OperationFuture<CASValue<T>> rv =
new OperationFuture<CASValue<T>>(key, latch, operationTimeout);
Operation op = opFact.gets(key, new GetsOperation.Callback() {
private CASValue<T> val = null;
public void receivedStatus(OperationStatus status) {
rv.set(val, status);
}
public void gotData(String k, int flags, long cas, byte[] data) {
assert key.equals(k) : "Wrong key returned";
assert cas > 0 : "CAS was less than zero: " + cas;
val =
new CASValue<T>(cas, tc.decode(new CachedData(flags, data,
tc.getMaxSize())));
}
public void complete() {
latch.countDown();
}
});
rv.setOperation(op);
addOp(key, op);
return rv;
}
すべてが順調に進んでいるように見えます。正しいインターフェースの匿名実装が後で最適化されるキューに入れられます。問題が発生している場所がわかりません。