LFS 搭建3 Chroot 以及构建额外工具

本文同步发布于
https://williamgong.github.io/2021/11/27/lfs%E6%90%AD%E5%BB%BA3/

现在开始就要 chroot 了,同时现在开始用户也要从lfsroot
不过这个顺序相比 9.0 差别太大了吧……
那么,现在就su吧。
记得设置$LFS:

export LFS=/mnt/lfs

改变 LFS 系统目录的所有者

毕竟一个正常的系统其系统文件所有者不可能是lfs

chown -R root:root $LFS/{usr,lib,var,etc,bin,sbin,tools}
case $(uname -m) in
x86_64) chown -R root:root $LFS/lib64 ;;
esac

准备虚拟内核文件系统

首先需要建立 dev,proc,sys,run 目录

mkdir -pv $LFS/{dev,proc,sys,run}

创建初始设备节点

主要是nullconsole

mknod -m 600 $LFS/dev/console c 5 1
mknod -m 666 $LFS/dev/null c 1 3

挂载 /dev

mount -v --bind /dev $LFS/dev

挂载虚拟内核文件系统

mount -v --bind /dev/pts $LFS/dev/pts
mount -vt proc proc $LFS/proc
mount -vt sysfs sysfs $LFS/sys
mount -vt tmpfs tmpfs $LFS/run

此外,还要创建一些目录

if [ -h $LFS/dev/shm ]; then
  mkdir -pv $LFS/$(readlink $LFS/dev/shm)
fi

Chroot

chroot "$LFS" /usr/bin/env -i   \
    HOME=/root                  \
    TERM="$TERM"                \
    PS1='(lfs chroot) \u:\w\$ ' \
    PATH=/usr/bin:/usr/sbin \
    /bin/bash --login +h

这时的 bash 会显示 I have no name,因为没有/etc/passwd,这是正常的,虽然有点丑 :D

退出时进入 Chroot 的操作

如果只是退出而不关机/重启的话,直接运行上面的命令就行,不然就要重新挂载这些文件系统。
不过建议每次 chroot 前都检查一次。

创建目录

现在再创建一些还需要的目录

mkdir -pv /{boot,home,mnt,opt,srv}

其实有一些目录已经创建了,但这里为了防止遗漏手册还是加上了这些目录。
现在创建子目录

mkdir -pv /etc/{opt,sysconfig}
mkdir -pv /lib/firmware
mkdir -pv /media/{floppy,cdrom}
mkdir -pv /usr/{,local/}{include,src}
mkdir -pv /usr/local/{bin,lib,sbin}
mkdir -pv /usr/{,local/}share/{color,dict,doc,info,locale,man}
mkdir -pv /usr/{,local/}share/{misc,terminfo,zoneinfo}
mkdir -pv /usr/{,local/}share/man/man{1..8}
mkdir -pv /var/{cache,local,log,mail,opt,spool}
mkdir -pv /var/lib/{color,misc,locate}
ln -sfv /run /var/run
ln -sfv /run/lock /var/lock
install -dv -m 0750 /root
install -dv -m 1777 /tmp /var/tmp

以上目录结构全部基于 FHS,但只加了必要的目录。

创建必要的文件和符号链接

先加上从/etc/mtab/proc的符号链接

ln -sv /proc/self/mounts /etc/mtab

然后是创建一个最简单的/etc/hosts

cat > /etc/hosts << EOF
127.0.0.1  localhost $(hostname)
::1        localhost
EOF

其实这里的$(hostname)在其他发行版里是需要手动改的

创建/etc/passwd

cat > /etc/passwd << "EOF"
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/dev/null:/bin/false
daemon:x:6:6:Daemon User:/dev/null:/bin/false
messagebus:x:18:18:D-Bus Message Daemon User:/run/dbus:/bin/false
systemd-bus-proxy:x:72:72:systemd Bus Proxy:/:/bin/false
systemd-journal-gateway:x:73:73:systemd Journal Gateway:/:/bin/false
systemd-journal-remote:x:74:74:systemd Journal Remote:/:/bin/false
systemd-journal-upload:x:75:75:systemd Journal Upload:/:/bin/false
systemd-network:x:76:76:systemd Network Management:/:/bin/false
systemd-resolve:x:77:77:systemd Resolver:/:/bin/false
systemd-timesync:x:78:78:systemd Time Synchronization:/:/bin/false
systemd-coredump:x:79:79:systemd Core Dumper:/:/bin/false
uuidd:x:80:80:UUID Generation Daemon User:/dev/null:/bin/false
systemd-oom:x:81:81:systemd Out Of Memory Daemon:/:/bin/false
nobody:x:99:99:Unprivileged User:/dev/null:/bin/false
EOF

可以看出这里加上了 systemd 需要的用户。
创建/etc/group

cat > /etc/group << "EOF"
root:x:0:
bin:x:1:daemon
sys:x:2:
kmem:x:3:
tape:x:4:
tty:x:5:
daemon:x:6:
floppy:x:7:
disk:x:8:
lp:x:9:
dialout:x:10:
audio:x:11:
video:x:12:
utmp:x:13:
usb:x:14:
cdrom:x:15:
adm:x:16:
messagebus:x:18:
systemd-journal:x:23:
input:x:24:
mail:x:34:
kvm:x:61:
systemd-bus-proxy:x:72:
systemd-journal-gateway:x:73:
systemd-journal-remote:x:74:
systemd-journal-upload:x:75:
systemd-network:x:76:
systemd-resolve:x:77:
systemd-timesync:x:78:
systemd-coredump:x:79:
uuidd:x:80:
systemd-oom:x:81:81:
wheel:x:97:
nogroup:x:99:
users:x:999:
EOF

这里用户组的标准可以看作 LFS 自己的标准了,其中用户组可以根据需要自行修改。
现在需要创建一个之后的测试中需要用到的用户,不过是临时的,最后会删除。

echo "tester:x:101:101::/home/tester:/bin/bash" >> /etc/passwd
echo "tester:x:101:" >> /etc/group
install -o tester -d /home/tester

现在,赋予 bash 以名字(无故中二 XD):

exec /bin/bash --login +h

还要创建一些日志文件,虽然都是空的:

touch /var/log/{btmp,lastlog,faillog,wtmp}
chgrp -v utmp /var/log/lastlog
chmod -v 664  /var/log/lastlog
chmod -v 600  /var/log/btmp

至此,初步配置完成,现在该安装额外工具了。

构建额外工具

你没理解错,以下部分全部都以root用户编译。

GCC-11.2.0 中的 Libstdc++ - 第二遍

在前面第二遍编译 gcc 时,并没有编译它,因为它不能用宿主机工具链编译。

tar -xvf gcc-11.2.0.tar.xz
cd gcc-11.2.0

创建一个符号链接

ln -s gthr-posix.h libgcc/gthr-default.h

建立build目录

mkdir build
cd build

configure

../libstdc++-v3/configure \
CXXFLAGS="-g -O2 -D_GNU_SOURCE" \
--prefix=/usr \
--disable-multilib \
--disable-nls \
--host=$(uname -m)-lfs-linux-gnu \
--disable-libstdcxx-pch

编译和安装

make
make install

Gettext-0.21

这里只安装msgfmtmsgmerge,以及xgettext这三个程序

tar -xvf gettext-0.21.tar.xz
cd gettext-0.21
./configure --disable-shared
make
cp -v gettext-tools/src/{msgfmt,msgmerge,xgettext} /usr/bin

Bison-3.7.6

tar -xvf bison-3.7.6.tar.xz
cd bison-3.7.6

configure

./configure --prefix=/usr \
--docdir=/usr/share/doc/bison-3.7.6

编译和安装

make
make install

Perl-5.34.0

此处要加一个 patch

tar -xvf perl-5.34.0.tar.xz
cp perl-5.34.0-upstream_fixes-1.patch perl-5.34.0/
cd perl-5.34.0
patch -Np1 -i perl-5.34.0-upstream_fixes-1.patch

configure

sh Configure -des \
-Dprefix=/usr \
-Dvendorprefix=/usr \
-Dprivlib=/usr/lib/perl5/5.34/core_perl \
-Darchlib=/usr/lib/perl5/5.34/core_perl \
-Dsitelib=/usr/lib/perl5/5.34/site_perl \
-Dsitearch=/usr/lib/perl5/5.34/site_perl \
-Dvendorlib=/usr/lib/perl5/5.34/vendor_perl \
-Dvendorarch=/usr/lib/perl5/5.34/vendor_perl

编译和安装

make
make install

Python-3.9.6

这里有两个 python 包,Python-3.9.6.tar.xzpython-3.9.6-docs-html.tar.bz2
解压前面那个,后面的那个包因为没安装bzip2无法解压。
注意区分大小写。

tar -xvf Python-3.9.6.tar.xz
cd Python-3.9.6

configure

./configure --prefix=/usr \
--enable-shared \
--without-ensurepip

编译和安装

make
make install

这里有部分模块是无法编译的,但 make 还是会报错(还是 fatal error),这里只要最外面的 make 执行成功即可。

Texinfo-6.8

tar -xvf texinfo-6.8.tar.xz
cd texinfo-6.8

在编译之前,需要修复在使用 Glibc-2.34 或更新版本时编译会出现的问题

sed -e 's/__attribute_nonnull__/__nonnull/' \
    -i gnulib/lib/malloc/dynarray-skeleton.c

之后

./configure --prefix=/usr
make
make install

Util-linux-2.37.2

tar -xvf util-linux-2.37.2.tar.xz
cd util-linux-2.37.2

根据 FHS 的建议,使用/var/lib/hwclock

mkdir -pv /var/lib/hwclock

configure

./configure ADJTIME_PATH=/var/lib/hwclock/adjtime \
--libdir=/usr/lib \
--docdir=/usr/share/doc/util-linux-2.37.2 \
--disable-chfn-chsh \
--disable-login \
--disable-nologin \
--disable-su \
--disable-setpriv \
--disable-runuser \
--disable-pylibmount \
--disable-static \
--without-python \
runstatedir=/run

编译和安装

make
make install

至此,额外的工具就构建完成了。

清理

首先清理文档

rm -rf /usr/share/{info,man,doc}/*

之后是libtool*.la文件

find /usr/{lib,libexec} -name \*.la -delete

最后删除/tools,现在已经不需要了

rm -rf /tools

备份

这是可选的,但小心一点总没错。
以下操作在 chroot 外进行,且使用root用户。

exit

备份需要至少 1G 空间。
先解除内核虚拟文件系统的挂载:

umount $LFS/dev{/pts,}
umount $LFS/{sys,proc,run}

按照手册默认路径,备份于/root

cd $LFS 
tar -cJpf $HOME/lfs-temp-tools-11.0-systemd.tar.xz .

还原

需要还原时,运行

cd $LFS
rm -rf ./*
tar -xpf $HOME/lfs-temp-tools-11.0-systemd.tar.xz

运行前务必检查$LFS是否正确设置!

不然你宿主系统就 gg 了,rm -rf /*了解一下。

至此,构建临时系统部分结束。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352

推荐阅读更多精彩内容