powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / Java [игнор отключен] [закрыт для гостей] / Страницы сайта обновляются раз в несколько минут. Как закешировать?
15 сообщений из 15, страница 1 из 1
Страницы сайта обновляются раз в несколько минут. Как закешировать?
    #34064582
Vetal
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Всем привет!

Написал сайт на java. Сайт информационный и практически все страницы сайта меняют свое содержимое раз в две минуты, потому что вся информация берется из базы, а в базу данные заливаются раз в две минуты. Интерактивности с пользователем практически нет (пользователь почти нигде не заполняет формы)

Проблема в том, что для отображения каждой страницы необходимо выполнить несколько десятков запросов к базе данных. В итоге каждая страница грузится секунд по десять. И это еще не предел, так как каждый день объем данных растет.

Можно ли как-то закешировать страницы, чтобы когда пользователь вводит адрес страницы, то страницы отдавались пользователю из кеша, а java обновляла кеш только раз в две минуты?

Как это сделать?

Используемые технологии на сайте: apache-tomcat-5.5.20, jetspeed-2, jdk1.5.

Всем заранее спасибо!
...
Рейтинг: 0 / 0
Страницы сайта обновляются раз в несколько минут. Как закешировать?
    #34064603
Фотография Timm
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Vetal...
Проблема в том, что для отображения каждой страницы необходимо выполнить несколько десятков запросов к базе данных. В итоге каждая страница грузится секунд по десять. И это еще не предел, так как каждый день объем данных растет. ...
Ключевая фраза. Это означает всего лишь то что ваше приложение не масштабируемо. Не изобретайте "кэш". Оптимизируйте приложение.
...
Рейтинг: 0 / 0
Страницы сайта обновляются раз в несколько минут. Как закешировать?
    #34064627
Vetal
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Timm Vetal...
Проблема в том, что для отображения каждой страницы необходимо выполнить несколько десятков запросов к базе данных. В итоге каждая страница грузится секунд по десять. И это еще не предел, так как каждый день объем данных растет. ...
Ключевая фраза. Это означает всего лишь то что ваше приложение не масштабируемо. Не изобретайте "кэш". Оптимизируйте приложение.
Любая система тем медленнее работает, чем больше в ней данных, как тут не оптимизируй.

На данный момент сайт нельзя выпускать, так как скорость работы недопустима. Поэтому необходимо закешировать данные.
...
Рейтинг: 0 / 0
Страницы сайта обновляются раз в несколько минут. Как закешировать?
    #34064635
Vetal
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
VetalНа данный момент сайт нельзя выпускать, так как скорость работы недопустима. Поэтому необходимо закешировать данные.
Имею в виду, необходимо закешировать страницы. Зачем тянуть данные из базы ежесекундно, когда это можно делать раз в две минуты? В этом и есть оптимизация.
...
Рейтинг: 0 / 0
Страницы сайта обновляются раз в несколько минут. Как закешировать?
    #34065243
angro
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
ну например MS SQL точно кэширует данные, думаю что и все остальные БД тоже.
Поставить буфер кэша побольше.
...
Рейтинг: 0 / 0
Страницы сайта обновляются раз в несколько минут. Как закешировать?
    #34065259
Фотография softwarer
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
VetalЛюбая система тем медленнее работает, чем больше в ней данных, как тут не оптимизируй.
Вы это в детском саду рассказывайте, может поверят.

VetalНа данный момент сайт нельзя выпускать, так как скорость работы недопустима.
Почему-то это меня не удивляет. И сразу вспоминается одна умная книга по Java, в первом же примере которой автор сначала написал код так, что нахрен убивал кэш БД, а потом долго рассказывал, какая полезная штука кэш и как его надо делать на Java.
...
Рейтинг: 0 / 0
Страницы сайта обновляются раз в несколько минут. Как закешировать?
    #34065336
LINUXER
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Что интересно грузиться 10сек? Хотя если там томик из Войны и мира, то конечно понятно :))
Я обычно складываю данные в буфер(в бин). Его можно чистить. Облегчает жизнь с асинхронными запросами.
...
Рейтинг: 0 / 0
Страницы сайта обновляются раз в несколько минут. Как закешировать?
    #34066808
Vetal
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
angroну например MS SQL точно кэширует данные, думаю что и все остальные БД тоже.
Поставить буфер кэша побольше.
Это, конечно же, решит проблему частично.

Однако, зачем мне у базы спрашивать одни и те же данные 200 раз, одни и те же данные 200 раз гнать по сети, одни и те же данные 200 раз обрабатывать на аппликейшн сервере, одни и те же страницы 200 раз создавать и одни и те же страницы 200 раз отдать клиенту,
когда можно один раз запросить у базы данные, один раз их перегнать по сети, один раз их обработать на аппликейшн сервере, один раз создать страницу и потом уже созданную страницу 200 раз отдать из кеша клиенту.

Разница есть?

Это и есть оптимизация. Не делать 200 раз то, что можно сделать один раз.
...
Рейтинг: 0 / 0
Страницы сайта обновляются раз в несколько минут. Как закешировать?
    #34066841
Vetal
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
softwarer VetalЛюбая система тем медленнее работает, чем больше в ней данных, как тут не оптимизируй.
Вы это в детском саду рассказывайте, может поверят.

Есть таблица1 - 200 000 записей. Есть таблица2 - 200 000 записей. Каждая запись в таблице2 сопоставляется с одной записью в таблице1. Нужно отобрать 20 записей отсортированных по полю1 из таблицы2 сджойненной с таблицой1, при том что на многие поля таблицы1 и таблицы2 накладываются фильтры по равенству (по типу таблица1.поле2=0 и т.п.)

VetalНа данный момент сайт нельзя выпускать, так как скорость работы недопустима.
Почему-то это меня не удивляет. И сразу вспоминается одна умная книга по Java, в первом же примере которой автор сначала написал код так, что нахрен убивал кэш БД, а потом долго рассказывал, какая полезная штука кэш и как его надо делать на Java.[/quot]
Конечно, кэш БД решает много проблем. При этом кэш готовых страниц сайта решит еще больше проблем...

А как можно из джавы убить кэш БД? Скажите плиз, чтобы я его тоже не убил...
...
Рейтинг: 0 / 0
Страницы сайта обновляются раз в несколько минут. Как закешировать?
    #34066950
Vetal
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
2softwarer: Извините, не закончил свой предыдущий пост. Заканчиваю...

softwarer VetalЛюбая система тем медленнее работает, чем больше в ней данных, как тут не оптимизируй.
Вы это в детском саду рассказывайте, может поверят.
Есть таблица1 - 200 000 записей. Есть таблица2 - 2 000 000 записей. Каждая запись в таблице2 сопоставляется с одной записью в таблице1. Нужно отобрать 20 записей отсортированных по полю1 из таблицы2 сджойненной с таблицой1, при том что на многие поля таблицы1 и таблицы2 накладываются фильтры по равенству (по типу таблица1.поле2=0 и т.п.).

Расскажите мне пожалуйста, каким образом я могу разработать все таким образом, чтобы скорость выборки не замедлялась, когда в таблице1 будет 1 000 000 записей, а в таблице2 10 000 000 записей? Какие индексы тут не строй, как запросы не оптимизируй, скорость все равно будет серьезно замедляться...
...
Рейтинг: 0 / 0
Страницы сайта обновляются раз в несколько минут. Как закешировать?
    #34066954
Фотография Timm
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Vetal...

Брехня-а-а… (ц) к/ф Неуловимые мстители

VetalА как можно из джавы убить кэш БД? Скажите плиз, чтобы я его тоже не убил...
Уже убили.
...
Рейтинг: 0 / 0
Страницы сайта обновляются раз в несколько минут. Как закешировать?
    #34066967
Vetal
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
LINUXERЧто интересно грузиться 10сек? Хотя если там томик из Войны и мира, то конечно понятно :))

В предыдущем письме я написал ответ на этот вопрос.

LINUXERЯ обычно складываю данные в буфер(в бин). Его можно чистить. Облегчает жизнь с асинхронными запросами.
Да, я об этом и спрашиваю. По идее, должны быть стандартные решения, оттестированные и опробованные жизнью... Зачем же мне изобретать велосипед и тратить несколько дней/недель на разработку и внедрение еще одного аналогичного решения?

Поэтому посоветуйте, пожалуйста, готовое средство для кеширования страничек.

Спасибо!
...
Рейтинг: 0 / 0
Страницы сайта обновляются раз в несколько минут. Как закешировать?
    #34066975
Vetal
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Timm Vetal...

Брехня-а-а… (ц) к/ф Неуловимые мстители
Спасибо, очень содержательно :)


Timm VetalА как можно из джавы убить кэш БД? Скажите плиз, чтобы я его тоже не убил...
Уже убили.
Чем? Почему вы так думаете?
...
Рейтинг: 0 / 0
Страницы сайта обновляются раз в несколько минут. Как закешировать?
    #34066979
Фотография Timm
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Vetal
Поэтому посоветуйте, пожалуйста, готовое средство для кеширования страничек.

Спасибо!
Вам на рсдн"е уже сказали о проксировании сайта.
...
Рейтинг: 0 / 0
Страницы сайта обновляются раз в несколько минут. Как закешировать?
    #34066985
Фотография Timm
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Vetal Timm Vetal...

Брехня-а-а… (ц) к/ф Неуловимые мстители
Спасибо, очень содержательно :)

Всегда пожалуйста.
...
Рейтинг: 0 / 0
15 сообщений из 15, страница 1 из 1
Форумы / Java [игнор отключен] [закрыт для гостей] / Страницы сайта обновляются раз в несколько минут. Как закешировать?
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]