PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
Jetro
Отправлено: 21 Июля, 2018 - 15:53:20
Post Id


Новичок


Покинул форум
Сообщений всего: 8
Дата рег-ции: Дек. 2013  


Помог: 0 раз(а)




Суть следующая - в личном кабинете пользователя есть окно, куда подгружаются сообщения, поступающие с внешнего сервера.
Сейчас это реализовано следующим способом - сообщение приходят через POST-запрос, загружаются в базу, плюс сразу-же создается apcu-кэш сообщений и их количество, для пользователя, которому поступило сообщение. После этого, если пользователь откроет личный кабинет, у него каждых 5 секунд отрабатывает AJAX-скрипт, который проверяет нет ли новых сообщений (отличается ли количество сообщений с переменной в js-скрипте от количества с кэша, которое подгружается через AJAX) и если количество разное, то AJAX подгружает новые сообщения с того-же кэша.
Сейчас все работает, но мне потребовалось помечать прочитанные сообщения, но это невозможно сделать пока они будут грузиться с кэша. Но если их грузить напрямую с БД, то возникает немаленькая такая нагрузка на БД, из-за чего сайт начинает тупить. Что-то мне кажется что мою задачу можно решить более элегантно, но я не представляю как. Прошу совета.
 
 Top
LIME
Отправлено: 22 Июля, 2018 - 18:21:06
Post Id



Активный участник


Покинул форум
Сообщений всего: 10058
Дата рег-ции: Нояб. 2010  


Помог: 299 раз(а)




вебсокеты
никаких периодических запросов
и еще - кэш не должен быть архитектурным решением
а только средством оптимизации
ьеще одна точка отказа какникак
(Добавление)
тоесть работать должно и без кэша
пусть диски дымят и процессор скрипит но работать должно


-----
вау
я кажется понял жастЮзера!!!
 
 Top
Jetro
Отправлено: 23 Июля, 2018 - 22:01:36
Post Id


Новичок


Покинул форум
Сообщений всего: 8
Дата рег-ции: Дек. 2013  


Помог: 0 раз(а)




С сокетами еще не работал. Года два назад думал внедрить, но когда начал изучать доступные модули, показалось что это слишком громоздко для такой задачи.

По поводу кэша - идет запрос новых сообщений. Скрипт проверяет наличие кэша нужных данных, и если он есть - грузим его. Если нет, делаем запрос к БД, отдаем полученные данные в ответ на запрос, плюс генерируем с этих данных новый кэш. Вы это имели ввиду, говоря о том, что должно работать без кэша?
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 1 (гостей: 1, зарегистрированных: 0)
« Хранение данных, их вывод и обработка »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB