SQL-бэкаппер и zip-архиватор (.Net)

Консольные утилиты для работы с бэкапами баз данных MS SQL Server.
Требуется .Net 2.0 или выше.

Исходники: https://github.com/gee12/BackupUtility

SqlBackUpper.exe

Выполняет запросы к базам данных MS SQL Server для создания резервных копий.

  1. Работа с СУБД MS SQL Server
  2. Работа с конфигурационным .xml файлом. По-умолчанию ищется в рабочем каталоге с именем приложения и расширением “.cfg”. Также полное имя конфигурационного файла можно задать в качестве аргумента. При отсутствии конфиг.файла – работа программы прекращается. Формат описания:

    Корневой тег Config – задание основных настроек. Атрибуты:

    • BackupNameMask (необязательный) – маска для формирования имени создаваемого бэкапа. Обязательно должна содержать местозаполнитель с индексом 0 (“{0}”) для вставки текущей даты и времени. Значение по-умолчанию – “_{0:dd-MM-yyyy_HH-mm-ss}.bak”
    • ConnectionMask (необязательный) – маска для формирования строки подключения к определенному серверу и базе данных. Обязательно должна содержать местозаполнители с индексами 0-6 для вставки параметров подключения. Значение по-умолчанию – “Data Source={0};Initial Catalog={1};User ID={2};Password={3};Integrated Security={4};Persist Security Info={5};Trusted_Connection={6};”
    • ConnectionGroupMask (необязательный) – маска для формирования строки подключения к определенному серверу (используется, если UniteSameInst=True). Обязательно должна содержать местозаполнители с индексами 0-5 для вставки параметров подключения. Значение по-умолчанию – “Data Source={0};User ID={1};Password={2};Integrated Security={3};Persist Security Info={4};Trusted_Connection={5};”
    • SqlQueryMask (необязательный) – маска для формирования строки запроса к БД на создание бэкапа. Обязательно должна содержать местозаполнители с индексами 0-3 для вставки имени БД (BaseName), пути к хранищу (BackupPath) и имени файла бэкапа соответственно (BackupNameMask). Значение по-умолчанию – “BACKUP DATABASE [{0}] TO DISK = N'{1}\\{2}’ WITH NOFORMAT, INIT, NAME = N'{3} – Full backup’, SKIP, NOREWIND, NOUNLOAD, STATS = 10”
    • Timeout (необязательный) – максимальное время в секундах, выделенное на выполнение запроса. Значение по-умолчанию – “30”
    • UniteSameInst (необязательный) – переключатель, необходимо ли группировать запросы к одинаковым серверам. Значение по-умолчанию – False
    • LogPath (необязательный) – путь для создания log-файла. По-умолчанию – “.\” (путь к рабочему каталогу)
    • MaxLogs (необязательный) – максимальное количество хранимых на диске (по указанному пути в LogPath) log-файлов. Удаляются лишние – наиболее старые. Поиск и удаление происходит по маске “*.log”. Значение по-умолчанию – ‘5’.
    • WindowStyle (необязательный) – стиль отображения консольных окон приложения и 7-zip. Возможные значения: Hidden (по-умолчанию), Normal, Maximized, Minimized
    • ReadKeyInFinish (необязательный) – переключатель того, необходимо ли ожидать от пользователя нажатия любой клавиши клавиатуры перед завершением программы. Возможные значения: True (по-умолчанию), False. Действует только при WindowStyle = Normal | Maximized

    Тег Connection – задание экземпляра соединения с базой данных и выполнения запроса на создание бэкапа. Могут задаваться несколько тегов Connection. Атрибуты:

    • InstName (обязательный) – имя целевого сервера
    • BaseName (обязательный) – имя целевой БД
    • UserName (обязательный) – имя учетной записи для подключения к серверу
    • Password (обязательный) – пароль
    • BackupPath (необязательный) – путь к хранилищу – каталогу назначения. Если заданный путь отсутствует, программа создает его автоматически. Значение по-умолчанию – “.\” (путь к рабочему каталогу)
    • MaxBackups (необязательный) – максимальное количество хранимых на диске (по указанному пути в BackupPath) бэкапов. Удаляются лишние – наиболее старые. Поиск и удаление происходит по маске “<BaseName>*”. Значение по-умолчанию – ‘5’.

    Примечание: Имя создаваемого файла бэкапа для каждого экземпляра Connection формируется как: BaseName + BackupNameMask

    Пример:

  3. Для работы необходима библиотека BackupLibrary.dll

BackupArchiver.exe

Запускает 7-zip с необходимыми аргументами для архивирования резервных копий БД (или других файлов в целевом каталоге) в хранилище.

  1. Работа с архиватором 7-zip (необходимо наличие установленного 7-zip)
  2. Работа с конфигурационным .xml файлом (см.пункт 1 в SqlBackUpper.exe). Формат описания:

    Корневой тег Config – задание основных настроек. Атрибуты:

    • ZipPath (необязательный) – путь к каталогу с 7-zip. Небходимо наличие 7z.exe, 7z.dll и 7-zip.dll. По-умолчанию ищет в рабочем каталоге, ‘C:\Program Files\’ или в ‘C:\Program Files (x86)\’
    • ZipArgs (необязательный) – аргументы для 7-zip. Значение по-умолчанию – “a -tzip -y”
    • TailMask (необязательный) – маска для формирования “хвостовой” части имени создаваемого архива. Обязательно должна содержать местозаполнитель с индексом 0 (“{0}”) для вставки текущей даты и времени. Значение по-умолчанию – “{0:dd-MM-yyyy_HH-mm-ss}.zip”
    • LogPath (необязательный) – см.пункт 1 в SqlBackUpper.exe
    • MaxLogs (необязательный) – см.пункт 1 в SqlBackUpper.exe
    • WindowStyle (необязательный) – см.пункт 1 в SqlBackUpper.exe
    • ReadKeyInFinish (необязательный) – см.пункт 1 в SqlBackUpper.exe

    Тег Folder – задание целевого каталога и хранилища. Могут задаваться несколько тегов Folder. Атрибуты:

    • SourcePath (обязательный) – путь к целевому каталогу. Если заданный путь отсутствует, текущий Folder не обрабатывается
    • DestPath (необязательный) – путь к хранилищу – каталогу назначения. Если заданный путь отсутствует, 7-zip создаст его автоматически. Значение по-умолчанию – “.\” (путь к рабочему каталогу)
    • HeadMask (необязательный) – маска для формирования “головной” части имени создаваемого архива. Значение по-умолчанию – “Backup”
    • MaxArchives (необязательный) – максимальное количество хранимых на диске (по указанному пути в DestPath) архивов. Удаляются лишние – наиболее старые. Поиск и удаление происходит по маске “<HeadMask>*”. Значение по-умолчанию – ‘5’.

    Примечание: Имя создаваемого файла архива для каждого экземпляра Folder формируется как: HeadMask + TailMask

    Пример:

  3. Для работы необходима библиотека BackupLibrary.dll

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *