Останні 2 дні я намагаюся створити завантажувальний образ debian (jessie / 8.4), і, наскільки я можу сказати, я маю правильну процедуру, але я не можу отримати правильну файлову систему. Я відносно впевнений, що я роблю щось не так, пропускаючи щось із монтажем або /etc/fstab
( на моєму зображенні немає жодного ). Я сподівався, що хтось із певним досвідом зможе допомогти мені / показати мені те, чого я сумую.
Ось помилки, які я бачу під час завантаження в qemu-system-x86:
Як текст, а потім як фактичні скріншоти:
Помилки:
fsck: error 2 (No such file or directory) while executing fsck.ext2 for /dev/sda1
fsck exited with status code 8
[FAILED] Failed to start Load/Save Random Seed
See `systemctl status systemd-random-seed.service` for details.
[FAILED] Failed to start Various fixups to make systemd work better on Debian.
See `systemctl status debian-fixup.service` for details.
...
[FAILED] Failed to start Update UTMP about System Boot/Shutdown.
See `systemctl status systemd-update-utmp.service` for details.
[DEPEND] Dependency failed for Update UTMP about System Runlevel Changes.
Ось інструкції, які я написав для себе / кроки, які я вжив:
cd ~
mkdir debootstrap
cd debootstrap/
# get newest
wget http://ftp.debian.org/debian/pool/main/d/debootstrap/debootstrap_1.0.80_all.deb
ar -x debootstrap_1.0.80_all.deb
zcat /root/debootstrap/data.tar.gz | tar xv
apt-get install parted
# 1.5Gbytes
dd if=/dev/zero of=1445.img bs=1024 count=1 seek=1536k
parted -s 1445.img -- mklabel msdos mkpart primary 1m 1.5g toggle 1 boot
losetup --show -f 1445.img
# prints out `/dev/loopX`, enter this on the next lin
partprobe /dev/loop0
# only have to make the filesytem once --> if you are troubleshooting steps, do not redo this line
mkfs -t ext2 /dev/loop0p1
mount /dev/loop0p1 /mnt
debootstrap --verbose --components=main,contrib,non-free \
--include=firmware-realtek,linux-image-amd64,grub-pc,ssh,vim \
--exclude=nano \
--arch amd64 jessie /mnt http://ftp.us.debian.org/debian
джерело інформації про використання --компонентів
Переконайтесь, що ядро встановлене, воно повинно з’являтися в
/boot
межах chroot, тобто/mnt/boot
із такими файлами:initrd.img-3.16.0-4-amd64
vmlinuz-3.16.0-4-amd64
config-3.16.0-4-amd64
System.map-3.16.0-4-amd64
встановити грязь
grub-install --boot-directory=/mnt/boot --modules=part_msdos /dev/loop0
Налаштувати APT
копіювати над влучними джерелами
cp /etc/apt/sources.list /mnt/etc/apt/sources.list
переконайтеся, що джерело компакт-диска коментується
додайте рядок:
deb http://ftp.debian.org/debian stable-backports main contrib non-free
Налаштування chroot
mount --bind /dev/pts /mnt/dev/pts
mount --bind /proc /mnt/proc
mount --bind /sys /mnt/sys
mount --bind /dev /mnt/dev
# if you want your pushprofilesettings
cp ~/.bashrc /mnt/root/
cp ~/.vimrc /mnt/root/
# chroot -- enter the system as if it were thy own
chroot /mnt /bin/bash
export HOME=/root
export LC_ALL=C
export LANG=C.UTF-8
export TERM=xterm-256color
mount
від man mount :
--bind
перезазначте піддерево деінде (його вміст доступний в обох місцях).
-t <type>
Монтування файлової системи типу , з цим, mount
буде намагатися визначити авто
налаштування послідовного / консольного доступу
редагувати /etc/default/grub
:
Встановити
GRUB_CMDLINE_LINUX=""
:GRUB_CMDLINE_LINUX="console=tty0 console=ttyS0,115200n8"
Відмінність
GRUB_TERMINAL=console
Внизу додайте рядок:
GRUB_SERIAL_COMMAND="serial --speed=115200 --unit=0 --word=8 --parity=no --stop=1"
Зробити потаємну конфігурацію - Це ПОВИННО бути зроблено в НЕ systemd-nspawn
оболонці (це означає , що chroot
)
grub-mkconfig -o /boot/grub/grub.cfg
Вихід із хроту
exit
Прибираємо за chroot'ed
umount /mnt/sys
umount /mnt/dev
umount /mnt/dev/pts
umount /mnt/proc
Можна перевірити наявність додаткових кріплень за допомогою:, mount | grep /mnt
а потім відключити їх umount
Введіть systemd-nspawn
systemd-nspawn -D /mnt
# not you are in a special container
Встановіть пароль для root
сpasswd
У /etc/ssh/sshd_config
коментарі PermitRootLogin without-password
прочитати #PermitRootLogin without-password
та вставити PermitRootLogin yes
під ним
Тепер увімкніть ssh при запуску
systemctl enable ssh
прибирати
# this is needed to clean up both chroot and systemd-nspawn -D /mnt
# once this is run you can not do systemd-nspawn either so wait until you are entirely done
exit
umount /mnt
losetup -d /dev/loop0
Перевірте наявність додаткових кріплень за допомогою: mount | grep /mnt
Якщо НЕЩО повернеться, від'єднайте їх umount
Відновлення (необхідне лише в помилці)
Якщо ви щось зламали або вам потрібно повторити спробу, повторно встановіть налаштування на існуючі .img
:
losetup --show -f 1445.img
# prints out `/dev/loopX`, enter this on the next lin
partprobe /dev/loop0
mount /dev/loop0p1 /mnt
тестування img
qemu-system-x86_64 -hda 1445.img -m 1024 -vnc :0
sudo debootstrap --components=main,contrib,nonfree --variant=minbase --include=linux-generic,grub-pc --arch=i386 xenial /mnt
.