Merge branch 'master' of ssh://git.da2001.ru:2222/da2001/notes

master
Долгий Артём 2023-11-21 11:38:02 +03:00
commit 335453e1d4
2 changed files with 200 additions and 53 deletions

View File

@ -5,29 +5,14 @@
1. Обеспечить подключение к хранилищу резервных копий по SSH на основе ключа пользователю root, т.к. скрипт будет выполняться от его имени
```bash
root@host-usb:~ $ ssh-keygen
root@host-usb:~ $ ssh-copy-id da2001@nas.dav.lan
root@opisd:~# ssh-keygen
root@opisd:~# ssh-copy-id da2001@nas.dav.lan
```
5. Создать конфигурационный файл EEPROM, который вернёт загрузку на SD
1. Подготовить скрипт, который выполнит создание образа eMMC и передаст его по SSH в сетевое хранилище
```bash
pi@host-usb:~ $ sudo mkdir /opt/backup_rpi && sudo vim /opt/backup_rpi/sd_eeprom.conf
```
```bash
pi@host-usb:~ $ cat /opt/backup_rpi/sd_eeprom.conf
[all]
BOOT_UART=0
WAKE_ON_GPIO=1
POWER_OFF_ON_HALT=0
BOOT_ORDER=0xf1
```
6. Подготовить основной скрипт, который выполнит создание образа SD-карты и передаст его по SSH в сетевое хранилище
```bash
pi@host-usb:~ $ sudo vim /opt/backup_rpi/rpi_backup.sh
da2001@opisd:~$ sudo vim /opt/backup_opi/opi_backup.sh
```
```bash
@ -35,14 +20,10 @@ pi@host-usb:~ $ sudo vim /opt/backup_rpi/rpi_backup.sh
###################################################################################################
# Скрипт создаёт образ SD-карты Raspberry PI и отправляет его на удалённый сервер по SSH,
# Скрипт создаёт образ eMMC OrangePI 5 Plus и отправляет его на удалённый сервер по SSH,
# при этом на удалённом сервере происходит сжатие образа для экономии места.
# Сжатие происходит на удалённом сервере, чтобы минимизировать операции записи на Flash память,
# с которой произведена загрузка RPI.
# После создания образа, происходит обновление конфигурации EEPROM Raspberry PI для загрузки с SD карты.
# В директории с этим скриптом должен находится конфигурационный файл EEPROM - $eeprom_conf
# Для корректной работы скрипта, EEPROM RPI должен поддерживать режим переключения загрузки SD<=>USB.
# с которой произведена загрузка OrangePI.
###################################################################################################
@ -56,28 +37,16 @@ fi
server=da2001@nas.dav.lan
# Путь сохранения на удалённом сервре
remote_path=/mnt/main/data/Backup/bastion_rpi
remote_path=/mnt/main/data/Backup/opi1
# Директория, в которой хранится конфигурационный файл EEPROM
eeprom_conf_path=/opt/backup_rpi
# Необходимо убедиться, что в папке присутствует конфиг EEPROM для изменения порядка загрузки
eeprom_conf="sd_eeprom.conf"
if [ ! -e "$eeprom_conf_path/$eeprom_conf" ]; then
ssh $server "echo Файл настроек EEPROM $eeprom_conf не найден" > $remote_path/lastlog 2>&1
exit
fi
# Необходимо синхронизировать время, т.к. сейчас оно отстаёт на неделю.
# Для этого используем утилиту ntpdate, Её необходимо заранее установить sudo apt install ntpdate.
ntpdate ntp1.vniiftri.ru
# Необходимо синхронизировать время
chronyc -a makestep
# Имя образа
name=$(echo $(date +%Y-%m-%d)_${HOSTNAME}_image.img.gz | sed 's/-usb//')
name=$(echo $(date +%Y-%m-%d)_${HOSTNAME}_image.img.gz | sed 's/-emmc//')
# Имя диска, над которым будем работать. SD в RPI называется mmcblk0
disk=/dev/mmcblk0
disk=/dev/mmcblk1
# запишем в переменную последний сектор последнего раздела диска
last_sector=$(fdisk -l -o end $disk | tail -1)
@ -98,9 +67,6 @@ ssh $server 'echo "$(tail -5 $remote_path/log)" > $remote_path/log'
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 --"
# Необходимо переключить EEPROM на загрузку с SD карты
rpi-eeprom-config -a $eeprom_conf_path/$eeprom_conf
# Перезагрузка
/usr/sbin/reboot
@ -109,19 +75,21 @@ rpi-eeprom-config -a $eeprom_conf_path/$eeprom_conf
Добавить права на выполнение
```bash
pi@host-usb:~ $ sudo chmod +x /opt/backup_rpi/rpi_backup.sh
da2001@opisd:~$ sudo chmod +x /opt/backup_opi/opi_backup.sh
```
7. Обеспечить выполнение скрипта при загрузке с USB. Сервис systemd
**!!Актуализировать!!**
7. Обеспечить выполнение скрипта при загрузке с SD. Сервис systemd
Для этого вам нужно создать скрипт запуска systemd и поместить его в каталог `/etc/systemd/system/`.
```bash
pi@host-usb:~ $ sudo vim /etc/systemd/system/rpi_backup.service
da2001@opisd:~$ sudo vim /etc/systemd/system/rpi_backup.service
```
```bash
pi@host-usb:~ $ cat /etc/systemd/system/rpi_backup.service
da2001@opisd:~$ cat /etc/systemd/system/rpi_backup.service
[Unit]
Description=Run a Backup Script at Startup
After=default.target
@ -141,7 +109,3 @@ pi@host-usb:~ $ sudo systemctl enable rpi_backup.service
```
***
<https://www.raspberrypi.com/documentation/computers/raspberry-pi.html#raspberry-pi-4-bootloader-configuration>
<https://www.raspberrypi.com/documentation/computers/raspberry-pi.html#raspberry-pi-4-boot-eeprom>
<https://www.raspberrypi.com/documentation/computers/raspberry-pi.html#BOOT_ORDER>

183
orangepi_pve.md Normal file
View File

@ -0,0 +1,183 @@
# Настройка OrangePI 5 Plus Debian
## Установка Proxmox на OrangePI 5 Plus Debian
https://github.com/jiangcuo/Proxmox-Arm64/wiki/Install-Proxmox-VE-on-Debian-bullseye
1. Указать внешний IP в hosts
```bash
da2001@opve:~$ cat /etc/hosts
127.0.0.1 localhost
192.168.13.14 opve.dav.lan opve
::1 localhost orangepi5plus ip6-localhost ip6-loopback
fe00::0 ip6-localnet
ff00::0 ip6-mcastprefix
ff02::1 ip6-allnodes
ff02::2 ip6-allrouters
```
1. Добавить репозиторий Proxmox VE
```bash
echo "deb https://global.mirrors.apqa.cn/proxmox/debian/pve bookworm port" > /etc/apt/sources.list.d/pveport.list
```
2. Добавить ключ репозитория
```bash
curl https://global.mirrors.apqa.cn/proxmox/debian/pveport.gpg -o /etc/apt/trusted.gpg.d/pveport.gpg
```
3. Обновить индексы пакетов
```bash
apt update && apt dist-upgrade -y
```
4. Установить необходимые пакеты
```bash
apt install ifupdown2
apt install proxmox-ve postfix open-iscsi
```
5. Перезагрузить устройство
```bash
reboot
```
***
## Debian 12 преднастроенный
```bash
su -
adduser da2001
usermod -aG 5,6,20,27,29,44,46,60,100,101,105,109,111,996,999 da2001
hostnamectl set-hostname opi.dav.lan
tee /etc/hosts<<EOF
192.168.13.14 opi.dav.lan opi
EOF
apt update && apt dist-upgrade -y
apt autoremove -y
orangepi-config
```
## Docker
Если не получилось настроить Proxmox, можно настроить Docker
### Сеть MacVLAN
```bash
docker network create -d macvlan \
--subnet=192.168.13.0/24 \
--gateway=192.168.13.1 \
-o parent=enP4p65s0 \
macvlan-net
```
где
`enP4p65s0` - сетевой интерфейс, подключенный к сети
**Узел docker не сможет взаимодействовать с созданной сетью macvlan, чтобы это изменить, необходимо создать интерфейс macvlan на узле со своим IP и маршрутом в сеть docker macvlan. Другие узлы сети без проблем взаимодействуют с клиентами сети docker macvlan, а это было целью. Таким образом, создавать дополнительный интерфейс и маршрут на узле не обязательно**
### Portainer
```bash
docker volume create portainer_data
docker run -d -p 8000:8000 -p 9443:9443 --name portainer --restart=always -v /var/run/docker.sock:/var/run/docker.sock -v portainer_data:/data portainer/portainer-ce:latest
```
### Adguard Home
```bash
cd /home/da2001
mkdir /home/da2001/adguardhome && cd /home/da2001/adguardhome
docker run --name adguardhome\
--restart unless-stopped\
--network=macvlan-net \
--ip=192.168.13.28 \
--mac-address=02:42:ac:11:00:02 \
-v /home/da2001/adguardhome/work:/opt/adguardhome/work\
-v /home/da2001/adguardhome/conf:/opt/adguardhome/conf\
-p 53:53/tcp -p 53:53/udp\
-p 67:67/udp -p 68:68/udp\
-p 80:80/tcp -p 443:443/tcp -p 443:443/udp -p 3000:3000/tcp\
-p 853:853/tcp\
-p 784:784/udp -p 853:853/udp -p 8853:8853/udp\
-p 5443:5443/tcp -p 5443:5443/udp\
-d adguard/adguardhome
```
### BIND DNS
```bash
cd /home/da2001
mkdir /home/da2001/bind
docker run --name bind9 \
--restart unless-stopped\
--network=macvlan-net \
--ip=192.168.13.27 \
--mac-address=02:42:ac:11:00:03 \
-v /etc/timezone:/etc/timezone:ro \
-p 53:53 \
-v /home/da2001/bind/etc:/etc/bind \
-v /home/da2001/bind/cache:/var/cache/bind \
-v /home/da2001/bind/records:/var/lib/bind \
-e BIND9_USER=bind \
-d ubuntu/bind9
```
***
## Debian 11
su -
adduser da2001
usermod -aG 5,6,20,27,29,44,46,60,100,101,105,109,111,996,999 da2001
hostnamectl set-hostname opve1.dav.lan
tee /etc/hosts<<EOF
192.168.13.14 opve1.dav.lan opve1
EOF
mkdir /mnt/{iso,vms,backup}
sudo tee -a /etc/fstab<<EOF
UUID=091632c3-e0b2-4d27-9595-a00d59a3e50c /mnt/vms ext4 defaults 0 0
UUID=8a388dd8-000d-4f15-8e23-9838a460c378 /mnt/backup ext4 defaults 0 0
UUID=6fbd6031-3631-41b5-b4e8-e2b301bb59e5 /mnt/iso ext4 defaults 0 0
EOF
systemctl daemon-reload
mount -a
apt update && apt full-upgrade -y
echo "deb https://global.mirrors.apqa.cn/proxmox/debian/pve bullseye port">/etc/apt/sources.list.d/pveport.list
curl https://global.mirrors.apqa.cn/proxmox/debian/pveport.gpg -o /etc/apt/trusted.gpg.d/pveport.gpg
apt update && apt full-upgrade
apt install ifupdown2 -y
apt install proxmox-ve postfix open-iscsi -y
***