У меня есть «клиент» EJB
, который вызывает 4 Asynchronous
EJB
с и должен дать им все 5 секунд для запуска. Через 5 секунд «клиентский» EJB собирает результаты готовности из Future
объекта, который завершил работу, и возвращает вывод.
У меня проблема с "ожиданием" в клиентской части. Я пытался вызвать future.get(5, TimeUnit.MILLISECONDS)
Иногда кажется, что async EJB
s начинает работать после тайм-аута.
Есть ли правильный способ сделать это?
1) Соберите Future
объектов в Map
:
Map<String, Future> futureMap = new HashMap<String, Future>();
for (String userID: users) {
Future<Set<FrontPageData>> test = util.asyncGetData(userID);
futureMap.put(serviceID, test);
}
return futureMap;
2) Затем я получаю вывод с таймаутом от Future
объектов
final long now = Calendar.getInstance().getTimeInMillis();
final long end = now + TimeUnit.SECONDS.toMillis(5)
Map<String, Object> output = new HashMap<String, Object>();
Object data;
for (String userID: futureMap.keySet()) {
Future future= futureMap.get(userID);
try {
//check how much time left till the end
long timeout = end - Calendar.getInstance().getTimeInMillis();
data = future.get(timeout, TimeUnit.MILLISECONDS);
output.put(userID, data);
} catch (Exception e) {//write to logs
}
}
return output;
}
спасибо