Добавление пакетов к автономному установщику Lubuntu Alternate ISO


При создании автономных установочных носителей для автоматизированной установки ОС Lubuntu 14.04 с использованием preseed, я столкнулся с тем, что мне нужно добавить на установочный носитель пакеты, которые отсутствуют в исходном alternate-дистрибутиве. Я перепробовал много различных способов создания собственных автономных дистрибутивов, но они оказались:

  • либо неподходящими (LiveCDCustomization), т.к. мне нужен не LiveCD, а установочный preseed-дистрибутив;
  • либо очень сложными (DebianCustomCD);
  • либо работали, не как ожидалось (Simple-CDD, DebianInstaller/Modify/CD), а может я не до конца разобрался.


В итоге остановился на способе, который описан в сообществе Ubuntu.

Хочу рассказать о том, что у меня получилось.


Для дополнения дистрибутива нам потребуется исходный alternate-дистрибутив, к которому будем добавлять пакеты. А также компьютер под управлением Ubuntu или Lubuntu, на котором мы будем это делать.

Создание структуры каталогов и копирование файлов


Создадим каталог, в котором мы будем работать с этим дистрибутивом:

mkdir -p /opt/cd-image


Скачаем дистрибутив:

wget http://cdimages.ubuntu.com/lubuntu/releases/trusty/release/lubuntu-14.04.1-alternate-i386.iso


Распакуем скачанный iso-образ:

mkdir /mnt/iso
mount -o loop lubuntu-14.04.1-alternate-i386.iso /mnt/iso
cp -rT /mnt/iso /opt/cd-image
umount /mnt/iso


Создадим каталог для пакетов, которые мы хотим добавить в дистрибутив:

mkdir -p /opt/cd-image/pool/extras


Структура каталогов целиком
tree -d -L 3 /opt
/opt
├── apt-ftparchive
├── build
│   └── ubuntu-keyring-2012.05.19
│       ├── debian
│       └── keyrings
├── cd-image
│   ├── boot
│   │   └── grub
│   ├── dists
│   │   └── trusty
│   ├── doc
│   │   └── install
│   ├── install
│   │   └── netboot
│   ├── isolinux
│   ├── pics
│   ├── pool
│   │   ├── extras
│   │   ├── main
│   │   └── universe
│   └── preseed
└── indices


Подготовка ключей шифрования


Если у Вас нет пары публичный-приватный ключ, то нужно будет ее создать с помощью gpg. Ключу желательно задать комментарий вида «XXX Signing Key».

gpg --gen-key
gpg --gen-key
gpg (GnuPG) 1.4.16; Copyright (C) 2013 Free Software Foundation, Inc.
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.

Please select what kind of key you want:
   (1) RSA and RSA (default)
   (2) DSA and Elgamal
   (3) DSA (sign only)
   (4) RSA (sign only)
Your selection? 1
RSA keys may be between 1024 and 4096 bits long.
What keysize do you want? (2048)
Requested keysize is 2048 bits
Please specify how long the key should be valid.
         0 = key does not expire
        = key expires in n days
      w = key expires in n weeks
      m = key expires in n months
      y = key expires in n years
Key is valid for? (0)
Key does not expire at all
Is this correct? (y/N) y

You need a user ID to identify your key; the software constructs the user ID
from the Real Name, Comment and Email Address in this form:
    "Heinrich Heine (Der Dichter) "

Real name: Alexandr Petrenko
Email address: *********@gmail.com
Comment: My Signing Key
You selected this USER-ID:
    "Alexandr Petrenko (My Signing Key) <*********@gmail.com>"

Change (N)ame, (C)omment, (E)mail or (O)kay/(Q)uit? o
You need a Passphrase to protect your secret key.



Приватный ключ будем использовать для подписывания Release-файлов репозитория.Для следующих действий потребуется пакет fakeroot, установите его, если он отсутствует в вашей системе.

Теперь нужно добавить ваш ключ в пакет ubuntu-keyring
mkdir /opt/build
cd /opt/build
# Скачаем исходники действующего пакета с ключами
apt-get source ubuntu-keyring

# Импортируем ключи из пакета
cd ubuntu-keyring-2012.05.19/keyrings/
gpg --import < ubuntu-archive-keyring.gpg

# Для просмотра ключей, содержащих "Signing Key" в комментарии, введите
gpg --list-keys "Signing Key"

pub   1024D/437D05B5 2004-09-12
uid                  Ubuntu Archive Automatic Signing Key 
sub   2048g/79164387 2004-09-12

pub   1024D/FBB75451 2004-12-30
uid                  Ubuntu CD Image Automatic Signing Key 

pub   2048R/YOURKEYID 2015-01-28
uid                  My Signing Key <*********@gmail.com>
sub   2048R/KEYID 2015-01-28

# Добавьте свой ключ в связку
gpg --export FBB75451 437D05B5 YOURKEYID > ubuntu-archive-keyring.gpg

# Перейдите на уровень выше в каталог ubuntu-keyring-2012.05.19 и соберите пакет с вашим ключом
cd .. 
dpkg-buildpackage -rfakeroot -m"Ваше имя " -kYOURKEYID

# И скопируйте полученный пакета в репозиторий на диске
cd ..
cp ubuntu-keyring*deb /opt/cd-image/pool/main/u/ubuntu-keyring



Можно просто добавить несколько пакетов вручную в каталог /opt/cd-image/pool/extras.

Если требуется обновить модули ядра установщика, то это можно сделать так:

cd /opt/cd-image/pool/main/l/linux/
wget -r -nd --no-parent -A *-modules-3.13.0-67*i386.udeb ftp://security.ubuntu.com/ubuntu/pool/main/l/linux/


где вместо 3.13.0–67*i386 можно указать нужную версию ядра, которое вы используете для загрузки, и архитектуру модулей. В данном примере это 3.13.0–67, 3.16.0–52 или 3.19.0–32.

Чтобы скачать все пакеты, установленные в текущей ОС на эталонном компьютере, можно выполнить вот такой

скрипт
#!/bin/bash
dpkg --get-selections | while read line
do
  package=`expr "$line" : '\(.*\)install'`
  echo $package
  apt-get download $package
done
for i in *; do mv $i ${i/'1%3a'/''}; done



И добавить скачанные пакеты из кэша apt в репозиторий.
Утилита apt-ftparchive содержится в пакете apt-utils.
Все настройки даны для Lubuntu 14.04 Trusty и архитектуры i386. Если версия или архитектура вашего дистрибутива отличаются, то нужно поправить соответствующие значения в конфигурационных файлах и скриптах.

Описание репозитория для apt-ftparchive


В каталоге /opt/apt-ftparchive необходимо создать следующие конфигурационные файлы:

Настройки для карманов main и universe:

apt-ftparchive-deb.conf
Dir {
  ArchiveDir "/opt/cd-image/";
};

TreeDefault {
  Directory "pool/";
};

BinDirectory "pool/main" {
  Packages "dists/trusty/main/binary-i386/Packages";
  BinOverride "/opt/indices/override.trusty.main";
  ExtraOverride "/opt/indices/override.trusty.extra.main";
};

BinDirectory "pool/universe" {
 Packages "dists/trusty/universe/binary-i386/Packages";
 BinOverride "/opt/indices/override.trusty.universe";
};

Default {
  Packages {
    Extensions ".deb";
    Compress ". gzip";
  };
};

Contents {
  Compress "gzip";
};



Настройки для модулей установщика debian-installer в карманах main и universe:

apt-ftparchive-udeb.conf
Dir {
  ArchiveDir "/opt/cd-image/";
};

TreeDefault {
  Directory "pool/";
};

BinDirectory "pool/main" {
  Packages "dists/trusty/main/debian-installer/binary-i386/Packages";
  BinOverride "/opt/indices/override.trusty.main.debian-installer";
};

BinDirectory "pool/universe" {
  Packages "dists/trusty/universe/debian-installer/binary-i386/Packages";
  BinOverride "/opt/indices/override.trusty.universe.debian-installer";
};

Default {
  Packages {
    Extensions ".udeb";
    Compress ". gzip";
  };
};

Contents {
  Compress "gzip";
};



Настройки для нашего кармана extras:

apt-ftparchive-extras.conf
Dir {
  ArchiveDir "/opt/cd-image/";
};

TreeDefault {
  Directory "pool/";
};

BinDirectory "pool/extras" {
  Packages "dists/trusty/extras/binary-i386/Packages";
};

Default {
  Packages {
    Extensions ".deb";
    Compress ". gzip";
  };
};

Contents {
  Compress "gzip";
};



Настройки для создания Release-файла репозитория:

release.conf
APT::FTPArchive::Release::Origin "Ubuntu";
APT::FTPArchive::Release::Label "Ubuntu";
APT::FTPArchive::Release::Suite "trusty";
APT::FTPArchive::Release::Version "14.04";
APT::FTPArchive::Release::Codename "trusty";
APT::FTPArchive::Release::Architectures "i386";
APT::FTPArchive::Release::Components "main restricted extras";
APT::FTPArchive::Release::Description "Ubuntu 14.04 LTS";



Загрузка индексов


get-indices.bash
#!/bin/bash
cd /opt/indices/
DIST=trusty
for SUFFIX in extra.main main main.debian-installer universe universe.debian-installer; do
  wget http://archive.ubuntu.com/ubuntu/indices/override.$DIST.$SUFFIX
done



Создание Packages и Release файлов репозитория


Скрипт, который запускает создание Packages и Release файлов репозитория утилитой apt-ftparchive с учетом наших настроек, после чего подписывает Release файл и записывает контрольные суммы файлов в md5sum.txt:

make-iso-repo.bash
BUILD=/opt/cd-image
APTCONF=/opt/apt-ftparchive/release.conf
DISTNAME=trusty

pushd $BUILD
apt-ftparchive -c $APTCONF generate /opt/apt-ftparchive/apt-ftparchive-deb.conf
apt-ftparchive -c $APTCONF generate /opt/apt-ftparchive/apt-ftparchive-udeb.conf
apt-ftparchive -c $APTCONF generate /opt/apt-ftparchive/apt-ftparchive-extras.conf
apt-ftparchive -c $APTCONF release $BUILD/dists/$DISTNAME > $BUILD/dists/$DISTNAME/Release

gpg --default-key "YOURKEYID" --output $BUILD/dists/$DISTNAME/Release.gpg -ba $BUILD/dists/$DISTNAME/Release
find . -type f -print0 | xargs -0 md5sum > md5sum.txt



Создание ISO-образа


make-iso-repo.bash
IMAGE=custom.iso
BUILD=/opt/cd-image/

mkisofs -r -V "Custom Ubuntu Install CD" \
            -cache-inodes \
            --iso-level 3 -J -l -b isolinux/isolinux.bin \
            -c isolinux/boot.cat -no-emul-boot \
            -boot-load-size 4 -boot-info-table \
            -o $IMAGE $BUILD

Загрузка с ISO-образа


Теперь можно загрузиться с помощью созданного ISO-образа, записав образ на CD/DVD-диск, или со сменного носителя.

Создание загрузочного USB диска


Для загрзуки нужно отформатировать диск в FAT32. Установить на диск загрузчик, например grub2:

sudo grub-install --no-floppy --root-directory=/media/multiboot /dev/sdb

где /media/multiboot — путь к смонтированному разделу загрузочного USB-диска; /dev/sdb — устройство загрузочного диска.

После этого настроить загрузчик. Примерный конфиг grub2:

/media/multiboot/boot/grub/grub.cfg
# таймаут меню
   set timeout=10
# выбранный пункт по умолчанию
   set default=0

# загружаем модули
   insmod ext2
   insmod loopback
   insmod iso9660
   insmod fat
   insmod part_msdos
   
menuentry "Boot from first hard disk" {
   set root=(hd1)
   chainloader +1
}

set iso="/custom.iso"

menuentry "Custom.iso" {
  linux /vmlinuz debconf/priority=high shared/ask_device=manual shared/enter_device=/dev/disk/by-label/DISKLABEL iso-scan/filename=$iso auto-install/enable=true debian-installer/language=ru debian-installer/locale=ru_RU.UTF-8 debian-installer/country=RU preseed/file=/cdrom/preseed/custom.seed DEBCONF_DEBUG=5 --
  initrd /initrd.gz
}



Также нужно добавить в корень USB-диска vmlinuz и initrd.

В файле udeb.list можно узнать версии модулей, которые требуются ядру, и которые нужно поместить в дистрибутив (см. выше).

Остается загрузиться с созданного диска, и запустить установку ОС.

Источники информации

© Habrahabr.ru