если у бота будет 300-500 юзеров?
немного из тз: команда /list должна отдавать список валют с ценами из бд, если последнее обновление бд было более 10 мин назад - делается запрос к сервису, ценники обновляются в бд и отдаются юзеру бота. я понимаю, что при использовании async для работы с бд надо предусмотреть лок во время запроса к сервису, чтобы избежать вакханалии на случай двух одновременных запросов... но меня очень интересует разница в скорости отдачи сообщений юзерам если использовать синхронный модуль для бд
Чо
Нужны транзакции, а не лок
1. зависит от многих факторов. что такое 300-500 юзеров? это 300-500 одновременных команд в секунду? 2. какой нахрен лок? +1 к вопросу тишки. 3. тебе нужно предусмотреть ситуацию, чтобы не высылать множество запросов на каждый раз, когда время последней синхронизации превысило таймаут. но для этого достаточно трекать а) таски синхронизации. б) время начала последней такой таски (т.е. писать время до того как запустил фоновую задачу синхронизациии, а не после того как). 4. в зависимости от логики работы с базой лок на таблицу \ запись все таки нужен. (но только для апдейта записи \ вставки новой записи, если например ты хранишь таблицу со списком прошлых тасков)
Обсуждают сегодня