Главная >> Инструкции >> Резервное копирование Ubuntu

Резервное копирование Ubuntu

Резервное копирование системы очень важно, поскольку если у вас есть резервная копия всех файлов, настроек или даже системы полностью, то вы можете ее восстановить в случае возникновения проблем. Несмотря на стабильность Linux, эта система может ломаться, например, после обновления или когда вы экспериментировали и сделали что-то не так.

Если вы делаете резервное копирование Ubuntu, то потом сможете все очень просто восстановить, даже если система была почти убита. Уже существует множество программ для создания резервных копий как файлов, так и всего диска, одна из самых популярных из них - это CloneZilla. Но мы не будем их сегодня рассматривать. В этой статье мы поговорим о том, как выполнить резервное копирование системы без сторонних программ, с помощью системных команд. Это может быть полезнее в некоторых случаях.


Содержание статьи

Резервное копирование Ununtu

Рассмотрим самые распространенные способы копирования среди администраторов и обычных пользователей.

Способ 1. Список пакетов

Самый простой способ резервного копирования Ubuntu, кстати, именно эту возможность использует MintBackup в LinuxMint, это получение списка всех установленных пакетов. Да, тут вы не сохраните всю конфигурацию, зато сможете очень быстро восстановить все установленные программы.

Если учесть, что большинство конфигурационных файлов находятся в домашней папке пользователя, а она не стирается при переустановке, то остальные файлы не такая уже большая проблема. А такая резервная копия будет занимать всего несколько килобайт. Для выполнения резервной копии наберите такую команду:

dpkg --get-selections | grep -v deinstall > backup.txt

Далее, скопируйте полученный файл в надежное место. Когда система сломается, переустановите ее с установочного носителя, а затем просто выполните команды:

sudo dpkg --set-selections < backup.txt

sudo apt -y update
sudo apt-get dselect-upgrade

Файл со списком пакетов нужно поместить в текущую папку. Таким образом, вы очень быстро вернете все ранее установленные программы с минимальными затратами времени и в то же время получите чистую систему.

Способ 2. Создание архива

Резервное копирование таким способом более надежно, поскольку вы не просто создаете список установленных программ, а делаете архив из всей файловой системе. Фактически, вы можете потом развернуть этот архив на любой машине и получить полноценную операционную систему после настройки драйверов.

Таким способом часто создаются резервные копии систем на серверах и для него достаточно просто использовать утилиту tar и не нужны сторонние программы. Для создания архива используйте такую команду:

sudo tar czf /backup.tar.gz --exclude=/backup.tar.gz --exclude=/home --exclude=/media --exclude=/dev --exclude=/mnt --exclude=/proc --exclude=/sys --exclude=/tmp /

В этой команде все достаточно просто несмотря на ее запутанность. Опция c означает, что нужно создать архив (Create), z - включает сжатие Gzip. Затем с помощью опции -f мы указываем файл, в который нужно сохранить результат. Затем с помощью серии опций --exclude мы исключаем из архива сам файл архива, домашний каталог и директории с виртуальными файловыми системами. В самом конце указываем папку, с которой стоит начать сбор данных - /. Вот и все. Процесс займет очень много времени, но когда он завершится, вы получите полную резервную копию системы в корневом каталоге.

Если система повреждена, вам нужно загрузиться с LiveCD/USB, и примонтировать корневой каталог в /mnt/. Затем подключите носитель с резервной копией и выполните команду для распаковки:

sudo tar xf /run/media/имя_носителя/backup.tar.gz -C /mnt

Команда быстро распакует все, что было сохранено и вам останется только перезагрузить компьютер, чтобы вернуться к своей основной системе. Здесь не восстанавливается только загрузчик, восстановить Grub нужно отдельно если он был поврежден.

Способ 3. Резервное копирование в rsync

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

rsync -aAXv --exclude={"/dev/*","/proc/*","/sys/*","/tmp/*","/run/*","/mnt/*","/media/*","/lost+found"} / /папка/назначения

Набор опций -aAX включают передачу в режиме архива, что гарантирует полное копирование символических ссылок, устройств, разрешений и расширенных атрибутов, при условии, что их поддерживает целевая файловая система. Опция --exclude, как и раньше, исключает из копии виртуальные файловые системы.

После завершения копирования вам останется отредактировать /etc/fstab и заменить в нем адрес корневого раздела на новый. А также создать новый конфигурационный файл для загрузчика, автоматически или вручную.

Способ 4. Создание образа раздела

Команда dd linux позволяет создать полную копию раздела или даже всего диска. Это самый надежный, но в то же время потребляющий большое количество памяти способ выполнить резервное копирование системы Ubuntu. Утилита просто переносит весь диск по одному байту в образ. Команда выглядит вот так:

sudo dd if=/dev/sda4 of=~/backup.img

Здесь /dev/sda4 - это ваш корневой раздел. После завершения выполнения команды вы получите готовый образ, затем, чтобы восстановить систему из этой копии достаточно поменять опции местами и указать путь к файлу копии:

sudo dd if=~/backup.img of=/dev/sda4

Правда, процесс может занять достаточно много времени, в зависимости от скорости работы вашего диска.

Способ 5. Создание Squashfs образа

Преимущество Squashfs в том, что это полноценная файловая система в одном файле, которую можно очень быстро примонтировать и быстро извлечь нужные файлы. Кроме того, файловую систему можно открыть привычными менеджерами архивов. Для создания образа со всей системы используйте:

sudo mksquashfs / /root-backup.sqsh -e root-backup.sqsh home media dev run mnt proc sys tmp

Теперь, чтобы примонтировать созданный образ будет достаточно набрать такую команду:

sudo mount /root-backup.sqsh /mnt/ -t squashfs -o loop

А уже отсюда вы можете извлечь любой файл или перенести все это в реальную файловую систему с помощью cp -p.

Выводы

Резервное копирование Ubuntu 16.04 очень важно для поддержания вашей операционной системы в нормальном состоянии. В случае любой неожиданной ситуации вы сможете все восстановить. Если вас интересуют графические программы для бэкапа, вы можете попробовать remastersys или timeshift. Надеюсь, эта информация была полезной для вас.

30 комментариев к “Резервное копирование Ubuntu”

  1. теперь ждёмс статью со способами автоматического бэкапа без скриптописания и статью о том как работать со снапшотами btrfs

    Ответить
  2. А есть ли утилиты, которые позволяют делать backup системы, но с расчетом, чтобы каждый раз не был Full, а также поддерживал бы дифференциальный?Понятно, что всякие дополнительные мощные средства как Symantec, Acronis, Veeam и др. умеют это делать, но именно чтобы были утилиты небольшие по размеру и желательно из репов и бесплатные?

    Ответить
    • можно попробовать Aptik

      Возможности
      Поддержание/восстановление пакетов приложений и PPA
      Поддержание/восстановление установленных пакетов
      Поддержание/восстановление иконок из директории /usr/share/icons и тем из директории /usr/share/themes
      Поддержание/восстановление настроек приложений. Оно сохраняет zip-архивы разделов конфигураций приложений из домашней директории в местоположение резервных копий.
      Поддержание/восстановление пользователей и групп. Создает резервные копии пользователей и групп и восстанавливает их на новой системе
      Поддержание/восстановление записей. Создает резервные копии записей в директориях /etc/fstab и /etc/crypttab и восстанавливает их на новой системе
      Поддержание/восстановление данных в директории Home. Создает резервные копию данных пользовательской директории Home и восстанавливает ее на новой системе
      Запланированные задачи. Создает резервные копии записей файлов заданий crontab для всех пользователей и восстанавливает их на новой системе
      Зашифрованные резервные копии. Резервные копии, содержащие личную информацию, шифруются с использованием AES-128.
      Отдельные или периодические операции. Можно создавать копии как одного, так и нескольких объектов
      Поддержка всех видов Ubuntu и производных (Linux Mint, Elementary OS и т.д.).
      Доступна для Ubuntu 17.04 Zesty/16.10 Yakkety/16.04 Xenial/14.04 Trusty/12.04 Precise/Linux Mint 18/17/13/и других производных Ubuntu.
      Для установки следующие команды:
      sudo add-apt-repository ppa:teejee2008/ppa
      sudo apt-get update
      sudo apt-get install aptik

      Ответить
  3. Я использую "Luckybackup", графическая среда для rsync!
    установка: sudo add-apt-repository ppa:luckybackup-maintainers/ppa
    sudo apt-get update
    sudo apt-get install luckybackup

    НУ что сказать, работает! Правда были проблемы с cron, в приложении есть возможность создания но не запуска)
    Решил установкой "Gnome Shedule"
    sudo apt-get install gnome-schedule
    Sheduler подтянул задания на выполнение и всё!

    Ответить
  4. А почему ни слова не сказано про fsarchiver? Утилита намного лучше, удобней и понятней в эксплуатации, чем клонезилла, я только fsarchiver-ом и пользуюсь, нареканий лет за 6 работы на моей машине никаких!

    Ответить
  5. Здравствуйте! Спасибо за статью, для чайника познавательно! Скажите, а есть программы для создания бекапа по расписанию? Типа acronis

    Ответить
  6. автор, а можно поподробнее про СОЗДАНИЕ SQUASHFS ОБРАЗА пожалуйста, что бы восстановить какая полная команда будет? и откуда, не понятно ничего... опиши, если не трудно

    Ответить
  7. Способ 2. Создание архива. Корневая папка будет LiveCD, а не нашей системы, которой надо копию сделать. Надо сначала смонтировать корневой раздел нашей системы в какую либо папку внутри mnt (например, mount/root), а уже потом этот раздел копировать в файл на флешке или внешнем жестком диске. Но тогда встает другая проблема. В архивный файл попадет структура mnt/root и при разархивировании будет не корневой раздел а mount/root/корневой_раздел

    Ответить
  8. Добрый день! Данный способ не сработал.
    sudo tar czf /backup.tar.gz --exclude=/backup.tar.gz --exclude=/home --exclude=/media --exclude=/dev --exclude=/mnt --exclude=/proc --exclude=/sys --exclude=/tmp /

    Результат:
    tar: Удаляется начальный `/' из имен объектов
    tar: Удаляются начальные `/' из целей жестких ссылок
    tar: /var/snap/canonical-livepatch/98/livepatchd.sock: сокет проигнорирован
    tar: /var/snap/canonical-livepatch/98/livepatchd-priv.sock: сокет проигнорирован
    tar: /run/wpa_supplicant/wlo1: сокет проигнорирован
    tar: /run/irqbalance/irqbalance484.sock: сокет проигнорирован
    tar: /run/uuidd/request: сокет проигнорирован
    tar: /run/snapd-snap.socket: сокет проигнорирован
    tar: /run/snapd.socket: сокет проигнорирован
    tar: /run/dbus/system_bus_socket: сокет проигнорирован
    tar: /run/cups/cups.sock: сокет проигнорирован
    tar: /run/avahi-daemon/socket: сокет проигнорирован
    tar: /run/acpid.socket: сокет проигнорирован
    tar: /run/user/1000/doc: Функция stat завершилась с ошибкой: Отказано в доступе
    tar: /run/user/1000/gvfs: Функция stat завершилась с ошибкой: Отказано в доступе
    tar: /run/user/1000/keyring/ssh: сокет проигнорирован
    tar: /run/user/1000/keyring/pkcs11: сокет проигнорирован
    tar: /run/user/1000/keyring/control: сокет проигнорирован
    tar: /run/user/1000/snapd-session-agent.socket: сокет проигнорирован
    tar: /run/user/1000/pulse/native: сокет проигнорирован
    tar: /run/user/1000/pk-debconf-socket: сокет проигнорирован
    tar: /run/user/1000/gnupg/S.gpg-agent: сокет проигнорирован
    tar: /run/user/1000/gnupg/S.gpg-agent.ssh: сокет проигнорирован
    tar: /run/user/1000/gnupg/S.gpg-agent.extra: сокет проигнорирован
    tar: /run/user/1000/gnupg/S.gpg-agent.browser: сокет проигнорирован
    tar: /run/user/1000/gnupg/S.dirmngr: сокет проигнорирован
    tar: /run/user/1000/bus: сокет проигнорирован
    tar: /run/user/1000/systemd/private: сокет проигнорирован
    tar: /run/user/1000/systemd/notify: сокет проигнорирован
    tar: /run/user/1000/inaccessible/sock: сокет проигнорирован
    tar: /run/systemd/fsck.progress: сокет проигнорирован
    tar: /run/systemd/journal/io.systemd.journal: сокет проигнорирован
    tar: /run/systemd/journal/socket: сокет проигнорирован
    tar: /run/systemd/journal/stdout: сокет проигнорирован
    tar: /run/systemd/journal/dev-log: сокет проигнорирован
    tar: /run/systemd/journal/syslog: сокет проигнорирован
    tar: /run/systemd/userdb/io.systemd.DynamicUser: сокет проигнорирован
    tar: /run/systemd/private: сокет проигнорирован
    tar: /run/systemd/notify: сокет проигнорирован
    tar: /run/systemd/inaccessible/sock: сокет проигнорирован
    tar: /run/udev/control: сокет проигнорирован
    tar: /: файл изменился во время чтения
    tar: Завершение работы с состоянием неисправности из-за возникших ошибок

    Могли бы вы сказать причины почему могло такое произойти и как можно это решить ?
    За ранее спасибо!

    Ответить
  9. Друзья, проблема. Автоматическое сохранение (бэкап) сохранил базы данных в формате .ZST
    Phpmyadmin у меня их восстанавливать отказывается. Других сохранений из DB нет. Что делать? Как правильно впихнуть в базу данных информацию из них? Действую с Ubuntu Server

    Ответить
  10. Походу афтар ничего толком сам не тестировал из описанного, так, где-то скопипастил шнягу.
    Кстати, при такой команде dd ничего не получится, т.к. копируется диск на тот же диск - в результате тупо забьётся свободной место.
    Неуч

    Ответить

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