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

Всем привет. У меня есть вопрос касательно MsSQL и миграции, буду

рад услышать ваше мнение.

Допустим, в базе у меня лежат какие-то данные (2 миллиона записей). И в NoSql базе (Redis) лежит 3,5 миллионов записей, причем из них 2 миллиона записей так же деблируются с базой.

Я хочу написать джобу, которая будет переводить остаток (1,5 миллиона записей) в MsSql. Но так как для меня MsSql - зверь неизвестный, я решил обратиться сюда.

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

Особенности выборки в MsSql состоит в том, что по дефолту там ставится блокировка (shared lock, если не ошибаюсь). Потому с такими вещами нужно быть осторожным.

Примерный сценарий, по которому хочу построить миграцию:
1. Получить все данные из Redis, замапить их в map’у (это необходимо сделать потому, что без ключей я не смогу дополнить данные для переноса в базу, так они были изначально туда записаны) - ключ по которому данные лежат и сами значения

2. После чего я хочу взять и пройтись итеративно по этой мапке, чтобы собрать нужные INSERT’ы для mssql.

3. Используя jdbc template я хочу выполнить все эти INSERT’ы

Концепция достаточно простая, но кажется, что она не особо рабочая. Во-первым, на втором шаге мне придётся проверять базу (условно говоря выполнять некий database.findAllByParams(…), чтобф вообще понять, есть ли эти данные в базе или нет. Ну и да, сами данные могут удаляться как из Redis’а, так и из базы. Плюс ко всему, если разом попытаться это всё дело мигрировать, то можно просто потерять новые данные, ведь блокировка может усилить контеншон, а значит нужно делать таймауты.

Короче, как вы думаете, есть ли смысл как-то двигаться в эту сторону? Или проще завести третью таблицу в базе и не рисковать? Ну и да, для третьей таблицы там нужно будет лишь выполнить следующее:
redis data - database data

1 ответов

22 просмотра

А какой размер одной записи? Я бы закинул всё из редиса в отдельную табличку/базу на том же экземпляре и сливал все уже внутри SQL server. Shared lock можно убрать с помощью read committed snapshot в свойствах бд - но стоит протестировать, т.к. меняется логика и нагрузка на tempdb возрастает.

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

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

Гайс, вопрос для разносторонее развитых: читаю стрим с юарта, нада выделять с него фреймы с определенной структурой, если ли чо готовое, или долбаться с ринг буффером? нада у...
Vitaly
9
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
длина пакета фиксированная, или меняется?
Okhsunrog
7
Вот еще странный косяк, подскажите как бороться. Я git clone сделал себе всего embassy и примеры там запускаю. Всё хорошо. Но вот решил в cargo.toml зависимости не как в приме...
Lukutin R2AJP
5
А в каком формате фреймы? Сам формат сейчас придумываешь, или что-то готовое нужно распарсить?
Okhsunrog
5
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
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
Всем привет, нужна как никогда, нужна помощь с IO в загрузчике. Пишу в code16 после установки сегментных регистров, пишу вывод символа. Пробовал 2 варианта: # 1 mov $0x0E, %a...
Shadow Akira
14
Раз начали говорить про embassy, то присоединюсь со своими парой вопросов. 1) Есть ли сопоставимые аналоги для асинхронного кода в emdebbed? 2) Можно ли внутри задач embassy ...
NI_isx
6
сделал сайт, прикрутил в боте сайт, и виджет логина. как автоматически логинить пользователя в аккаунт(телеграм), при входе с бота?
Александра Чернивецкая
5
Карта сайта