问题描述
PackageKit,包管理服务,通过 DBus 接口,执行某些简单的包管理任务,比如刷新缓存,安装、更新、移除软件等等。
但是该服务经常占用大量 CPU 资源,非常多,而且一直有人反馈这个问题:
https://gitlab.gnome.org/GNOME/gnome-software/issues/512
https://bugs.launchpad.net/appcenter/+bug/1587975
https://www.reddit.com/r/linuxquestions/comments/55q35o/what_is_packagekitd_and_why_does_it_use_so_much/
https://baheyeldin.com/technology/linux/how-avoid-packagekit-consuming-lots-cpu-and-ram-kubuntu-1404.html
鉴于在系统管理中,我们经常使用 YUM/APT 等等的包管理器,从未使用该服务,因此我们决定关闭该服务。
该笔记将介绍:如何关闭 PackageKit 服务。
附加说明
操作系统:Kali GNU/Linux Rolling
软件版本:packagekit 1.0.1-2
关于该笔记分类:在 Debian 10.3 中,桌面环境(graphical.target)会启动 PackageKit 服务,而多用户环境(multi-user.target)不会启动该服务,因此将该笔记分类到桌面环境设置中。
解决办法
目前(09/02/2019),并没有人找到 CPU 占用高的原因。所以,对于这个问题也没有什么解决方案。卸载的有,禁用的有,这那的都有,都是些 workaround 办法。
第一步、禁用服务
由于依赖的原因,还不能直接删除掉。因此只能禁用服务:
systemctl stop packagekit.service systemctl disable packagekit.service systemctl mask packagekit.service # 如果不mask的话,它还会启动。
第二步、移除配置(可选步骤)
在 Debian 中,当禁用 PackageKit 服务后,执行 apt-get 安装的最后阶段,会产生错误提示:
Error: GDBus.Error:org.freedesktop.systemd1.UnitMasked: Unit packagekit.service is masked.
这是由 /etc/apt/apt.conf.d/20packagekit 导致的。因为在 apt-get install 完成之后,会出触发特定的 PackageKit 钩子,由于我们禁用 PackageKit 服务而导致钩子无法访问该服务,所以禁用该钩子即可:
mv -v /etc/apt/apt.conf.d/20packagekit{,.disabled}
参考文献
- WikiNotes/关闭 PackageKit 服务
- CentOS / RHEL 7 : How to enable or disable automatic updates (via packagekit)
- How to disable PackageKit on CentOS, Fedora or RHEL
- All Debian package managers broken due to Python bug