Коллеги, подскажите, корректно ли в стартапе веб-сервиса (в будущем рассчитанного

на много пользователей) использовать MySQL? Знакомый говорит что у этой СУБД большая проблема с многопоточностью.

Объясняется это так: при выполнении транзакции MySQL блочит ВСЮ таблицу, в других же СУБД, том же Postgre, таблица не блочится, блочится только запись к которой обращается транзакция. Так ли это, кто разбирается, прошу немного пролить свет на этот вопрос )

4 ответов

19 просмотров

Ну например весь бекенд Яндекс Еды и Такси работает на мускуле. Не знаю, как сейчас, но раньше это точно было так. Что касается блокировок-то они очень разные бывают. Я лично не юзал мускуль, но судя по доке, дефолтный уровень-как раз row-level locking. Транзакция скорее всего выставляет на таблицу разделяемую блокировку (чтобы во время работы транзации никто не мог таблицу дропнуть целиком или поменять), но транзакциям, которые совместно меняют строки в таблице, это мешать не должно.

и да и нет у mysql несколько вариантов движков для таблиц старый myisam который как раз блочит всю таблицу на транзакциях и условно новый (почти 20 лет не возраст) innodb (уже дефолт в последних версиях) который как раз row-level блокировки

Вот хорошая статья. How Quora scaled MySQL to 100k+ Queries Per Second

это мифы из эпохи myisam. c innodb таблицами mysql лочит обычно только то что нужно, но есть нюанс. если предикат апдейта не индексирован и идет фуллскан, фуллскан начнет лочить все записи таблицы. т.е. надо следить что бы модифицирующие запросы по идексу шли

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

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

Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
сделал сайт, прикрутил в боте сайт, и виджет логина. как автоматически логинить пользователя в аккаунт(телеграм), при входе с бота?
Александра Чернивецкая
5
Объясните, пожалуйста, почему компилятор ругается на использование в условии неинициализированной переменной: int x; Task.Run(async () => { x = await somefunc(); }).Wait...
Александр
5
Ребят, подскажите, пожалуйста, почему в префиксе к ассетам, которые генерируются через фильтр | theme в шаблоне, стал вдруг появляться index.php? Вот так выглядит ссылка на а...
Виталий
1
Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
Блин, ребята, сори за тупые вопросы. А можно ли как-то открыть вебапку по нажатию на кнопку в меню(которое появляется слева, команды)?
Artem Stormageddon
3
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
13
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
Коллеги, может знает кто, можно ли цвет бейджа счётчика в BackendMenu менять без бубнов?
Alex Blaze
3
Карта сайта