170 похожих чатов

Подскажите пожалуйста как правильно реализовать в моем случае кэширование через

редиску. У меня к каждому товару есть блок условных схожих предложений что можно еще посмотреть, он может обновляться время от времени. У меня была идея делать это следующим образом.
Собрать схожие продукты и поместить этот массив объектов в объект data и подписать это rows и так же в объект data добавить поле updatedAt, и каждый раз сравнивать старше ли часа/дня этот кэш, если старше то перегенерировать rows и обновить updatedAt.
Насколько это адекватная практика? И можно ли это реализовать как то иначе?

12 ответов

26 просмотров

как происходит обновление? В плане как ты это узнаешь?

Amwey- Автор вопроса
idk
как происходит обновление? В плане как ты это узна...

Ну могу узнать если сравнить количество продуктов как вариант

А почему это кэшированием называется? Какое основное хранилище для рекомендаций? Или генерация на лету?

Amwey- Автор вопроса
John Doe
А почему это кэшированием называется? Какое основн...

они нигде не хранятся в данный момент, он составляются по определенным параметрам из бд

Amwey
они нигде не хранятся в данный момент, он составля...

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

вообще можно создать ключ типа: cache:product:id_product:recommendations и хранить там этот массив. У set есть ttl. Так же ты можешь пойти дальше и сделать ключ более детальным, в плане добавления к основному ключу(cache:product:id_product:recommendations) допольнительных параметров, тем самым ты можешь разделять схожие запросы и\или инвалидировать конкретный Вот у меня есть пример(хотя он не до конца рабочий, но идею с ключами можно уловить) - https://github.com/mxxnseat/caching Но мы в продакшене пошли по примеру реакта(на колбеках) - https://github.com/TanStack/query/blob/main/packages/query-core/src/queryCache.ts

Amwey- Автор вопроса
Amwey- Автор вопроса

Ого,а как такое обходить?

Amwey
Ого,а как такое обходить?

Можно брать лок, тогда только первый запрос запустит перегенерацию, а последующие заберут результат из кеша. Но поскольку товар является коллаборативным ресурсом, то будет черезмерное потребление ресурсов при продажах популярных товаров (куча запросов в очереди ждут лок). А можно гененрировать предложения в бекграунде, класть их в хранилище. Клиенты будут забирать из хранилища товар с актуальным предложением

John Doe
Можно брать лок, тогда только первый запрос запуст...

ну кстате в таком случае все равно есть вероятность устаревшего кеша

John Doe
Можно брать лок, тогда только первый запрос запуст...

Можно лизом обойтись. https://martinfowler.com/articles/patterns-of-distributed-systems/time-bound-lease.html

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта