NOTE(simon): 讲啰嗦一点,方便搜索引擎收录关键字。需要解决方案的同学,可以直接拖到后半部分。

旧办法不灵

不知道什么原因,CentOS 7 下面安装 dnf 总是要出错,各种各样的问题与不兼容。CentOS 直到现在,还没有正式支持 dnf。相反,Fedora 22 开始就已经正式支持 dnf 作为默认的包管理工具了。差距啊。

之前试过用一个半官方的 dnf repo(rpmsoftwaremanagement/dnf-nightly Copr) 在 CentOS 7 下面安装 dnf,一直都是可以的。也可以正常升级。以前通过这个办法安装过 dnf 的系统,已经升级到 2.8.5。用起来很顺。

但是不知道为什么,最近用这个库,在全新的 CentOS 7 下面安装 dnf,遇到一个麻烦,就是包版本有冲突。类似的错误信息如下。

# yum install -y dnf-2.8.5-0.101g0f20917d.el7.centos
Loaded plugins: fastestmirror
Loading mirror speeds from cached hostfile
 * base: mirrors.shu.edu.cn
 * epel: mirrors.yun-idc.com
 * extras: mirrors.163.com
 * updates: mirrors.163.com
Resolving Dependencies
--> Running transaction check
---> Package dnf.noarch 0:2.8.5-0.101g0f20917d.el7.centos will be installed
--> Processing Dependency: python2-dnf = 2.8.5-0.101g0f20917d.el7.centos for package: dnf-2.8.5-0.101g0f20917d.el7.centos.noarch
--> Running transaction check
---> Package python2-dnf.noarch 0:2.8.5-0.101g0f20917d.el7.centos will be installed
--> Processing Dependency: rpm-plugin-systemd-inhibit for package: python2-dnf-2.8.5-0.101g0f20917d.el7.centos.noarch
--> Running transaction check
---> Package rpm-plugin-systemd-inhibit.x86_64 0:4.11.3-32.el7 will be installed
--> Processing Conflict: python2-librepo-1.9.2-2gc670c6b.el7.x86_64 conflicts python2-dnf < 2.8.8
--> Finished Dependency Resolution
Error: python2-librepo conflicts with python2-dnf-2.8.5-0.101g0f20917d.el7.centos.noarch
 You could try using --skip-broken to work around the problem
 You could try running: rpm -Va --nofiles --nodigest

重点在这句,librepo-1.9.2-2gc670c6b.el7.x86_64 conflicts python2-dnf < 2.8.8

版本依赖关系树中提到的 python2-dnf 2.8.8,在 repo 中尚未发布。很明显的,dnf 2.8.5 依赖 python2-dnf 2.8.5 才对。事实也是,python2-dnf 最新的版本号是 2.8.5。

无论如何也解决不了这个难题。毕竟人家是 nightly,夹带一点私货也正常。

难道只能 build from source?不科学。dnf 是自展的,编译 dnf 需要用到 dnf。可手里是全新 CentOS 7。

  • 半官方的 dnf nightly repo。FAILED
  • build from source。FAILED

解决办法

然后,在找 dnf 2.7.5 rpm 的时候,被我发现一个隐藏的 repo。也算是半官方的吧。亲测可用。完美。用法如下。

NOTE(simon): 2018-10-09 亲测有效

cat <<EOF > /etc/yum.repo.d/another-dnf.repo
[another-dnf]
name=Another DNF Repo by CentOS.
baseurl=https://cbs.centos.org/repos/configmanagement7-dnf-common-release/\$basearch/os/
type=rpm-md
skip_if_unavailable=True
gpgcheck=0
repo_gpgcheck=0
enabled=1
enabled_metadata=1
EOF
yum clean all
yum makecache fast
yum install -y dnf dnf-conf dnf-automatic dnf-plugins-core

这是个 ConfigManagement SIG 的社区项目,但是没有用 ConfigManagement SIG 的 GPG 证书签名,也没有出现在社区 wiki (SpecialInterestGroup/ConfigManagementSIG - CentOS Wiki) 中,我理解属于边缘项目。不过依赖有效,能直接安装。

啥都不说了,只希望这次这个 dnf 的 repo 坚持久一点。

思考

为什么 dnf 这么棒的工具在 Fedora 里面有,在 CentOS 里面就没有?我猜测,主要还是考虑稳定性。毕竟 CentOS 一直的策略都是以降级保稳定。dnf 还没过官方的考验期,所以一直没予以替换。既往所有的 repo 都是非官方的,最多也只能算是半官方的。