Рейтинг:0

Используйте моментальные снимки, чтобы заморозить одну базу данных в MySQL

флаг au

Различные ресурсы, такие как https://mariadb.com/kb/en/backup-and-restore-overview/ или же https://www.thegeeksearch.com/how-to-backup-and-restore-mariadb-database/ описать, как сделать резервную копию всех данных экземпляра MySQL. Однако все они говорят обо всем наборе данных во всех базах данных.

Я хотел бы получить моментальные снимки для каждой базы данных (например, с помощью LVM, KVM, qcow2 и т. д.). Однако это может быть невозможно, поскольку я понимаю, что мариадб имеет несколько общих файлов во всех базах данных.

В моих мечтах: представьте ситуацию, когда приложения A и B подключаются к одному мариадб экземпляр, содержащий обе соответствующие базы данных A и B. Теперь приложение A выполняет критическую миграцию, и перед этим я хочу сделать быстрый (физический) снимок. mysqldump займет несколько часов, поэтому предположим, что мне каким-то образом удалось мариадб записать всю информацию о базе данных A (например, а.idb) в специальное место, такое как том LVM. Я просто блокирую свои таблицы, делаю снимок этого тома, разблокирую таблицы и получаю молниеносно быструю копию своих данных на основе COW. Я запускаю свою миграцию, она взрывается. Теперь снимок восстановлен, и если это сработает, я вернусь к исходным данным за считанные секунды. Приложение B не затрагивается.

Теперь это не реальность, как кажется. Есть некоторая информация о восстановлении баз данных с а.idb и другие файлы, например. https://symplecticgames.wordpress.com/2018/04/05/recovering-mysql-database-from-frm-and-idb-files/ но это не совсем работа на входе и выходе, как было бы при идеальном восстановлении моментального снимка, описанном выше. Описание даже предполагает остановку всего мариадб процесс.

Очевидным решением было бы иметь отдельный мариадб процесс со своим собственным полным набором данных в другом специальном месте, таком как том LVM. Однако это усложняет управление потенциально очень большим количеством серверов MySQL, работающих одновременно. Хотя это может быть автоматизировано, это может быть не идеально.

Есть ли какая-то возможность достичь или приблизиться к миру грез, описанному выше?

Ответить или комментировать

Большинство людей не понимают, что склонность к познанию нового открывает путь к обучению и улучшает межличностные связи. В исследованиях Элисон, например, хотя люди могли точно вспомнить, сколько вопросов было задано в их разговорах, они не чувствовали интуитивно связи между вопросами и симпатиями. В четырех исследованиях, в которых участники сами участвовали в разговорах или читали стенограммы чужих разговоров, люди, как правило, не осознавали, что задаваемый вопрос повлияет — или повлиял — на уровень дружбы между собеседниками.