JBossCache'Malagueta'3.2.0.GAを使用しています
本番環境で奇妙な問題に直面しました。jbossキャッシュへの書き込みが正しく機能しない場合があります。簡単なJavaアプリケーションでこの状況を再現しようとしました
public static void testCache() {
Cache cache = new DefaultCacheFactory().createCache(false);
cache.create();
cache.start();
final Node node = cache.getRoot().addChild(Fqn.fromString("/child1"));
int threadsCount = 20;
final CyclicBarrier b = new CyclicBarrier(threadsCount);
for (int i = 0; i < threadsCount; i++) {
final long j = i;
new Thread(new Runnable() {
@Override
public void run() {
try {
b.await();
String name = RandomGenerator.getRandomName(4);
node.put(j, name);
String nameFromCache = (String) node.get(j);
if (!name.equals(nameFromCache)) {
System.out.println("error");
}
} catch (Exception e) {
e.printStackTrace();
}
}
}).start();
}
}
時々、このテストは「エラー」を出力しますが、これはstatic void main
失敗から実行されます。3回の実行のうち1回は、「エラー」メッセージを返します。単にnullを返します。すべてのマシンで再現できるわけではありません。
どんな手掛かり ?