Резервное копирование — это одна из самых важных вещей если вы управляете серверами или у вас есть хотя бы один свой сервер. Непредвиденная ситуация может произойти в любой момент. Для того чтобы потерять данные не надо никакого особого случая. У вас может выйти из строя жесткий диск, у хостинг провайдера может что-то сломаться, или вы можете сами случайно снести базу данных забыв, что она где-то используется и в ней ещё есть важные данные.
В этой статье мы рассмотрим как выполняется установка и настройка Bacula. Это одна из самых популярных систем резервного копирования для Linux с открытым исходным кодом.
Содержание статьи:
Bacula — это система резервного копирования корпоративного уровня. Она имеет клиент-серверную архитектуру и состоит из таких компонентов:
Все компоненты могут быть установлены как на одном сервере, так и на разных, но каждый из них должен иметь возможность обратится к другому по сети. Для управления всем этим используется утилита командной строки bconsole. Для неё существует как консольный так и веб-интерфейс, но основной способ управления — командная строка.
Для версии сервера можно устанавливать полностью группу пакетов bacula. В Ubuntu по умолчанию будут установлены также такие пакеты, как PostgreSQL и Postfix. Команда установки будет выглядеть вот так:
sudo apt install bacula
Для работы Bacula нужна какая-нибудь база данных поэтому без Postgresql обойтись не получится, но Postfix можно не ставить, для этого просто допишите в команде установки postfix-. Например:
sudo apt install bacula postfix-
В процессе установки программа предложит настроить базу данных для Bacula. Лучше сделать это сейчас чтобы потом не делать вручную. Поэтому выберите Yes в следующем окне:
Поскольку база данных находится на том же сервере, что и Bacula достаточно выбрать localhost:
Далее введите пароль от будущей базы данных:
Установщик автоматически создаст базу данных, пользователя, а также пропишет их в конфигурационный файл Bacula. После завершения установки можно переходить к настройке программы.
Давайте первым делом настроем хранилище для Bacula. Конфигурация хранилища находится в файле /etc/bacula/bacula-sd.conf. В конфигурационном файле есть несколько секций:
Каждая секция имеет такой синтаксис:
имя_секции {параметр = значение}
Пробелы игнорируются интерпретатором, а регистр имен параметров не имеет значения. Секций с одним именем может быть несколько. Давайте теперь рассмотрим содержимое каждой секции, которая нам нужна подробнее. Старый конфигурационный файл можете переместить в _back, а для этой конфигурации создать новый:
sudo mv /etc/bacula/bacula-sd.conf{,_back}
sudo vi /etc/bacula/bacula-sd.conf
Удалять оригинальный файл не стоит, потому что может в будущем изменятся какие-либо пути и вам надо будет сверится с этим файлом. Сначала секция Storage:
Storage { Name = eizenhorn-sd #имя хранилища, hostname+sd SDPort = 9103 #порт на котором оно доступно WorkingDirectory = "/var/lib/bacula" Pid Directory = "/run/bacula" Plugin Directory = "/usr/lib/bacula" Maximum Concurrent Jobs = 20 SDAddress = 127.0.0.1 #IP адрес на котором будет ожидать соединений хранилище }
Дальше секция Director:
Director { Name = eizenhorn-dir #director сервис будет называться hostname+dir Password = "очень сложный пароль" }
Секция Device:
Device { Name = Local-Device #имя устройства Media Type = File #устройство является файлом Archive Device = /backup #путь в файловой системе где хранятся резервные копии LabelMedia = yes; Random Access = Yes; #поддерживает произвольный доступ AutomaticMount = yes; RemovableMedia = no; #не съемный накопитель AlwaysOpen = no; #открывать накопитель только при необходимости Maximum Concurrent Jobs = 5 #максимальное количество одновременно работающих задач }
Некоторые опции довольно странные. Это потому что изначально программа использовала не жесткие диски, а накопители на магнитной ленте для хранения данных. Последняя секция Messages. Всё остается как было в оригинальном файле:
Messages { Name = Standard director = eizenhorn-dir = all }
После завершения редактирования конфигурационного файла необходимо проверить его на ошибки. Для этого используйте такую команду:
sudo /usr/sbin/bacula-dir -t -c /etc/bacula/bacula-sd.conf
Если программа не вывела в консоль вообще ничего можно двигаться дальше. Перезапустите сервис чтобы применить изменения:
sudo systemctl restart bacula
Эта служба используется для доступа к файлам на сервере. Она должна быть запущена на машинах, с которых вы хотите делать резервные копии. Конфигурация стандартная, для локальной машины вы можете оставить то, что там есть по умолчанию. Рассмотрим основные секции:
sudo vi /etc/bacula/bacula-fd.conf
Director { Name = eizenhorn-dir #имя директора, который может сюда подключаться hostname+dir Password = "очень сложный пароль" }
Дальше идет секция с основными настройками File Daemon:
FileDaemon { Name = eizenhorn-fd # название, используется при подключении, hostname+fd FDport = 9102 # порт, на котором программа ожидает подключения WorkingDirectory = /var/lib/bacula Pid Directory = /run/bacula Maximum Concurrent Jobs = 20 Plugin Directory = /usr/lib/bacula FDAddress = 127.0.0.1 # IP адрес на котором программа ожидает подключений }
Ну и стандартная секция для отправки сообщений в Director:
Messages { Name = Standard director = eizenhorn-dir = all, !skipped, !restored }
Если что-то меняли, не забудьте проверить конфигурацию на ошибки и перезапустить сервис bacula-fd.
Конфигурационный файл Bacula Director находится по такому пути /etc/bacula/bacula-director.conf. Здесь тоже всё разбито на секции. Вы можете поступить аналогично настройке Storage. Переименовать его и добавлять секции в пустой файл. Давайте рассмотрим основные секции. Главная секция, описывающая сам сервис управления называется Director:
Director { Name = eizenhorn-dir #имя сервиса hostname+dir DIRport = 9101 #порт, на котором ожидает соединений сервис QueryFile = "/etc/bacula/scripts/query.sql" #файл с запросами SQL WorkingDirectory = "/var/lib/bacula" PidDirectory = "/run/bacula" Maximum Concurrent Jobs = 20 #максимальное количество одновременно выполняемых задач Password = "очень сложный пароль" #используется для подключения к сервису из консоли Messages = Daemon DirAddress = 127.0.0.1 }
Следующая секция не обязательная, но она есть в конфигурационном файле Bacula — JobDefs. Эта секция содержит значения по умолчанию, которые потом можно будет использовать при создании задач (Job):
JobDefs { Name = "DefaultJob" #имя Type = Backup #тип задачи - резервное копирование (Backup) или восстановление (Restore) Level = Incremental - #тип резервного копирования Client = eizenhorn-fd - #имя клиента, который используется для доступа к файлам FileSet = "Catalog" - #имя набора файлов Schedule = "LocalDaily" #имя расписания Storage = eizenhorn-sd #имя хранилища Messages = Standard Pool = File #имя пула SpoolAttributes = yes Priority = 10 Write Bootstrap = "/var/lib/bacula/%c.bsr" - куда записывать файл с метаданными. }
Файл с метаданными в формате bsr содержит информацию в ASCII о том, где и какие файлы находятся. Она необходима для того чтобы потом можно было восстановить из резервной копии отдельные файлы без восстановления всего что было сохранено. Дальше идёт секция с именем Catalog, в которой описывается способ подключения к базе данных Postgresql, которая была создана и настроена во время установки. Если всё сделано правильно, то в оригинальном конфигурационном файле уже есть верные данные:
Catalog { Name = MyCatalog dbname = "bacula"; DB Address = "localhost"; dbuser = "bacula"; dbpassword = "пароль" }
Ещё тут есть секция Messages с именем Standart и секция Console. В них ничего менять не надо, просто скопируйте их из оригинального конфигурационного файла.
Теперь у вас есть полностью настроенное хранилище, eizenhorn-sd и файловый демон eizenhorn-fd. Можно приступать к настройке резервного копирования локальной папки. Для этого в конфигурационный файл директора надо добавить несколько секций. Давайте сначала добавим пул, где будут хранится данные. Фактически, эта секция описывает набор томов (Volume), а фактически файлов в файловой системе с одинаковым префиксом, в которые будут записываться резервные копии. Это полезно, например, если вы хотите хранить резервные копии каждой машины в отдельном файле:
sudo vi /etc/bacula/bacula-dir.conf
Pool { Name = LocalPool #имя пула Pool Type = Backup #тип пула, на данный момент доступно только это значение Recycle = yes # переиспользование не нужных больше томов AutoPrune = yes # включает автоматическое удаление данных, которые больше не нужны Volume Retention = 365 days # сколько надо хранить резервные копии Maximum Volume Bytes = 50G # максимальный размер тома Maximum Volumes = 100 # максимальное количество томов Label Format = "Local-" # метка для файлов тома в файловой системе }
Пул готов, дальше надо определиться какой клиент мы будем использовать для доступа к файлам. Поскольку это локальная машина, надо использовать ранее настроенный eizenhorn-fd:
Client { Name = eizenhorn-fd # имя, должно совпадать с именем в настройках клиента Address = localhost # хост на котором ожидает соединений клиент FDPort = 9102 # порт, на котором ожидает соединений клиент Catalog = MyCatalog # каталог для метаданных, который мы создали ранее Password = "пароль" # пароль и настроек клиента File Retention = 60 days # сколько хранить информацию о файлах Job Retention = 6 months # сколько хранить информацию о задачах AutoPrune = yes # Автоматически удалять данные о файлах и задачах по истечении срока }
Тут надо разобраться с группой параметров удаления данных. Раньше, в настройке пула использовался параметр Volume Retention, в настройке клиента ещё два. Вот их значения:
После того как клиент есть осталось понять какие файлы надо поместить в резервную копию, для этого есть секция FileSet:
FileSet { Name = "Local-configuration" Include { Options { signature = MD5 } File = /etc } }
В данном случае интересен только параметр File, который указывает путь к папке, которую надо поместить в резервную копию. В данном случае это папка с конфигурацией системы — /etc.
Теперь надо указать когда запускать резервную копию с помощью секции Scedule:
Schedule { Name = "LocalDaily" Run = Level=Full daily at 06:00 }
Имя Name может быть произвольным, вы его будете использовать позже, при составлении задачи, а параметр Run должен указывать когда надо запускать резервную копию, а также может переопределять параметры заданные в задаче (Job). Кроме того можно задать несколько директив Run для того чтобы настроить разные типы резервного копирования.
Переопределяя уровень резервирования (Level) можно указать такие параметры:
Подробно о формате времени можно узнать в официальной документации. В упрощенном варианте можно использовать такой синтаксис:
день at ЧЧ:ММ
Или:
месяц номер_недели день at ЧЧ:ММ
В качестве дня можно использовать daily (каждый день) или sun, mon, the, wed, thu, fri, sat. В качестве номера недели: 1st, 2st, 3st, 4st, 5st. Например, можно записать вот так:
Schedule { Name = "LocalWeekCycle" Run = Level=Full sun at 06:00 # в воскресенье в 6:00 Run = Level=Incremental mon-sat at 06:00 # с понедельника по субботу включительно Run = Level=Full monthly 1st sun at 06:00 # в первое воскресенье каждого месяца }
Дальше осталось объединить всё созданное ранее в задаче (Job):
Job { Name = "LocalBackup" # имя задачи, будет использоваться для ручного запуска и выводится в логах JobDefs = "DefaultJob" # значения по умолчанию, которые мы определили раньше Enabled = yes # задача активна Level = Full # по умолчанию полная резервная копия FileSet = "Local-configuration" # набор файлов, должно совпадать с FileSet созданным раньше Schedule = "LocalDaily" # расписание запусков, должно совпадать c Schedule созданным раньше Storage = eizenhorn-sd # хранилище, в которое сохраняется резервная копия Pool = "LocalPool" # имя пула, созданного ранее }
После завершения настройки проверьте конфигурационный файл на ошибки:
sudo /usr/sbin/bacula-dir -t -c /etc/bacula/bacula-dir.conf
И если всё хорошо, перезапустите сервис:
sudo systemctl restart bacula-dir
Конфигурационный файл консоли находится здесь /etc/bacula/bconsole.conf. В нём есть только одна секция и здесь нужно указать на каком IP адресе ожидает соединений Bacula Director, а также пароль, к нему настроенный в секции Director файла /etc/bacula/bacula-dir.conf. Например:
Director { Name = eizenhorn-dir #имя директора, должно совпадать с настроенным в директоре DIRport = 9101 # порт address = 127.0.0.1 # IP Password = "очень сложный пароль" }
Дальше можно переходить к работе с консолью.
Работать с консолью Bacula довольно непривычно. Но у неё есть свои плюсы. Для запуска консоли выполните такую команду:
sudo bconsole
Вы увидите такое окно, с приглашением ввода в виде звездочки:
Для запуска задачи по резервному копированию выполните команду run. Поскольку сейчас задача одна, вам сразу же будет предложено её выполнить, в дальнейшем надо будет выбрать номер задачи или явно указать её имя команде в параметре команды run. После выполнения задачи она будет просто поставлена в очередь:
Больше ничего выведено не будет. Но результат выполнения задачи никуда не теряется. Он приходит вам в виде сообщений. Вы можете закрыть консоль и снова войти или просто нажать Enter и увидите сообщение о том, что You have messages:
Для того чтобы прочитать сообщения используйте команду messages:
messages
В данном случае будет выведена краткая статистика по задаче, а также результат её выполнения, ОК:
Посмотреть список выполненных задач можно командой list jobs:
Обратите внимание, что у каждой задачи есть свой ID и вы можете с помощью него посмотреть список файлов каждой задачи:
list files jobid=14
Для восстановления данных можно создать специальную задачу (Job), а затем воспользоваться командой restore, которая позволяет восстановить нужную резервную копию. Сначала надо добавить нужную задачу в конфигурационный файл /etc/bacula/bacula-dir.conf. Например, для восстановления ранее сделанной резервной копии папки /etc:
Job { Name = "LocalRestore" # имя задачи Type = Restore # означает, что эта задача используется для восстановления Client= "eizenhorn-fd" # клиент для работы с файлами FileSet="Local-configuration" # набор файлов для восстановления Storage = eizenhorn-sd # хранилище Pool = "File" #пул Messages = Standard Where = /opt/restore # куда восстанавливать }
Сохраните изменения и перезапустите bacula-dir, затем создайте папку, куда будет выполнятся восстановление:
sudo mkdir /opt/restore
Запустите консоль и выполните команду restore для того чтобы начать восстановление:
restore
Дальше вам надо знать задачу по резервному копированию, которую вы хотите восстановить. Узнать её можно несколькими способами:
Все варианты я рассматривать не буду. Для примера можно воспользоваться первым, и выбрать одну из ранее выполненных задач:
Давайте попробуем восстановить файлы из резервной копии, созданной заданием с ID 15. Для этого нажмите 4 и введите 15:
Здесь нужно перемещаться по виртуальной файловой системе с помощью команд cd и ls, а также отмечать или снимать отметку для файлов которые надо извлечь командами mark и unmark. Когда всё будет готово выполните команду done:
После этого утилита предложит выбрать клиент с помощью которого будет выполнятся восстановление:
А затем утилита покажет общую информацию о будущем восстановлении и вам надо набрать yes для того чтобы продолжать.
После завершения восстановления файлы появятся в папке /opt/restore. Если вы хотите восстановить все файлы из последней резервной копии, то вам не надо делать всё это достаточно выполнить команду run и передать ей имя задачи по восстановлению:
run LocalRestore
Из этой статьи вы узнали как выполняется установка и настройка Bacula в Linux для резервного копирования локальных файлов. Удалённое резервное копирование не намного сложнее. Вам просто надо установить на удалённую машину клиент и прописать его IP адрес в директоре. Это довольно громоздкая платформа, но нельзя не отдать ей должное в том, что конфигурационные файлы вполне понятны и их не очень сложно редактировать. А если вы не хотите иметь дело с консолью и конфигурационными файлами, то у программы есть несколько сторонних веб-интерфейсов.
Источник: https://losst.ru/ Материал распространяется под лицензией CC-BY-SA
Продолжая использовать данный сайт вы принимаете политику конфиденциальности и cookies