# Описание процесса создания резервной копии eMMC OrangePi 5 Plus В OrangePi 5 Plus нельзя изменить приоритет загрузки, в первую очередь загрузка происходит с SD карты, если загрузчик на SD карте не находится, производится попытка загрузки с eMMC и т.д. Таким образом, для того, чтобы создать образ диска eMMC достаточно загрузиться с SD карты и средствами команды `dd` выполнить создание образа диска eMMC. 1. Обеспечить подключение к хранилищу резервных копий по SSH на основе ключа пользователю root, т.к. скрипт будет выполняться от его имени ```bash root@opisd:~# ssh-keygen root@opisd:~# ssh-copy-id da2001@nas.dav.lan ``` 1. Подготовить скрипт, который выполнит создание образа eMMC и передаст его по SSH в сетевое хранилище ```bash da2001@opisd:~$ sudo vim /opt/backup_opi/opi_backup.sh ``` ```bash #!/bin/bash ################################################################################################### # Скрипт создаёт образ eMMC OrangePI 5 Plus и отправляет его на удалённый сервер по SSH, # при этом на удалённом сервере происходит сжатие образа для экономии места. # Сжатие происходит на удалённом сервере, чтобы минимизировать операции записи на Flash память, # с которой произведена загрузка OrangePI. ################################################################################################### # Убедиться, что запуск происходит от root if [ "$EUID" -ne 0 ] then echo "Скрипт необходимо запускать от администратора" exit fi # Удалённый сервер. Необходимо предварительно обеспечить доступ по ключам - ssh-keygen && ssh-sopy-id user@server server=da2001@nas.dav.lan # Путь сохранения на удалённом сервре remote_path=/mnt/main/data/Backup/opi1 # Необходимо синхронизировать время chronyc -a makestep # Имя образа name=$(echo $(date +%Y-%m-%d)_${HOSTNAME}_image.img.gz | sed 's/-emmc//') # Имя диска, над которым будем работать. SD в RPI называется mmcblk0 disk=/dev/mmcblk1 # запишем в переменную последний сектор последнего раздела диска last_sector=$(fdisk -l -o end $disk | tail -1) # Считаем, что размер сектора составляет 512 Байт, тогда необходимо сохранить ($last_sector+1)*512 Байт. # Или ($last_sector+1)*512/1024/1024 Мб. count=$(($(($last_sector+1))*512/1024/1024)) # Команда создания образа dd if=$disk bs=1M count=$count conv=noerror,sync | ssh $server "gzip -c > $remote_path/$name 2>> $remote_path/lastlog" && \ ssh $server "echo `date +"%A, %d %B %Y"` - Образ создан успешно >> $remote_path/log" || \ ssh $server "echo `date +"%A, %d %B %Y"` - При создании образа произошла ошибка >> $remote_path/log" # Необходимо хранить только последние 20 строк в файле log ssh $server 'echo "$(tail -5 $remote_path/log)" > $remote_path/log' # Необходимо хранить только последние 3 резервные копии count_copies=3 ssh $server "find $remote_path -type f -name '*_image.img.gz' -printf '%T@ %p\n' | sort -nr | cut -d' ' -f 2- | tail -n +$(($count_copies+1)) | xargs rm -f --" # Перезагрузка /usr/sbin/reboot ``` Добавить права на выполнение ```bash da2001@opisd:~$ sudo chmod +x /opt/backup_opi/opi_backup.sh ``` **!!Актуализировать!!** 7. Обеспечить выполнение скрипта при загрузке с SD. Сервис systemd Для этого вам нужно создать скрипт запуска systemd и поместить его в каталог `/etc/systemd/system/`. ```bash da2001@opisd:~$ sudo vim /etc/systemd/system/rpi_backup.service ``` ```bash da2001@opisd:~$ cat /etc/systemd/system/rpi_backup.service [Unit] Description=Run a Backup Script at Startup After=default.target [Service] ExecStart=/opt/backup_rpi/rpi_backup.sh [Install] WantedBy=default.target ``` Перечитать скрипты и активировать созданный сервис ```bash pi@host-usb:~ $ sudo systemctl daemon-reload pi@host-usb:~ $ sudo systemctl enable rpi_backup.service ``` ***