我想找到一种方法,在 Yocto 生成的操作系统中从 .bbappend 文件对文件运行 sed 脚本。我的操作系统有一个只读的 rootfs,它似乎阻止了安装后脚本的任何可能性。具体来说,我需要对 /etc/default/ssh
进行这些更改(在启动生成的操作系统后运行):
sed -i 's/var\/run/etc/' /etc/default/ssh
sed -i 's/_readonly//' /etc/default/ssh
这是我为解决这些问题而创建的 openssh_7.1p1.bbappend
:
FILESEXTRAPATHS_prepend := "${THISDIR}/files:"
SRC_URI += " \
file://ssh_host_dsa_key.pub \
file://ssh_host_rsa_key.pub \
...
"
do_install_append() {
sed -i 's/var\/run/etc/' ${D}${sysconfdir}/default/ssh
sed -i 's/_readonly//' ${D}${sysconfdir}/default/ssh
# these lines work fine
install -m 0755 ${WORKDIR}/ssh_host_dsa_key ${D}/etc/ssh
install -m 0755 ${WORKDIR}/ssh_host_dsa_key.pub ${D}/etc/ssh
...
}
FILES_${PN} += "${sysconfdir}/default/ssh"
#these lines work
FILES_${PN} += "${sysconfdir}/ssh/ssh_host_dsa_key"
FILES_${PN} += "${sysconfdir}/ssh/ssh_host_dsa_key.pub"
...
BitBake 在 do_install_append()
执行期间失败并出现此错误:
sed: can't read ${TMPDIR}/work/x86-poky-linux/openssh/image/etc/default/ssh: No such file or directory
(其中 TMPDIR 是我实际的 tmp 目录)显然这个文件不存在,因为正确的副本是在单独的 MULTIMACH_TARGET_SYS
目录中创建的(即不是 x86-poky-linux
) 由 image.bbclass。
是否可以在 .bbappend 文件(或其他一些分隔方式)中执行此类操作?我找到了一种在 .inc 文件中使用 ROOTFS_POSTPROCESS_COMMAND
在我的核心镜像中执行此操作的方法,但这种方法会导致组织结构不佳。
最佳答案
也许将操作转移到 post-installation .bbappend 中的函数是否适合您的情况?
pkg_postinst_${PN} () {
#!/bin/sh
if [ x"$D" = "x" ]; then
sed -i 's/var\/run/etc/' /etc/default/ssh
sed -i 's/_readonly//' /etc/default/ssh
else
exit 1
fi
}
上面的函数将导致 sed 操作在第一次启动时执行,而不是在构建期间执行。
关于linux - 我应该如何在 Yocto 生成的 rootfs 上 sed 文件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34318288/