Хөгжил дөнгөж эхэлж байх үед зорилтот rootfs руу аль багцууд очих нь тодорхойгүй байдаг.
Өөрөөр хэлбэл, LFS, buildroot эсвэл yocto (эсвэл өөр зүйл) авахад эрт байна, гэхдээ та аль хэдийн эхлэх хэрэгтэй. Баян хүмүүсийн хувьд (би туршилтын дээж дээр 4 ГБ eMMC байгаа) одоо дутуу байгаа зүйлийг хурдан хүргэх боломжийг хөгжүүлэгчдэд түгээх арга зам байгаа бөгөөд дараа нь бид үргэлж багцын жагсаалтыг цуглуулж, жагсаалт үүсгэж болно. зорилтот rootfs.
Энэ нийтлэл нь шинэ зүйл биш бөгөөд хуулж буулгах энгийн заавар юм.
Өгүүллийн зорилго нь ARM хавтангуудад зориулсан Ubuntu rootfs (миний хувьд Colibri imx7d дээр суурилсан) бүтээх явдал юм.
Зураг бүтээх
Бид хуулбарлах зорилгоор зорилтот rootfs-ийг цуглуулдаг.
Ubuntu суурийг задалж байна
Бид өөрсдийн хэрэгцээ, сонголт дээр үндэслэн хувилбарыг өөрсдөө сонгодог. Энд би 20 өгсөн.
$ mkdir ubuntu20
$ cd ubuntu20
$ mkdir rootfs
$ wget http://cdimage.ubuntu.com/ubuntu-base/releases/20.04/release/ubuntu-base-20.04-base-armhf.tar.gz
$ tar xf ubuntu-base-20.04-base-armhf.tar.gz -C rootfs
Цөм дэх BINFMT дэмжлэгийг шалгаж байна
Хэрэв танд нийтлэг тархалт байгаа бол BINFMT_MISC-ийн дэмжлэг байгаа бөгөөд бүх зүйл тохируулагдсан, хэрэв үгүй бол цөм дэх BINFMT-ийн дэмжлэгийг хэрхэн идэвхжүүлэхээ мэддэг гэдэгт би итгэлтэй байна.
Цөмд BINFMT_MISC идэвхжсэн эсэхийг шалгана уу:
$ zcat /proc/config.gz | grep BINFMT
CONFIG_BINFMT_ELF=y
CONFIG_COMPAT_BINFMT_ELF=y
CONFIG_BINFMT_SCRIPT=y
CONFIG_BINFMT_MISC=y
Одоо та тохиргоог шалгах хэрэгтэй:
$ ls /proc/sys/fs/binfmt_misc
qemu-arm register status
$ cat /proc/sys/fs/binfmt_misc/qemu-arm
enabled
interpreter /usr/bin/qemu-arm
flags: OC
offset 0
magic 7f454c4601010100000000000000000002002800
mask ffffffffffffff00fffffffffffffffffeffffff
Та гараар бүртгүүлж болно, жишээ нь:
Qemu статик гарыг тохируулж байна
Одоо бидэнд статик байдлаар угсарсан qemu жишээ хэрэгтэй байна.
!!! АНХААР!!!
Хэрэв та ямар нэгэн зүйл барихын тулд сав ашиглахаар төлөвлөж байгаа бол дараахь зүйлийг шалгана уу.
https://sourceware.org/bugzilla/show_bug.cgi?id=23960
https://bugs.launchpad.net/qemu/+bug/1805913
Дараа нь x86_64 хост болон зочны хувьд та qemu-ийн i386 хувилбарыг ашиглах хэрэгтэй:
http://ftp.ru.debian.org/debian/pool/main/q/qemu/qemu-user-static_5.0-13_i386.deb
$ wget http://ftp.debian.org/debian/pool/main/q/qemu/qemu-user-static_5.0-13_amd64.deb
$ alient -t qemu-user-static_5.0-13_amd64.deb
# путь в rootfs и имя исполняемого файла должно совпадать с /proc/sys/fs/binfmt_misc/qemu-arm
$ mkdir qemu
$ tar xf qemu-user-static-5.0.tgz -C qemu
$ file qemu/usr/bin/qemu-arm-static
qemu/usr/bin/qemu-arm-static: ELF 64-bit LSB executable, x86-64, version 1 (GNU/Linux), statically linked, BuildID[sha1]=be45f9a321cccc5c139cc1991a4042907f9673b6, for GNU/Linux 3.2.0, stripped
$ cp qemu/usr/bin/qemu-arm-static rootfs/usr/bin/qemu-arm
$ file rootfs/usr/bin/qemu-arm
rootfs/usr/bin/qemu-arm: ELF 64-bit LSB executable, x86-64, version 1 (GNU/Linux), statically linked, BuildID[sha1]=be45f9a321cccc5c139cc1991a4042907f9673b6, for GNU/Linux 3.2.0, stripped
Кроот
Энгийн скрипт:
ch-mount.sh
#!/bin/bash
function mnt() {
echo "MOUNTING"
sudo mount -t proc /proc proc
sudo mount --rbind /sys sys
sudo mount --make-rslave sys
sudo mount --rbind /dev dev
sudo mount --make-rslave dev
sudo mount -o bind /dev/pts dev/pts
sudo chroot
}
function umnt() {
echo "UNMOUNTING"
sudo umount proc
sudo umount sys
sudo umount dev/pts
sudo umount dev
}
if [ "$1" == "-m" ] && [ -n "$2" ] ;
then
mnt $1 $2
elif [ "$1" == "-u" ] && [ -n "$2" ];
then
umnt $1 $2
else
echo ""
echo "Either 1'st, 2'nd or both parameters were missing"
echo ""
echo "1'st parameter can be one of these: -m(mount) OR -u(umount)"
echo "2'nd parameter is the full path of rootfs directory(with trailing '/')"
echo ""
echo "For example: ch-mount -m /media/sdcard/"
echo ""
echo 1st parameter :
echo 2nd parameter :
fi
Бид үр дүнг биширдэг:
$ ./ch-mount.sh -m rootfs/
# cat /etc/os-release
NAME="Ubuntu"
VERSION="20.04 LTS (Focal Fossa)"
ID=ubuntu
ID_LIKE=debian
PRETTY_NAME="Ubuntu 20.04 LTS"
VERSION_ID="20.04"
HOME_URL="https://www.ubuntu.com/"
SUPPORT_URL="https://help.ubuntu.com/"
BUG_REPORT_URL="https://bugs.launchpad.net/ubuntu/"
PRIVACY_POLICY_URL="https://www.ubuntu.com/legal/terms-and-policies/privacy-policy"
VERSION_CODENAME=focal
UBUNTU_CODENAME=focal
# uname -a
Linux NShubin 5.5.9-gentoo-x86_64 #1 SMP PREEMPT Mon Mar 16 14:34:52 MSK 2020 armv7l armv7l armv7l GNU/Linux
Хөгжилтэй байхын тулд хамгийн бага багц багцыг (миний хувьд) суулгахын өмнө болон дараа нь хэмжээг хэмжиж үзье.
# du -d 0 -h / 2>/dev/null
63M /
Шинэчилье:
# apt update
# apt upgrade --yes
Бидний сонирхож буй багцуудыг суулгацгаая:
# SYSTEMD_IGNORE_CHROOT=yes apt install --yes autoconf kmod socat ifupdown ethtool iputils-ping net-tools ssh g++ iproute2 dhcpcd5 incron ser2net udev systemd gcc minicom vim cmake make mtd-utils util-linux git strace gdb libiio-dev iiod
Цөмийн толгой файлууд болон модулиуд нь тусдаа асуудал юм. Мэдээжийн хэрэг, бид Ubuntu-ээр дамжуулан ачаалагч, цөм, модуль, төхөөрөмжийн модыг суулгахгүй. Тэд гаднаас бидэн дээр ирэх болно, эсвэл бид өөрсдөө угсарна, эсвэл хавтанг үйлдвэрлэгчээс бидэнд өгөх болно, ямар ч тохиолдолд энэ нь энэ зааварт хамаарахгүй.
До какой-то степени расхождение версий допустимо, но лучше взять их со сборки ядра.
# apt install --yes linux-headers-generic
Юу болсныг харцгаая, тэгээд маш их зүйл болсон:
# apt clean
# du -d 0 -h / 2>/dev/null
770M /
Нууц үг тохируулахаа бүү мартаарай.
Зургийг савлаж байна
$ sudo tar -C rootfs --transform "s|^./||" --numeric-owner --owner=0 --group=0 -c ./ | tar --delete ./ | gzip > rootfs.tar.gz
Нэмж хэлэхэд бид etckeeper-ийг автоматаар түлхэх тохиргоотой суулгаж болно
За, бид угсралтаа тараалаа гэж бодъё, дараа нь системийн өөр өөр хувилбаруудыг хэрхэн хамгийн сайн угсрах ажил эхэлсэн.
etckeeper бидний тусламжид ирж болно.
Аюулгүй байдал нь хувийн асуудал юм:
- Та тодорхой салбаруудыг хамгаалж чадна
- төхөөрөмж бүрт өвөрмөц түлхүүр үүсгэх
- хүчээр түлхэхийг идэвхгүй болгох
- гэх мэт. ...
# ssh-keygen
# apt install etckeeper
# etckeeper init
# cd /etc
# git remote add origin ...
Автомат түлхэлтийг тохируулцгаая
Мэдээжийн хэрэг, бид төхөөрөмж дээр салбаруудыг урьдчилан үүсгэж болно (бид анх удаа ажиллуулахад скрипт эсвэл үйлчилгээ хийе гэж бодъё).
# cat /etc/etckeeper/etckeeper.conf
PUSH_REMOTE="origin"
Эсвэл бид илүү ухаалаг зүйл хийж болно ...
Залхуу арга
Процессорын серийн дугаарыг хэлье (эсвэл MAC - ноцтой компаниуд энэ хүрээг худалдаж авдаг) өвөрмөц танигчтай болцгооё.
муур / proc / cpuinfo
# cat /proc/cpuinfo
processor : 0
model name : ARMv7 Processor rev 5 (v7l)
BogoMIPS : 60.36
Features : half thumb fastmult vfp edsp neon vfpv3 tls vfpv4 idiva idivt vfpd32 lpae evtstrm
CPU implementer : 0x41
CPU architecture: 7
CPU variant : 0x0
CPU part : 0xc07
CPU revision : 5
processor : 1
model name : ARMv7 Processor rev 5 (v7l)
BogoMIPS : 60.36
Features : half thumb fastmult vfp edsp neon vfpv3 tls vfpv4 idiva idivt vfpd32 lpae evtstrm
CPU implementer : 0x41
CPU architecture: 7
CPU variant : 0x0
CPU part : 0xc07
CPU revision : 5
Hardware : Freescale i.MX7 Dual (Device Tree)
Revision : 0000
Serial : 06372509
Дараа нь бид үүнийг түлхэх салбарын нэрэнд ашиглаж болно:
# cat /proc/cpuinfo | grep Serial | cut -d':' -f 2 | tr -d [:blank:]
06372509
Энгийн скрипт үүсгэцгээе:
# cat /etc/etckeeper/commit.d/40myown-push
#!/bin/sh
set -e
if [ "$VCS" = git ] && [ -d .git ]; then
branch=$(cat /proc/cpuinfo | grep Serial | cut -d':' -f 2 | tr -d [:blank:])
cd /etc/
git push origin master:${branch}
fi
Энэ бол хэсэг хугацааны дараа бид өөрчлөлтүүдийг харж, зорилтот програм хангамжийн багцуудын жагсаалтыг үүсгэж болно.
Санал болгож буй материалууд
getdents64 асуудал
Эх сурвалж: www.habr.com