NetInstall: различия между версиями
(ALT 10) |
Нет описания правки |
||
Строка 28: | Строка 28: | ||
# Указание используемого TFTP-сервера | # Указание используемого TFTP-сервера | ||
next-server 192.168.0.17; | next-server 192.168.0.17; | ||
# адрес NFS-сервера для установки в Legacy | |||
option root-path "/srv/public/netinst/mnt"; | option root-path "/srv/public/netinst/mnt"; | ||
option routers 192.168.0.1; | option routers 192.168.0.1; | ||
Строка 86: | Строка 87: | ||
kernel /boot/vmlinuz | kernel /boot/vmlinuz | ||
append initrd=/boot/initrd.img fastboot changedisk automatic=method:ftp,network:dhcp,server:192.168.0.195,directory:/netinst/mnt/ stagename=altinst ramdisk_size=669397 showopts nosplash mpath lang=ru_RU | append initrd=/boot/initrd.img fastboot changedisk automatic=method:ftp,network:dhcp,server:192.168.0.195,directory:/netinst/mnt/ stagename=altinst ramdisk_size=669397 showopts nosplash mpath lang=ru_RU | ||
label nfs | |||
kernel /boot/vmlinuz | |||
append initrd=/boot/initrd.img fastboot changedisk automatic=method:nfs,network:dhcp stagename=altinst ramdisk_size=669397 showopts nosplash mpath lang=ru_RU | |||
label memtest | label memtest | ||
Строка 96: | Строка 101: | ||
Type one of: | Type one of: | ||
ftp - install from ftp archive | ftp - install from ftp archive | ||
nfs - install from nfs archive | |||
local - boot from 1st HDD | local - boot from 1st HDD | ||
memtest - run memtest | memtest - run memtest | ||
Строка 111: | Строка 117: | ||
set timeout=120 | set timeout=120 | ||
menuentry $"Install FTP "'ALT Server 10.1 x86_64 | menuentry $"Install FTP "'ALT Server 10.1 x86_64' { | ||
echo $"Loading Linux vmlinuz | echo $"Loading Linux vmlinuz ..." | ||
linux /boot/vmlinuz | linux /boot/vmlinuz fastboot changedisk automatic=method:ftp,network:dhcp,server:192.168.0.17,directory:/netinst/mnt/ stagename=altinst ramdisk_size=669397 vga=normal mpath lang=ru_RU | ||
echo $"Loading initial ramdisk ..." | echo $"Loading initial ramdisk ..." | ||
initrd /boot/initrd | initrd /boot/initrd.img | ||
} | } | ||
menuentry $"Install "'ALT Server 10.1 x86_64 | menuentry $"Install NFS "'ALT Server 10.1 x86_64' { | ||
echo $"Loading Linux vmlinuz | echo $"Loading Linux vmlinuz ..." | ||
linux /boot/vmlinuz | linux /boot/vmlinuz fastboot changedisk automatic=method:nfs,network:dhcp,server:192.168.0.17,directory:/srv/public/netinst/mnt/ stagename=altinst ramdisk_size=669397 vga=normal mpath lang=ru_RU | ||
echo $"Loading initial ramdisk ..." | echo $"Loading initial ramdisk ..." | ||
initrd /boot/initrd | initrd /boot/initrd.img | ||
} | } | ||
menuentry $"Memory Test (may not work with Secure Boot)" --id 'memtest' { | menuentry $"Memory Test (may not work with Secure Boot)" --id 'memtest' { | ||
linux /boot/memtest.efi | linux /boot/memtest.efi | ||
Строка 144: | Строка 151: | ||
#: <syntaxhighlight lang="bash"># ln -s /srv/public /var/ftp</syntaxhighlight> | #: <syntaxhighlight lang="bash"># ln -s /srv/public /var/ftp</syntaxhighlight> | ||
===== Настройка NFS ===== | |||
# Установить NFS-сервер: | |||
#: <syntaxhighlight lang="bash"># apt-get install nfs-server</syntaxhighlight> | |||
# Дописать в файл {{path|/etc/exports}} строки: | |||
#: <syntaxhighlight lang="text"> | |||
/srv/public -ro,insecure,no_subtree_check,fsid=1 * | |||
/srv/public/netinst/mnt -ro,insecure,no_subtree_check,fsid=2 * | |||
</syntaxhighlight> | |||
# Экспортировать каталоги: | |||
#: <syntaxhighlight lang="bash"># exportfs -r</syntaxhighlight> | |||
# Разрешить rpcbind прослушивать входящие соединения из сети: | |||
#: <syntaxhighlight lang="bash">#control rpcbind server</syntaxhighlight> | |||
# Запустить NFS-сервер: | |||
#: <syntaxhighlight lang="bash"># systemctl enable --now nfs-server</syntaxhighlight> | |||
=== Сетевая установка ALT Linux 7.0 === | === Сетевая установка ALT Linux 7.0 === | ||
==== Минимально необходимые ручные настройки для однократной установки ==== | ==== Минимально необходимые ручные настройки для однократной установки ==== |
Версия от 14:01, 20 ноября 2023
Сетевая установка ALT Linux
Требуются:
- на новом компьютере — сетевой интерфейс с поддержкой PXE;
- сервер DHCP с поддержкой BOOTP;
- сервер TFTP;
- сервер FTP (желательно с анонимным доступом), HTTP или NFS.
Сетевая инсталляция ALT 10.x
Требуется: сетевая карта с поддержкой PXE.
Установить пакет syslinux:
# apt-get install syslinux
Настройка DHCP
- Установить DHCP-сервер:
# apt-get install dhcp-server
- Настроить файл конфигурации DHCP (/etc/dhcp/dhcpd.conf):
option arch code 93 = unsigned integer 16; if option arch = 00:06 { filename "bootia32.efi"; } else if option arch = 00:07 { filename "shimx64.efi"; } else { filename "pxelinux.0"; } subnet 192.168.0.0 netmask 255.255.255.0 { # Указание используемого TFTP-сервера next-server 192.168.0.17; # адрес NFS-сервера для установки в Legacy option root-path "/srv/public/netinst/mnt"; option routers 192.168.0.1; option domain-name-servers 8.8.8.8; option domain-name "test.alt"; default-lease-time 3600; max-lease-time 3600; range 192.168.0.190 192.168.0.200; }
- Запустить DHCP-сервер:
# systemctl enable --now dhcpd
Настройка TFTP
Trivial File Transfer Protocol (TFTP) используется для загрузки загрузочного образа на клиентскую машину.
- Установить TFTP-сервер:
# apt-get install tftp-server-xinetd
- Отредактировать файл /etc/xinetd.d/tftp и убедиться что включен TFTP-сервер:
disable = no
- Удалить или закомментировать следующую строку в файле /etc/xinetd.conf:
only_from = 127.0.0.1
- Перезапустить сервис xinetd:
# systemctl restart xinetd
Загрузить ISO-образ и переместить его на PXE-сервер.
Смонтировать ISO-образ:
# mkdir -p /srv/public/netinst/mnt/
# mount -t iso9660 -o loop,ro /path/iso-file.iso /srv/public/netinst/mnt
Создать подкаталог для хранения файлов загрузочного образа в /var/lib/tftpboot:
# mkdir -p /var/lib/tftpboot/pxelinux.cfg
Скопировать файл загрузчика pxelinux в каталог, указанный в конфигурации TFTP:
# cp /usr/lib/syslinux/pxelinux.0 /var/lib/tftpboot/
Скопировать каталог boot, содержащий ядро ОС и начальную файловую систему, выполнив команду:
# cp -r /srv/public/netinst/mnt/boot/ /var/lib/tftpboot/
Настройка установки в Legacy
Создать файлы /var/lib/tftpboot/pxelinux.cfg/default и /var/lib/tftpboot/pxelinux.cfg/default.msg
# cp /srv/public/netinst/mnt/syslinux/isolinux.cfg /var/lib/tftpboot/pxelinux.cfg/default
# chmod 644 /var/lib/tftpboot/pxelinux.cfg/default
Содержимое файла /var/lib/tftpboot/pxelinux.cfg/default:
timeout 120
prompt 1
default local
display pxelinux.cfg/default.msg
label local
localboot -2
label ftp
kernel /boot/vmlinuz
append initrd=/boot/initrd.img fastboot changedisk automatic=method:ftp,network:dhcp,server:192.168.0.195,directory:/netinst/mnt/ stagename=altinst ramdisk_size=669397 showopts nosplash mpath lang=ru_RU
label nfs
kernel /boot/vmlinuz
append initrd=/boot/initrd.img fastboot changedisk automatic=method:nfs,network:dhcp stagename=altinst ramdisk_size=669397 showopts nosplash mpath lang=ru_RU
label memtest
menu label ^Memory Test
linux /boot/memtest.bin
Содержимое файла /var/lib/tftpboot/pxelinux.cfg/default.msg:
Type one of:
ftp - install from ftp archive
nfs - install from nfs archive
local - boot from 1st HDD
memtest - run memtest
Настройка установки в UEFI
Создать конфигурационный файл grub.cfg в /var/lib/tftpboot.
# cp /srv/public/netinst/mnt/boot/grub/grub.cfg /var/lib/tftpboot/
# chmod 644 /var/lib/tftpboot/grub.cfg
Пример файла /var/lib/tftpboot/grub.cfg:
set timeout=120
menuentry $"Install FTP "'ALT Server 10.1 x86_64' {
echo $"Loading Linux vmlinuz ..."
linux /boot/vmlinuz fastboot changedisk automatic=method:ftp,network:dhcp,server:192.168.0.17,directory:/netinst/mnt/ stagename=altinst ramdisk_size=669397 vga=normal mpath lang=ru_RU
echo $"Loading initial ramdisk ..."
initrd /boot/initrd.img
}
menuentry $"Install NFS "'ALT Server 10.1 x86_64' {
echo $"Loading Linux vmlinuz ..."
linux /boot/vmlinuz fastboot changedisk automatic=method:nfs,network:dhcp,server:192.168.0.17,directory:/srv/public/netinst/mnt/ stagename=altinst ramdisk_size=669397 vga=normal mpath lang=ru_RU
echo $"Loading initial ramdisk ..."
initrd /boot/initrd.img
}
menuentry $"Memory Test (may not work with Secure Boot)" --id 'memtest' {
linux /boot/memtest.efi
}
Получить файлы shimx64.efi и grubx64.efi:
# cp /usr/lib64/efi/shimx64.efi /var/lib/tftpboot
# cp /usr/lib64/efi/grubx64.efi /var/lib/tftpboot
Настройка FTP
- Установить FTP-сервер:
# apt-get install vsftpd
- Отредактировать файл /etc/xinetd.d/vsftpd и убедиться что включен FTP-сервер:
disable = no
- Перезапустить сервис xinetd:
# systemctl restart xinetd
- Создать ссылку на /srv/public:
# ln -s /srv/public /var/ftp
Настройка NFS
- Установить NFS-сервер:
# apt-get install nfs-server
- Дописать в файл /etc/exports строки:
/srv/public -ro,insecure,no_subtree_check,fsid=1 * /srv/public/netinst/mnt -ro,insecure,no_subtree_check,fsid=2 *
- Экспортировать каталоги:
# exportfs -r
- Разрешить rpcbind прослушивать входящие соединения из сети:
#control rpcbind server
- Запустить NFS-сервер:
# systemctl enable --now nfs-server
Сетевая установка ALT Linux 7.0
Минимально необходимые ручные настройки для однократной установки
Обычно в сети уже имеется сервер DHCP. Особенности реализации:
- вносятся изменения в уже имеющийся сервер DHCP (ISC или совместимый по формату конфигов) — в Альтлинуксе пакет dhcp-server;
- сервер TFTP выполняется в режиме программы, но не демона — используем пакет tftpd;
- в качестве источника установки используется один из имеющихся серверов (демонов): FTP, HTTP или NFS.
Подготовка загрузчика
Пусть корень сервера TFTP будет ~/Altlinux/PXEINSTALL.
- Создаём каталоги для сервера TFTP: mkdir -p ~/Altlinux/PXEINSTALL/pxelinux.cfg ~/Altlinux/PXEINSTALL/alt0
- Копируем загрузчик из пакета syslinux: cp /usr/lib/syslinux/pxelinux.0 ~/Altlinux/PXEINSTALL
- Создаём файл конфигурации загрузчика — умолчание для всех компьютеров
- (Примечание: Размер виртуального диска в "append ... ramdisk_size=" определяется размером файла "altinst" — если места не хватит, pxelinux.0 будет бесконечно спрашивать источник загрузки.
echo " default local timeout 120 prompt 1 display pxelinux.cfg/altlinux.msg label local localboot 0 #install source: FTP label ftp kernel alt0/vmlinuz append initrd=alt0/full.cz live fastboot showopts automatic=method:ftp,network:dhcp,server:192.0.2.2,directory:/pub/ALTLinux/ stagename=altinst ramdisk_size=45000 #install source: HTTP label http kernel alt0/vmlinuz append initrd=alt0/full.cz live fastboot automatic=method:http,network:dhcp,server:192.0.2.2,directory:/Altlinux stagename=altinst ramdisk_size=45000 #install source: NFS label nfs kernel alt0/vmlinuz append initrd=alt0/full.cz ai live fastboot automatic=method:nfs,network:dhcp,server:192.0.2.2,directory:/space/ftp/pub/Altlinux/ stagename=altinst " > ~/Altlinux/PXEINSTALL/pxelinux.cfg/default
- Если известен адрес MAC сетевой карты, можно сделать копию или hardlink файла конфигурации для этого адреса MAC.
- Нельзя делать simlink из-за того, что in.tftpd с опцией -s отказывается ресолвить симлинки.
- Пример: ln default ~/Altlinux/PXEINSTALL/pxelinux.cfg/01-00-18-f3-d0-62-06
- Создаём файл с подсказкой о выборе загрузки
echo " Network install Altlinux 7.0.4 Type one of: ftp - install from ftp archive http - install from http site nfs - install from nfs directory local - boot from 1st HDD " > ~/Altlinux/PXEINSTALL/pxelinux.cfg/altlinux.msg
Подготовка сервера DHCP (BOOTP)
В файл конфигурации сервера DHCP добавляем секцию для нашего нового компьютера:
host PXE { hardware ethernet 00:18:f3:d0:62:06; # MAC сетевого интерфейса fixed-address 192.0.2.7; # такой IP будет ему назначен (не обязателено) next-server 192.0.2.6; # IP-адрес сервера TFTP filename "pxelinux.0"; # имя файла загрузчика PXELINUX }
(Эта секция добавлена рядом с секцией "subnet 192.0.2.0 netmask 255.255.255.0 { … }", на том же уровне иерархии.)
Запуск сервера TFTP
Запустим программу сервера TFTP в foreground chroot в подготовленный каталог:
# in.tftpd -L4s ~/Altlinux/PXEINSTALL
Проверить, всё ли в порядке, можно в файлах протоколов /var/log/daemons/warnings и /var/log/daemons/errors.
Если хочется увидеть, какие файлы запрашивает клиент (PXE), укажите высокий уровень протоколирования и наблюдайте лог /var/log/daemons/info. В одном окне консоли:
# in.tftpd -L4s --verbosity 10 ~/Altlinux/PXEINSTALL
В другом:
# tail -F /var/log/daemons/info
Публикация источника установки
Монтируем загрузочный CD или DVD и раздаём его содержимое по ftp, http или nfs Пример для FTP:
# mkdir /ftp/pub/Altlinux # mount -t iso9660 -o ro /dev/sdd /ftp/pub/Altlinux
или
# mount -t iso9660 -o loop,ro ~/Downloads/alt-N-installdvd.iso /ftp/pub/Altlinux
Загрузка компьютера
Включаем новый компьютер, вызываем его BIOS SETUP, разрешаем "LAN adapter BOOT ROM", "PXE boot" или аналогичный пункт настройки, загружаем.
В процессе загрузки видна заставка PXELINUX, затем начинается загрузка. Если FTP или HTTP требует аутентификацию, PXELINUX предложит указать источник загрузки - в текстовой форме ввода можно задать адрес сервера, путь к содержимому установочного диска, логин и пароль.
Сетевая инсталляция ALT Linux 9.0
Требуется: сетевая карта с поддержкой PXE[1]. Установить следующие пакеты:
# apt-get install dhcp-server syslinux tftp-server vsftpd tftp-server-xinetd apache2-base
Настройка dhcpd сервера /etc/dhcp/dhcpd.conf[2]:
option arch code 93 = unsigned integer 16; class "pxeclients" { match if substring (option vendor-class-identifier, 0, 9) = "PXEClient"; next-server 192.168.1.1; if option arch = 00:06 { filename "bootia32.efi"; } else if option arch = 00:07 { filename "shimx64.efi"; } else { filename "pxelinux.0"; } } subnet 192.168.1.0 netmask 255.255.255.0 { default-lease-time 3600; max-lease-time 3600; range 192.168.1.100 192.168.1.200; }
# mkdir -p /srv/public/netinst/mnt/ # mount /dev/sr0 /srv/public/netinst/mnt/ # cp -r /srv/public/netinst/mnt/syslinux/ /var/lib/tftpboot/ # cp /usr/lib/syslinux/pxelinux.0 /var/lib/tftpboot/ # mkdir -p /var/lib/tftpboot/pxelinux.cfg # touch /var/lib/tftpboot/pxelinux.cfg/default /var/lib/tftpboot/pxelinux.cfg/default.msg
Настройка установки в Legacy
Содержимое файла /var/lib/tftpboot/pxelinux.cfg/default:
default local display pxelinux.cfg/default.msg timeout 100 prompt 1 label local localboot 0 label ftp kernel syslinux/alt0/vmlinuz append initrd=syslinux/alt0/full.cz changedisk fastboot ramdisk_size=347909 showopts vga=normal quiet splash automatic=method:ftp,network:dhcp,server:192.168.1.1,directory:/netinst/mnt/ tz=Europe/Moscow lang=ru_RU label nfs kernel syslinux/alt0/vmlinuz append initrd=syslinux/alt0/full.cz changedisk fastboot ramdisk_size=347909 showopts vga=normal quiet splash automatic=method:nfs,network:dhcp tz=Europe/Moscow lang=ru_RU label http kernel syslinux/alt0/vmlinuz append initrd=syslinux/alt0/full.cz changedisk fastboot ramdisk_size=347909 showopts vga=normal quiet splash automatic=method:http,network:dhcp,server:192.168.1.1,directory:/ tz=Europe/Moscow lang=ru_RU label memtest linux memtest.bin
Содержимое файла /var/lib/tftpboot/pxelinux.cfg/default.msg:
Type one of: ftp - install from ftp archive http - install from http site nfs - install from nfs directory local - boot from 1st HDD mem - run memtest
Настройка установки в UEFI
Содержимое файла /var/lib/tftpboot/grub.cfg:
set timeout=120 menuentry "FTP install" { linuxefi syslinux/alt0/vmlinuz fastboot live lowmem ramdisk_size=871661 showopts quiet splash stagename=altinst automatic=method:ftp,network:dhcp,server:192.168.1.1,directory:/netinst/mnt/ initrdefi syslinux/alt0/full.cz } menuentry "NFS install" { linuxefi syslinux/alt0/vmlinuz fastboot live lowmem ramdisk_size=871661 showopts quiet splash stagename=altinst automatic=method:nfs,network:dhcp,server:19 2.168.1.1,directory:/srv/public/netinst/mnt/ initrdefi syslinux/alt0/full.cz } menuentry "HTTP install" { linuxefi syslinux/alt0/vmlinuz fastboot live lowmem ramdisk_size=871661 showopts quiet splash stagename=altinst automatic=method:http,network:dhcp,server:192.168.1.1,directory:/ initrdefi syslinux/alt0/full.cz }
Получить файлы shimx64.efi и grubx64.efi:
cp /usr/lib64/efi/shimx64.efi /var/lib/tftpboot cp /usr/lib64/efi/grubx64.efi /var/lib/tftpboot
Настройка TFTP
Отредактировать файл /etc/xinetd.d/tftp и убедиться что включен tftp сервер:
disable = no
Перезапустить сервис:
# systemctl restart xinetd
Настройка FTP
Отредактировать файл /etc/xinetd.d/vsftpd и убедиться что включен ftp сервер:
disable = no
Перезапустить сервис:
# systemctl restart xinetd
Настройка NFS
В файле /etc/exports должна быть следующая строчка:
/srv/public -ro,insecure,no_subtree_check,fsid=1,crossmnt *
Экспорт каталогов:
exportfs -r
Настройка HTTP
Для apache создать конфигурационный файл /etc/httpd2/conf/sites-available/netinst.conf со следующим содержимым:
<VirtualHost *:80> DocumentRoot /srv/public/netinst/mnt/ <Directory /srv/public/netinst/mnt/> Options +FollowSymLinks -Indexes AllowOverride None Require all granted </Directory> </VirtualHost>
Применить изменения:
a2dissite 000-default a2dissite 000-default_https a2ensite netinst systemctl restart httpd2