我想在嵌入式设备(mips)上运行 Linux,它有一些非常严格的限制:
- 只有 16MB 的存储空间
- 没有有线以太网(只有wifi)
好消息:
- 我有一个有效的引导加载程序(u-boot)
- 我也有一个工作内核(版本 3.10.14 #2 PREEMPT)
- 我有一个工作的根文件系统(linux 可以启动并且我可以登录)
现在的问题是我没有更多空间可以在这个硬件上运行任何用户应用程序,这就是我想要转向 NFS 的原因。
在这里,我不确定程序。
正如我所提到的,引导过程由 U-boot 处理。但是 U-boot 无法初始化 Wifi - 因此我需要一些小型 Linux 操作系统来实现这个目的。
大意
- U-boot 加载内核并启动它
- 内核包含 wifi 芯片的驱动程序并挂载 rootfs
- rootfs 包含连接 AP 所需的文件(密码、ssid 等)
- 一旦连接建立,NFS 会将远程 fs 挂载到 /opt 或其他东西
是否可以用 NFS 上的文件系统替换根 (/) 文件系统?(尽管 wifi 配置存储在此分区上,这是启动连接所必需的)
更新
我已经成功地为 mips 编译了 nfs 客户端程序,并且设备现在能够通过 nfs 将新的 rootfs 挂载到某个目录中,但是pivot_root失败:
# mount -o nolock IPADDRESS:/srv/fs /tmp/nfs
# ls /tmp/nfs
bin
etc
...
# ls /tmp
nfs
old
# pivot_root /tmp/nfs /tmp/old
pivot_root: Invalid argument
# pivot_root
BusyBox v1.29.0.git (2018-06-23 20:08:52 CEST) multi-call binary.
Usage: pivot_root NEW_ROOT PUT_OLD
Move the current root file system to PUT_OLD and make NEW_ROOT the new root file system
是的——而且你基本上在做与 Linux PC 上的 initramfs 相同的事情。
/
initramfs 像内存中rootfs上的普通根文件系统一样启动;然后它将真正的根文件系统安装在 /mnt 或 /real 的某个位置。(这实际上通常用于在服务器上实现 NFS-root,在内核的内置 NFS 支持不足的情况下——例如,当需要 Kerberos 时。)
重要的一步是使用pivot_root()系统调用将当前根与新安装的根交换。调用之后,原来的 rootfs 仍然保持挂载状态,但不再位于 / - 调用将挂载移动到“新”rootfs 的子目录。
Busybox(以及 util-linux)中还有一个
pivot_root
程序,如果您的 init 进程是 shellscript(通常是这种情况),则可以使用该程序。链接的 util-linux 手册页有其用法示例。或者,根据Linus的说法,只需chroot()进入新安装的根目录就足够了——也就是说,如果您不再需要访问原始根目录。同样,有一个
chroot
命令行工具。注意:您不需要构建和使用 initramfs 来实现此目的;这些函数不关心它们是从 initrd 映像还是从真正的 rootfs 调用的。
然而,因为“正常”的 initramfs 是从一个临时的内存中解压文件系统运行的,所以对于喜欢
switch_root
在转到新根目录之前删除所有 initramfs 文件的工具来说,这是习惯性的。但是,如果您直接从磁盘文件系统引导,这可能不是您想要的,因此请务必不要使用该switch_root
工具,仅pivot_root
.