====== Резервное копирование в с помощью duply (duplicity) ====== Duply представляет собой shell скрипт, являющийся оберткой вокруг другого скрипта - duplicity. Не смотря на то, что сам по себе [[http://duplicity.nongnu.org/|duplicity]] является полноценным ПО для создания резервных копий, duply дополняет его функционал рядом полезных свойств, упрощающих работу с опциями командной строки для выполнения различных типовых операций. Резервные копии бывают полные и инкрементальные. Если с полной резервной копией все понятно: это просто полная копия всех данных, подлежащих резервированию, то инкрементальная копия означает, что в бэкапе содержится только список изменений относительно предыдущего бэкапа. Инкрементальное резервное копирование с одной стороны позволяет экономить место на дисках, но с другой стороны для восстановления данных вам потребуется не только последний инкрементальный бэкап, но и весь перечень всех предыдущих бэкапов вплоть до последнего полного. Рассмотрен вариант установки и настройки на Debian. Если вы используете Ubuntu то перед каждой командой добавляйте ''sudo'' ====== Устанавливаем duplicity и duply ====== apt-get install duply duplicity python-boto ====== Конфигурируем duply ====== Создадим пустой конфигурационный файл duply: duply mybackup create где mybackup - это название профиля, где будет описана схема будущего резервного копирования. Профиль будет создан в файле ~/.duply/mybackup/conf. В файле /root/.duply/mybackup/conf, потребуется изменить строку TARGET в зависимости куда мы хотим сохранять архивы: GPG_KEY='disabled' TARGET='s3://xxxxxxxxxxxxxxxxxx:xxxxxxxxxxxxxxxxxxx@s3.netangels.ru/uXXXXX-backup/uXXXXX-vmZZZZZ' SOURCE='/' MAX_AGE=20D MAX_FULL_BACKUPS=3 MAX_FULLBKP_AGE=1W DUPL_PARAMS="$DUPL_PARAMS --full-if-older-than $MAX_FULLBKP_AGE --volsize $VOLSIZE --s3-multipart-chunk-size=15 " VOLSIZE=50 Параметры: GPG_KEY - Можно включить если нужно шифровать данные. Нам это не требуется, так как это увеличивает нагрузку. TARGET - Это метод путь куда будем сохранять с типом подключения SOURCE - Начальная точка архивации MAX_AGE - Количество дней хранения данных MAX_FULL_BACKUPS - Количество полных резервных копий MAX_FULLBKP_AGE - Максимальный возраст полных копий (в данном случае 1 неделя) DUPL_PARAMS - строка из параметров выше VOLSIZE - Сохранять резервные копии томами по указанное количество мегабайт (рекомендуется 50) В файле /root/.duply/mybackup/exclude укажем какие каталоги не надо архивировать: /dev /proc /sys /tmp /run /lib/modules В файле ''/root/.boto'' если используем s3 то пишем следующее: [Boto] host = s3.netangels.ru port = 80 is_secure = False ====== Создание резервных копий ====== При запуске duply следует иметь ввиду, что не смотря на то, что и duply, и duplicity переведены на русский язык, с локалью ru_RU.UTF-8 duplicity не дружит. Поэтому перед запуском duply необходимо сменить локаль на англоязычную: export LANG=C; /usr/bin/duply mybackup backup_purge --force Поставим архивирование по расписанию на каждый день Можно создать файл с root правами ''sudo nano /root/backup'' с содержимым: #!/bin/bash export LANG=C; /usr/bin/duply mybackup backup_purge --force И запускать его, скажем, в 6 утра. Добавим это в cron так ''crontab -e'' 0 6 * * * root /root/backup ====== Просмотр состояния бэкапов ====== $ export LANG=C; duply mybackup status ... Type of backup set: Time: Num volumes: Full Tue Feb 25 12:24:20 2014 1 Incremental Tue Feb 25 12:24:37 2014 1 Incremental Wed Feb 26 05:28:01 2014 1 Incremental Wed Feb 26 05:31:44 2014 1 ... Здесь видно, что в наличии имеется 4 резервных копии: одна полная и 3 инкремента. ====== Восстановление данных из резервной копии ====== Восстановление состояния всей папки ''/var/www'' из последнего бэкапа (существующие данные будут перезаписаны): export LANG=C; duply mybackup restore /var/www Восстановить файл ''/var/www/index.html'' по состоянию 4х дневной давности в отдельный файл ''/tmp/restore.html'' (не перезаписывая текущий файл ''/var/www/index.html''): export LANG=C; duply mybackup fetch var/www/index.html /tmp/restore.html 4D Обратите внимание, что путь к файлу внутри бэкапа пишется без начального слэша (/). Подробнее о резервном копировании в облачное хранилище s3 по ссылке [[https://www.netangels.ru/support/cloud-storage/duplicity/]]