linux: 进入 Anaconda 调试模式调试系统安装过程

198 阅读4分钟

在 Red Hat 系统的定制安装过程中,Kickstart 文件可以帮助实现自动化安装,但遇到问题时,调试过程可能会比较复杂。如果在系统的 Kickstart 安装过程中某些命令失败,或我们需要对安装进行自定义调整,Anaconda 提供了非常有用的调试功能,能够帮助我们进行深入分析。 通常使用 Ctrl + Alt + F2Ctrl + Alt + F3 切换到其他 TTY 终端,然后手动执行所需的命令,查看系统的状态。

在本文中,我将介绍如何利用 Ctrl + Alt + F2 的方法在 Anaconda 安装过程中进入调试环境,并通过几个简单的步骤使安装调试更加方便。

screen_shot_2019-06-12_at_1.58.39_pm.png

1. 进入 Anaconda 调试环境

在 Kickstart 文件执行过程中,Anaconda 提供了多个虚拟终端(TTY)供用户使用。通常,按 Ctrl + Alt + F2 可以切换到一个新的终端,而不影响当前的安装过程。这种方式允许我们在 Anaconda 安装的同时执行以下操作:

  • 检查文件系统的挂载状态
  • 查看日志
  • 手动执行命令

这是在图形化或文本模式下安装时非常有用的功能。特别是在 Kickstart 文件的 post 阶段出现问题时,能快速通过该方式进入系统并进行修复。

2. 挂载信息及命令行调试

通过 Ctrl + Alt + F2 进入调试模式后,我们可以在新打开的终端中执行命令来检查系统状态,例如使用 df -h 来查看文件系统的挂载信息。如下图所示,我们可以检查 /mnt/sysimage 是否正确挂载,这是新安装系统的根文件系统。

Filesystem      Size  Used Avail Use% Mounted on
devtmpfs        1.9G     0  1.9G   0% /dev
tmpfs           2.0G   24K  2.0G   1% /dev/shm
/dev/vda4       3.9G  2.7G  1.0G  73% /run/install/isodir
/dev/vda3        25G  5.6G   18G  25% /mnt/sysimage

此时我们可以通过 chroot /mnt/sysimage 进入新安装的系统环境,并进行更多的调试操作,例如配置网络、修复包管理器,甚至手动完成一些 Kickstart 文件未能正确执行的操作。

3. 调试的典型场景

  • 网络问题调试:如果安装过程需要从网络上获取软件包,但由于网络配置问题失败,可以通过 Ctrl + Alt + F2 进入系统,然后手动配置网络并尝试恢复。

    nmcli device status   # 查看网络状态
    nmcli connection up <连接名称>  # 启用网络连接
    ping <测试地址>  # 测试网络连通性
    
  • 日志查看:安装过程中遇到的问题可以通过查看日志来分析。我们可以检查 /var/log/anaconda/ 目录中的日志文件,以查明错误发生的具体原因。

    less /var/log/anaconda/anaconda.log
    
  • 自定义安装命令执行:有时我们希望在安装过程中执行特定的命令,例如安装额外的包或修改系统配置文件。在进入调试终端后,可以手动执行这些命令并检查结果。

4. 如何在 Kickstart 文件中添加调试暂停点

为了在某些关键的调试点让安装过程暂停,您可以在 Kickstart 文件的 post 阶段添加 read 命令,这将使系统暂停,等待用户输入。

%post
echo "Pause for debugging. Press Enter to continue."
read

这样做的好处是,您可以在安装过程中插入暂停点,通过 Ctrl + Alt + F2 进入调试模式,检查系统状态。当一切正常后,按下 Enter 继续安装过程。

5. 使用 chroot 进入新安装的系统

为了更加深入地调试新安装的系统,可以通过 chroot 命令进入安装环境,并在新安装的系统中执行命令。例如:

chroot /mnt/sysimage

进入后,您可以像正常系统一样操作,检查网络配置、查看服务状态,甚至修复潜在的错误。在完成调试后,输入 exit 退出 chroot 环境,并继续安装。

6. 结束调试并恢复安装

完成所有调试步骤后,我们可以通过在调试终端输入 exit 来退出终端或调试模式,系统会继续执行剩余的安装步骤,直到安装完成。

总结

通过 Ctrl + Alt + F2 进入调试模式并在安装过程中进行手动干预是一种非常实用的调试手段。无论是检查挂载点、查看日志,还是手动执行命令,这种方式都能够帮助我们快速定位问题,尤其是在定制化系统安装过程中遇到的复杂问题。

调试技巧总结

  • 使用 Ctrl + Alt + F2 进入调试终端
  • 检查挂载点和系统状态
  • 查看 Anaconda 的日志文件
  • 使用 chroot 进入新安装系统进行深度调试

这种方法让我们能够在系统自动化安装过程中手动介入,极大地提高了安装调试的灵活性和效率。通过这种方法,我们可以快速定位并修复潜在问题,确保系统顺利安装。