我正在进行预置安装,其中涉及debconf
在 debian 安装程序中显示 INFO 消息。在 late_command 结束时,我希望系统弹出安装 cdrom,并重新启动我的实例。问题是,它不是以这种方式运行,而是返回到 debian 安装程序菜单,为了完成安装过程,它只留下了手动关闭和从磁盘引导以弹出安装 cdrom 的选项。
重要的是要准确地说,这种意外行为仅在我开始使用debconf INFO
消息时出现(它之前按预期工作,因此preseed.cfg
通常正确配置),因此它与它直接相关。
以下是以下内容:我的,late_command part
由其启动的脚本,安装完成的时间,以及我被引导回来的屏幕。late_command
debconf
syslog
late_command
:
d-i preseed/late_command string \
cp -rf /cdrom/build /target/home/device; \
/bin/sh /target/home/machine/build/deployment-preseed-track.sh; \
chmod +x /target/home/machine/build/deployment-preseed.sh; \
in-target --pass-stdout ./home/machine/build/deployment-preseed.sh > /target/var/log/installation.log; \
in-target rm -rf /home/machine/build;
deployment-preseed-track.sh
(它基本上是通过扫描日志来检测部署进度)
#!/bin/sh
. /usr/share/debconf/confmodule
. "/home/machine/build/variables.sh"
logFile="/target${INSTALLATION_LOG_LOCATION}"
templatePath="/target/tmp/deployment_progress_tracker.templates"
cat > "${templatePath}" << 'EOF'
Template: deployment_progress_tracker/progress/fallback
Type: text
Description: ${STEP}...
EOF
debconf-loadtemplate deployment_progress_tracker "${templatePath}"
db_progress START 0 1 deployment_progress_tracker/progress
watchLogs () {
deploymentDone=false
while ! $deploymentDone
do
if [ -f "${logFile}" ]; then
step=$(grep -E -o -a -h "Progress-step: .*" "${logFile}" | tail -1 | sed 's/Progress-step: //')
if [ -z "${step##*$DEPLOYMENT_FINISHED*}" ]; then
deploymentDone=true
elif [ -n "${step}" ]; then
db_subst deployment_progress_tracker/progress/fallback STEP "${step}"
db_progress INFO deployment_progress_tracker/progress/fallback
fi
fi
sleep 3
done
}
经过几天的尝试失败后,我会回复自己。
Debconf 不是罪魁祸首。发生的事情是我编排脚本调用的方式(后台跟踪器和前台部署脚本)没有给 debian 安装程序以干净、预期的方式杀死后台脚本的机会。只要部署脚本被不一致地终止或未终止,就会随机导致部署成功或失败。
在了解发生了什么之前,我很难尝试使用 debconf,但自从我终于明白了,这就是我最终让它每次都能无缝工作的结果。
我没有将部署脚本
deployment-preseed.sh
作为前台进程启动,将跟踪器deployment-preseed-track.sh
作为后台进程启动,而是完全相反,即:deployment-preseed-track.sh
作为前台进程和deployment-preseed.sh
后台进程。我相应地更新了
late_command
: