yum使用tips

找到系统尚未安装的工具命令属于哪个rpm包

经常会在需要使用某个工具软件的时候,不知道应该安装哪个rpm软件包。虽然 rpm.pbone.net 提供了在线搜素软件包的功能,不过,对于使用YUM管理的服务器,实际上可以通过yum provides命令来找到对应软件包,或者使用yum whatprovides命令。

以下举例寻找哪个软件包提供了命令lssubsys

yum provides pstack

yum whatprovides pstack

输出显示

Loaded plugins: branch, fastestmirror
Loading mirror speeds from cached hostfile
alios.7u2.base.x86_64/x86_64/filelists_db      | 6.7 MB  00:00:00
ops.7.noarch/7/filelists_db                    | 182 kB  00:00:00
ops.7.x86_64/7/x86_64/filelists_db             | 309 kB  00:00:00
taobao.7.noarch.stable/filelists_db            |  48 kB  00:00:00
taobao.7.x86_64.stable/filelists_db            |  11 MB  00:00:00
gdb-7.6.1-80.1.alios7.x86_64 : A GNU source-level debugger for C, C++, Fortran, Go and other languages
Repo        : alios.7u2.base.x86_64
Matched from:
Filename    : /usr/bin/pstack

可以看到gdb软件包提供了该pstack工具命令。

参考How to find out which package a file belongs to?

yum使用代理服务器

有时候需要使用polipo这样的代理服务器访问internet资源,如果偶尔使用yum安装软件包,可以设置当前用户环境变量http_proxy来实现安装:

如果要一直使用代理服务器方式,则修改/etc/yum.conf配置文件,添加:

参考Using yum with a Proxy Server

查看软件包属于哪个仓库

  • yum list 软件包可以显示软件包的详细版本,并且可以显示软件包属于哪个软件库

部署oVirt v3.6 的时候,在engine关机控制台添加host后,软件包安装到node节点的时候出现报错:

我检查了是可以安装glusterfsglusterfs-cli软件包的,但是yum search vdsm却只有vdsm-jsonrpc-java.noarch,不像以前安装的ovrit节点有大量的vdsm软件包。Ovirt 3.5 problem adding GlusterFS servers 提示需要检查服务器即诶单是否有vdsm-gluster软件包。

检查 /usr/share/ovirt-host-deploy/plugins/ovirt-host-deploy/gluster/packages.py 果然有:

那么究竟是谁提供了这个软件包?在节点上使用命令yum list vdsm-gluster发现是最早安装的ovirt-3.5提供了这个软件包(后来又升级到ovirt-3.6反而没有这个软件包)

检查 http://resources.ovirt.org/pub/ovirt-3.5/rpm/el6Server/noarch/ 果然有这个软件包,而且版本要高于EPEL提供的版本。所以删除掉EPEL仓库,添加 @ovirt-3.5 仓库,即再增加 /etc/yum.repos.d/ovirt-3.5.repo (和ovirt-3.6.repo并存,内容是从ovirt-3.6.repo复制并修改版本号成3.5)。这样就可以使用ovirt 3.5仓库中的软件包,同时由于ovirt 3.6中相关软件版本较新,也不会错误覆盖

总之,使用yum list 软件包名字可以找寻出对应的软件仓库,也就可以进一步排查问题的原因

避免升级部分软件包

如果由于一些原因需要保持系统中某些软件包不升级,如兼容性,特定测试,则可以通过在/etc/yum.conf中添加 exclude=配置行来跳过:

举例,如果要过滤掉所有32位软件包:

命令行也可以传递给yum需要屏蔽的软件包,例如:

就不会升级 glibc。并且 --exclude= 参数也可以使用 -x 来代替,上述命令就是

要传递多个不包含的包

如果要比较好地管理不包含的软件包,则可以用分开的配置版本,例如 /etc/yum.repos.d/mongodb.repo 包含mangodb的管理配置

如果要临时关闭exclude,可以使用命令

或者

yum versionlock插件

  • 可以通过 yum-versionlock 实现版本锁定:

  • 然后检查 /etc/yum/pluginconf.d/versionlock.conf 有内容

  • /etc/yum/pluginconf.d/versionlock.list 添加要锁定的版本:

关闭repo仓库升级

  • 检查当前仓库

  • 关闭某个仓库升级

当然也可以直接编辑仓库配置文件,将配置文件修改成 enabled=0 也就关闭了该仓库使用。

yum updateyum upgrade的差别

参考 yum update和upgrade的区别?

yum updateyum upgrade的功能是一样的,都是将需要更新的package更新至软件源中的最新版。唯一不同是:yum upgrade会删除旧版本的package,而yum update则会保留。

注意!如果你的某些软件依赖旧版本的package,请使用yum update

yum equivalent to apt-get upgrade vs apt-get dist-upgrade?有详细说明:

yum update只是升级软件包到新版本。例如,foo-awesome淘汰替换了foo,但是yum update不会将foo更改升级成foo-awesome。必须加上--obsoletes这个开关这样yum update才会进行扩展检查来提供更新路径。

yum upgrade则相当于yum --obsoletes update,也就是可以直接将旧软件包体换成新的软件包,这样foo就会被升级体换成foo-awesome。通常,由于某些软件依赖旧版本软件包来运行,则应该使用yum update,如果没有这种旧版兼容要求,则可以使用yum upgrade,以便能够使用最新的软件体系。

在线维护的服务器,通常求稳定,可能使用yum update较安全一些。此外,需要做好完整的兼容稳定性测试。

如果希望yum update时避免更新内核,可以使用yum --exclude=kernel* update。见前述避免升级部分软件包,通过配置文件yum.conf也可以达到相同效果。

参考

Last updated

Was this helpful?