update -alternatives命令是一种常用方法,用于指定各种替代程序中的哪一个应该是几类程序(网络浏览器、编辑器等)中的每一个的默认程序。我认为用户更改默认值的正常方法是运行类似sudo update-alternatives --config gnome-www-browser
各种应用程序依赖于其他指定默认浏览器的方法(参见例如'xdg-open')。
但我这里的问题集中在priority
配置设置的含义和策略上。手册页说明:
每个备选方案都有一个与之关联的优先级。当链接组处于自动模式时,组成员指向的备选方案将是那些具有最高优先级的备选方案。
它还指出,提供相同文件的不同包需要合作完成。
我想了解这些优先事项是如何设计的:
- 谁决定优先级?
- 是否期望用户修改它们?
- 在打包一个程序的时候,这些优先级应该怎么设置呢?
- 有没有一种简单的方法可以查看所有 Ubuntu 软件包对每个替代方案使用的优先级,作为当前实践的指南?我想官方包比附加回购协议中的包更容易,但是给定一个回购协议,我想它也可以被查询。
- 对于在官方存储库之外打包应用程序的组织,我们应该有什么期望?
- 软件包是否应该询问用户是否要在安装时更改默认设置?
在阅读Microsoft Edge is Now Taking Over as Your Default Browser… on Linux后,我遇到了这个问题,它记录了 Microsoft 为基于 Debian 的系统打包的 Edge 如何作为浏览器被赋予 200 的优先级(带有评论# Good enough to be the default.
). x-www-browser
在我的 Ubuntu 20.04 系统上,和的其他优先级gnome-www-browser
是:
$ update-alternatives --display x-www-browser
x-www-browser - auto mode
link best version is /usr/bin/microsoft-edge-stable
link currently points to /usr/bin/microsoft-edge-stable
link x-www-browser is /usr/bin/x-www-browser
/usr/bin/firefox - priority 40
/usr/bin/google-chrome-beta - priority 150
/usr/bin/microsoft-edge-stable - priority 200
我安装了官方的 Ubuntu chromium-based 浏览器chromium
,现在使用的是snap
. 但它没有出现在备选方案中。
我还没有安装 google-chrome-stable。他们是否也使用 200 的优先级?
当备选方案之间的优先级值存在联系时会发生什么?
非常感谢。
进行包装的人员或团队决定了优先级。在 Ubuntu 中,每个 Ubuntu Flavor 的默认应用程序默认值由使用该 Flavor 的团队合作设置。请注意,应用程序(但不是默认应用程序)也可以使用元数据包而不是 deb 控制字段来设置。叹。这是一个丰富的挂毯。
用户可以通过几种不同的方式告诉系统他们想要哪个应用程序作为默认应用程序,并且用户的选择会覆盖打包程序的优先级。在应用程序安装期间不会询问(也不应该!)如果他们的新应用程序因窃取默认值而出现异常,他们可以将默认值改回。
用户最常抱怨的问题之一是系统有时会问他们一些他们认为不相关或根本不理解的问题。这就是为什么,例如,Ubuntu 安装程序会问最少数量的问题来安装一个工作系统。
不询问就窃取默认值的应用程序可能被视为错误,并且当包到达 Ubuntu 时,上游优先级可能会更改。
Debian 和 Ubuntu 都没有分发 Edge 和 Chrome 的例子,你可以看到打包者在竞争窃取用户而不是合作。他们是坏邻居,也许他们的软件可能会被避开,直到他们行为端正。这并不奇怪:未能满足通过 Debian/Ubuntu 分发的最低开源标准的组织已经证明他们是不合作的。
最后,snap 应用程序目前通常与 Debian/Ubuntu 更新替代系统不兼容,没有一点杂乱无章。原因:update-alternatives 仅适用于 Debian,而 Snaps 是跨平台的。Snapd 是开源的,因此欢迎任何想要使它们协同工作的人参与进来。