Добрый день! Подскажите, пожалуйста, где можно почитать о том, как

работает репликации MongoDB 4.0 изнутри? Я хочу понять для себя, что именно происходит, когда я запускаю пустую ноду и она начинает в себя подтягивать БД. Так то я понимаю, что при запуске она получает конфиг, определяет кто PRIMARY, кто SECONDARY. Далее, судя по всему происходит выбор SECONDARY для репликации. Дальше она начинает стягивать БД и коллекции в них. Тянет по одной коллекции, потом строит индексы. Вот эта часть меня больше всего интересует. Когда она начинает тащить коллекцию, лочит ли она его на той стороне, откуда тащит? И тащит ли сразу всю коллекцию целиком, или по кусочкам? В какой момент времени и в какой итерации идёт обращение к opLog?

5 ответов

24 просмотра

Нет, не лочит. Смысл в том, что вы потом накатите всё содержимое оплога поверх точки начала initial sync, которая сейчас в самом его начале. Initial sync по сути это find

Elina-Linko Автор вопроса
yopp 💉💉
Нет, не лочит. Смысл в том, что вы потом накатите ...

На время вызова find идёт ли блокировка коллекции? И этот find выполняется на всю коллекцию сразу? К тому же, ведь во время синхронизации коллекций между нодами в выбранную текущую коллекцию могут активно писаться изменения. Как оно обеспечивает в это время атомарность изменений? Про opLog понятно, оно потом докатит разницу.

Elina Linko
На время вызова find идёт ли блокировка коллекции?...

В монге нет блокировок в классическом их понимании. Блокировки это деталь реализации

Elina Linko
На время вызова find идёт ли блокировка коллекции?...

Атомарность изменений гарантируется только на уровне документов и эта гарантия сохраняется при чтении

yopp 💉💉
Атомарность изменений гарантируется только на уров...

Так с 4 версии нормальные транзакции же появились на уровне коллекций, или я неправильно понял ?

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

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

Ребята, всем привет. Подскажите, пожалуйста, можно ли как-то через бота понять, что этого бота добавили в группу\канал и выдали ему права администратора?
Artem Stormageddon
9
Это переведённый текст с английского. Я не говорю на русском, но могу использовать переводчик Телеграм. Приветствую! Я начинающий веб-разработчик и все еще учусь. В настояще...
𐩱𐩪𐩣𐩱𐩲𐩺𐩡
2
А не хотим ли мы развлечься? 😉 Но так чтобы с пользой для наших профессиональных навыков?? 👨‍🎓👩‍🎓 Предлагаю на октябрь запланировать тестовый запуск новой командной игры "Игр...
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
Ребят, а двух-факторку для плагина Users и для бэкенда октября кто-то прикручивал? Поделитесь опытом
Constantine Anikin
4
Карта сайта