Модераторы: LSD, AntonSaburov
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Нужна критика архитектуры приложения 
:(
    Опции темы
danilych
Дата 17.5.2011, 09:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 72
Регистрация: 2.2.2011

Репутация: 3
Всего: 3



Не имею большого опыта в проектировании, поэтому буду благодарен за критику...

Речь идет о web приложении. Есть несколько сайтов (назову их донорами), с которых мое приложение должно собирать однотипную информацию, которая передается посредством xml. Пользователи моего приложения должны получать собранную информацию одним запросом. Информация на сайтах-донорах может обновляться несколько раз в день. Пользователи моего сайта только читают информацию из базы или из кеша.

Придумал следующее решение, но не уверен до конца в его праве на жизнь:

Хочу создать класс, который бы обращался к сайтам-донорам, получал от них информацию, парсил ее и сохранял в БД, работать он должен по таймеру либо буду использовать quartz (http://www.quartz-scheduler.org/). Т.к. пользователи сайта только читают информацию, то хочу создать своего рода кеш по шаблону синглтон. Кеш будет обновляться только после того, как мой класс-парсер заметит, что информация на каком-либо сайте-доноре обновилась, реализовать обновление кеша планирую по шаблону наблюдатель. 

Я понимаю, что могут возникнуть проблемы с синхронизацией, когда пользователь будет читать информацию из кеша, а класс-парсер будет ее обновлять, но планирую сделать так, чтобы класс-парсер дожидался ставил блокировку на кеш и дожидался пока пользователь не дочитает ее. Пользователь же, если увидит, что кеш залочен, обратится напрямую в БД. Под пользователем я подразумеваю сервлет-обработчик запроса.

Можно ли таким образом реализовать мое приложение или есть более удачные решения.
PM MAIL   Вверх
MisterCleric
Дата 17.5.2011, 10:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1043
Регистрация: 16.2.2006
Где: Харьков, Украина

Репутация: 5
Всего: 38



Привет. Зачем лазит в БД, если пользователь просто читает инфу?
Поставь модификатор voletile на твоем проперти с инфой, и разные потоки всегда будут получать актуальную.


--------------------
ПРИШЕЛ, УВИДЕЛ - ПЕРЕПИСАЛ...
PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
javastic
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux, javastic.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Java: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0617 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.