在Debian系统中,由于各种原因可能会导致软件包损坏或安装失败。本教程将详细介绍如何从这些损坏的系统中恢复软件包,并提供相应的解决方案和技巧。通过掌握这些知识将能够更有效地管理和使用Debian系统,确保软件包的稳定运行和安全使用。
一、缺少依赖
如果通过”sudo dpkg -i …”强制安装一个软件包到系统,而不安装它所依赖的所有软件包,这个软件包将作为“部分安装”而失败。
应当安装所有依赖的软件包,使用 APT 系统或者 “sudo dpkg -i …”。然后,使用下列命令来配置所有部分安装的软件包。
# dpkg --configure -a
二、软件包数据缓存错误
软件包数据缓存错误,能够造成奇怪的错误,比如 APT 的 “GPG error: … invalid: BADSIG …”。
应该通过 “sudo rm -rf /var/lib/apt/* ” 删除所有缓存的数据,然后重新尝试。(如果使用了 apt-cacher-ng,还应运行”sudo rm -rf /var/cache/apt-cacher-ng/* “。 )
三、不兼容旧用户配置
如果一个桌面 GUI 程序在重要的上游版本升级后变得不稳定,应该怀疑这是旧的本地配置文件(由它创建的)所导致的。如果它在新建的用户账号下运行稳定,那么这个假设就得到了证实。(这是一个打包的 bug 并且打包者通常会避免它。)
为了恢复稳定,应该移除相应的本地配置文件并重新启动 GUI 程序。可能需要阅读旧的配置文件内容以便之后恢复配置信息。
四、不同软件包
文档级的软件包管理系统,比如说 aptitude(8) 或 apt-get(1), 使用软件包依赖,当出现相同文件时,不会尝试去安装软件包。
软件包维护者的错误,或者系统管理员配置了不一致的档案库混合源,都会出现不正确的软件包依赖情况。如果在出现相同文件的情况下,通过 aptitude(8) 或 apt-get(1) 安装软件包,dpkg(1) 在对软件包解包时,确定会给调用程序返回错误,并不会覆盖已经存在的文件。
使用第三方软件包会导致重大的系统风险,因为其通过使用 root 权限运行维护者脚本能够对系统做任何事。dpkg(1) 命令只防止解包时的覆盖行为。可以先通过删除旧的令人讨厌的软件包,old-package,来解决这类错误的安装问题。
$ sudo dpkg -P old-package
五、修复软件包脚本
当软件包脚本中的一个命令由于某些原因返回错误,脚本也将由于错误而退出,软件包管理系统忽略它们的行为,并导致部分安装的软件包。当一个软件包在它的删除脚本中有错误时,该软件包将会成为不可能删除的软件包,处理这些问题,都会变得相当棘手。
对于 “package_name” 的软件包脚本问题,应该查看下列的软件包脚本。
- “/var/lib/dpkg/info/package_name.preinst”
- “/var/lib/dpkg/info/package_name.postinst”
- “/var/lib/dpkg/info/package_name.prerm”
- “/var/lib/dpkg/info/package_name.postrm”
使用下列的方法,以 root 编辑损坏的软件包脚本。
- 在行首添加 “#” 可以禁用出错的行;
- 在出错行的行尾添加 “|| true” 可以强制返回成功。
六、使用dpkg命令
因为 dpkg 是非常底层的软件包工具,它可以在很糟糕的情况下进行工作,例如无法启动系统且没有网络连接。让我们假定 foo 软件包损坏了,并且需要更换。
可以在软件包缓存目录:“/var/cache/apt/archives/” 中找到旧的 foo 软件包的无 bug 版本。(如果找不到,可以从档案库 https://snapshot.debian.org/ 中下载它,或从具有软件包缓存功能的机器中拷贝它。)
如果能够启动系统,可以通过下列命令来安装它。
# dpkg -i /path/to/foo_old_version_arch.deb
如果系统无法从硬盘启动,应该寻找其它方式来启动它。
- 使用 Debian 安装光盘以救援模式启动系统;
- 将硬盘上无法启动的系统挂载到 “/target”;
- 通过下列命令安装旧版本的 foo 软件包。
# dpkg --root /target -i /path/to/foo_old_version_arch.deb
即使位于硬盘上的 dpkg 命令已损坏,该命令依旧可以执行。
任何由硬盘、live GNU/Linux CD、可启动的 USB 驱动或网络启动上的另一系统启动的 GNU/Linux 系统到可以类似地用来救援损坏的系统。如果由于依赖问题,无法用这种方式安装软件包,并且真的必须真么做,可以使用 dpkg 的 “–ignore-depends”、“–force-depends” 和其它选项来无视依赖。如果这么做了,之后必须认真努力地修复依赖关系。
如果系统严重损坏了,应该将系统完整备份到一个安全的地方(参见 第 10.2 节 “备份和恢复”)并进行一次全新的安装。这是耗时较少且效果较好的办法。
七、恢复软件包选择数据
如果 “/var/lib/dpkg/status” 因为某种原因出现错误,Debian 系统会丢失软件包选择数据并受到严重影响。寻找位于 “/var/lib/dpkg/status-old” 或 “/var/backups/dpkg.status.*” 中旧的 “/var/lib/dpkg/status” 文件。
给 “/var/backups/” 分配一个单独的分区是一个好习惯,因为这个目录包含了许多重要的系统数据。对于严重的损坏,我建议备份系统后重新安装。即使失去 “/var/” 中的所有数据,依旧可以从 “/usr/share/doc/” 目录恢复一些信息来引导进行新的安装。
重新安装最小(桌面)系统:
# mkdir -p /path/to/old/system 将旧系统挂载到 “/path/to/old/system/”。 # cd /path/to/old/system/usr/share/doc # ls -1 >~/ls1.txt # cd /usr/share/doc # ls -1 >>~/ls1.txt # cd # sort ls1.txt | uniq | less
然后就可以根据软件包名称来进行安装了。(可能会有一些非软件包名称,例如 “texmf”。)