Как использовать несколько экземпляров bean с сохранением состояния? - PullRequest
0 голосов
/ 19 мая 2011

У меня есть следующая проблема в школьном проекте.

  1. Все многочисленные автомобили отправляют свои данные о местоположении в веб-службу без сохранения состояния, которая сбрасывает их в очередь сообщений Java.
  2. Thisочередь обрабатывается компонентом, управляемым сообщениями, который вычисляет некоторые вещи и отправляет их в кеш.
  3. Этот кеш / буфер должен содержать набор меньших объектов буфера для каждой машины и периодически очищать каждый буфер, посылаявещи для этой машины в другую систему.

У меня много трудностей с шагом 3. Моей первой мыслью было бы создать экземпляр бина с состоянием для каждой машины, чтобы каждая машина вСистема может содержать несколько из них.Одиночный боб будет отслеживать буферы для всех автомобилей.Надеемся, что это сохранит масштабируемость.

Хотя это не так, как кажется, все указывает на инъекцию и соотношение 1-1 между клиентами и компонентами с состоянием, в то время как мне, кажется, нужен 1-многие отношения.

После некоторых исследований я обнаружил, что онлайновая информация о подобных сценариях в лучшем случае расплывчата, а в худшем - неактуальна.Моя книга «Начинаю платформу Java EE 6 с Glassfish 3», похоже, вообще не касается этого.Я связался с моим учителем, но он еще не ответил, и я сомневаюсь, что он на самом деле много знает об этом.

Я не хочу использовать базу данных, потому что вещи действительно не нужны (и не должны't!) храниться дольше, чем это абсолютно необходимо.

Может быть, я упускаю какую-то фундаментальную концепцию, или, может быть, я просто обдумываю вещи и мне нужен совершенно другой подход.Мой вопрос: как бы вы справились с этим типом проблемы в этой среде?Я использую Glassfish 3.0.1.

Ответы [ 2 ]

0 голосов
/ 23 мая 2011

я думаю, что вы что-то упустили для реализации кэша. Вы можете использовать простой HashSet для кэширования ваших данных. Или вы можете использовать существующую структуру кеша, такую ​​как memcache (google cache), которая очень эффективна. см Memcache Если вы хотите периодически очищать кеш, вы можете использовать java.util Таймер класса.

0 голосов
/ 19 мая 2011

Зачем использовать сессионные компоненты с состоянием (нужно)?Я написал бы другой StatelessSessionBean, который может возвращать значения из вашего кэша, а затем обернуть его другим веб-сервисом.

...