Всем привет! текущая реализация (опустил куски кода с транзакциями): (все при помощи

транзакций)

const dataProduct = await Product.findOneAndUpdate(
{ _id: productId },
{ $inc: { countActivate: 1 } },
{ session, new: true }
);

if (countActivate >= 5000) {
// пользователь не может купить продукт, т.к. его уже купили 5 тысяч раз
// аборт транзакции и завершении сессии
// говорим пользователю что товар раскупили
}

// Если все в порядке, то пользователь купил продукт
await ProductBuy.create(
[
{
userId,
productId
}
],
{ session }
);

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

товары быстро разбирают, максимально быстро
около 200-300 RPS

пользователи встречают writeConflict (здесь все понятно), можно повторить транзакцию N раз

вопрос

как можно увеличить скорость покупки товара?
может есть иные решения?
сейчас при 200-300 RPS около 10 пользователей купят, остальные получат writeConflict
хотелось бы избежать повтора транзакций и ускорить процесс покупки

5 ответов

17 просмотров
Leksey-🕶 Автор вопроса

я искал разные решения 1. менял местами 1) productBuy 2) и далее инкремент количества товара 2. через каунтинг документов не дает гарантию

Leksey-🕶 Автор вопроса

есть подозрения, что мне надо будет редис подрубить для каунтинга и проверки 😁

да, делать retry это наиболее корректное решение вашей проблемы при таких условиях

Leksey-🕶 Автор вопроса
yopp 💉💉
да, делать retry это наиболее корректное решение в...

Т.е. нет варианта ускорить мою конструкцию? Есть конечно вариант, использовать редис для инкремента и проверок числа Конечно, понятно, что документ лочится транзакцией и другая транзакция не может ничего сделать и поможет только retry (бесконечный или N раз), но хотелось бы избежать этого

Leksey 🕶
Т.е. нет варианта ускорить мою конструкцию? Есть ...

не очень понятно тогда в чём основная проблема

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

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

Ребята, всем привет. Подскажите, пожалуйста, можно ли как-то через бота понять, что этого бота добавили в группу\канал и выдали ему права администратора?
Artem Stormageddon
9
Это переведённый текст с английского. Я не говорю на русском, но могу использовать переводчик Телеграм. Приветствую! Я начинающий веб-разработчик и все еще учусь. В настояще...
𐩱𐩪𐩣𐩱𐩲𐩺𐩡
3
А не хотим ли мы развлечься? 😉 Но так чтобы с пользой для наших профессиональных навыков?? 👨‍🎓👩‍🎓 Предлагаю на октябрь запланировать тестовый запуск новой командной игры "Игр...
Andrii Kurdiumov
2
Привет всем! Почему этот код не срабатывает при добавлении или удалении пользователя из чата? bot.on('chat_member', async (ctx) => { console.log(ctx); }) bot.launch({allo...
Alexander
5
у кого сколько оперативы на базе данных ?
АДИЛЬБЕК
4
Через бот апи возможно получить ID стикерпака? Не ссылку.
Vexylon [АФК до 09.09]
5
Привет Хочу сделать аналог iCloud’а для своих проектов, чтобы пользовательская информация хранилась в облаке, была доступна во всех сервисах, её можно было подсасывать везде)...
Виталий
9
В тг можно спарсить всех кто пишет в группе? Если список участников скрыт
S
3
код Event::listen('cms.page.display', function (&$content, $slug, $page, $html) { if (is_object($content)) { dump($content); } else { dump($s...
Point 111
3
Всем привет. Не понимаю, в чём тут шутка юмора. Убирается только разрешение на send_messages. А send_media_messages остаётся. Как сделать, чтобы оба убирались? await b...
Alexander
2
Карта сайта