程序包管理器将编译好的文件打包成一个或有限的几个文件,可用于实现便捷的安装、卸载、升级、查询,校验等程序管理。 centos常用的程序管理器有rpm和yumrpm: redhat package manager, RPM is Package Manager
rpm是由红帽公司开发的软件包管理方式,使用rpm我们可以方便的进行软件的安装、查询、卸载、升级等工作。但是rpm软件包之间的依赖性问题往往会很繁琐,尤其是软件由多个rpm包组成时。
RPM包的命名例如,bash-4.3.2-1.centos6.x86_64.rpmrpm的应用安装rpm {-i|--install} [install-options] PACKAGE_FILE ...
-i 安装
-v 显示详细信息,可叠加使用查看更加详细信息,如-vv,-vvv
-h 显示进度,用50个#来作为进度条
我们一般组合使用-ivh来安装rpm包
--nodeps 取消依赖关系
--replacepkgs 重新安装
--test 测试安装,而不是真正安装
举例:
[root@localhost ~]# rpm -ivh package.rpm
升级rpm {-U|--upgrade} [install-options] PACKAGE_FILE ...
如果有较旧的版本程序包,则升级安装;若没有,则直接安装
rpm {-F|--freshen} [install-options] PACKAGE_FILE ...
如果有较旧的版本程序包,则升级安装;若没有,则终止
我们一般组合使用-Uvh、-Fvh来安装rpm包
[install-options]
--oldpackage 降级安装
--force 忽略冲突,强制执行
注意:
不要对内核包执行升级操作;linux支持多版本内核并存,因此,对新版本内核可直接安装;
如果原程序包的配置文件安装后曾被改动,升级时,新版本的文件并不会直接覆盖老版本的文件,而是把新版本的文件重命(加后缀.rpmnew)名后保留;
举例:
[root@localhost ~]# rpm -Uvh package.rpm
卸载rpm {-e|--erase} [--allmatches] [--nodeps] [--noscripts] [--notriggers] [--test] PACKAGE_NAME ...
--nodeps 忽略依赖关系
--test 卸载测试
举例:
[root@localhost ~]# rpm -ev package
查询rpm {-q|--query} [select-options] [query-options]
[select-options]
1、查询该包是否安装
rpm -q PACKAGE_NAME...
2、查询已安装的所有包
rpm -qa
3、查询某文件是由哪个包安装生成
rpm -qf /path/to/somefile
4、查询尚未安装包的相关信息
rpm -qp PACKAGE_FILE
[query-options]
1、查询某包的简要说明信息
rpm -qi PACKAGE_NAME
2、查询某包安装后生成的所有文件列表
rpm -ql PACKAGE_NAME
3、查询某包安装后生成的所有配置文件列表
rpm -qc PACKAGE_NAME
4、查询某包安装后生成的所有帮助文件列表
rpm -qd PACKAGE_NAME
5、查询某rpm包制作时随版本变化的changelog列表信息
rpm -q --changelog PACKAGE_NAME
6、查询某包提供的capabilities
rpm -q --provides PACKAGE_NAME
7、查询某包所依赖的capabilities
rpm -q --requires PACKAGE_NAME
8、查询某包安装卸载时的脚本
rpm -q --scripts
安装卸载时的脚本有四种:
preinstall: 安装前执行的脚本
postinstall: 安装后执行的脚本
preuninstall: 卸载前执行的脚本
postuninstall: 卸载后执行的脚本
举例:
查询系统中所有已安装 RPM 包
[root@localhost ~]# rpm -qa
查询 RPM 包中包含的文件列表
[root@localhost ~]# rpm -qlp package
查询 RPM 包中包含的帮助文件列表
[root@localhost ~]# rpm -qdp package
校验rpm {-V|--verify} [select-options] [verify-options]
常用用法:rpm -V PACKAGE_NAME
文件改动后校验会有下列相关信息提示:
5:文件的MD5校验值
S:文件大小
L:链接文件
T:文件创建的时间
D:设备文件
U:文件的用户
G:文件的用户组
M:文件的权限
举例:
先用vim对yum.conf文件进行修改,再进行校验
[root@localhost ~]# rpm -V yum.conf
S.5....T. c /etc/yum.conf
包来源合法性及完整性验正rpm --import PUBKEY ...
导入密钥
rpm {-K|--checksig} [--nosignature] [--nodigest] PACKAGE_FILE ...
验证密钥
--nosignature: 不检查来源合法性
--nodigest: 不检查完整性
举例:
[root@localhost ~]# rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-*
[root@localhost ~]# rpm -k /var/ftp/pub/Server/kernel-PAE-2.6.18-194.el5.i686.rpm
/var/ftp/pub/Server/kernel-PAE-2.6.18-194.el5.i686.rpm: (sha1) dsa sha1 md5 gpg OK
公共数据库:/var/lib/rpm重建数据库
rpm {--initdb|--rebuilddb}
初始化:--initdb
如果事先不存在数据,则会新之;否则,不执行任何操作
重新构造:--rebuilddb
无论当前是否已经存在数据库,都会直接重建并覆盖现有数据库
举例:
[root@localhost ~]# rpm --initdb
[root@localhost ~]# rpm --rebuilddb
yum: Yellow dog Updater,Modified
主要功能是更方便的添加/删除/更新RPM包,它能自动解决包的倚赖性问题,便于管理大量系统的更新问题
配置yum仓库yum仓库配置文件:
指向仓库的位置以及各种配置信息;每个yum客户可以有多个可用的yum仓库
主配置文件有:
/etc/yum.conf
/etc/yum.repos.d/*.repo
yum客户端配置的高级用法:
1、如果有多个yum仓库,想优先选择使用,可以在配置文件添加一行cost定义仓库的使用开销值,默认值是1000,数值越低越优先
例如:cost=400
2、baseurl中指定路径时可使用变量,
例如:http://mirrors.sohu.com/centos/$releasever/os/$basearch
3、可以使用mirrorlist指令替换baseurl
指向一个URL,此URL是一个文本文件,其中保存了大量镜像服务器列表;用户使用yum仓库时,会获取此列表文件,而后通过fastestmirror插件判断哪一个镜像为访问速度最快的服务器,并以之做为本次访问的baseurl
yum的应用yum仓库相关的命令
列出所有可用仓库:
# yum repolist
列出所有程序包:
# yum list {all | installed | available}
支持globbing通配符
缓存管理:
# yum clean {all | packages}
# yum makecache
举例:
[root@localhost ~]# yum list
[root@localhost ~]# yum clean
[root@localhost ~]# yum makecache
安装yum install PACKAGE_NAME ...
-y: 自动回答为yes
如果需要安装指定的版本的程序:
yum install PACKAGE-VERSION ...
重新安装指定的程序包:
yum reinstall PACKAGE_NAME ...
举例:
[root@localhost ~]# yum -y install creatrepo
升级yum update PACKAGE_NAME
如果有多个版本的升级包可用,且仅期望升级到指定版本:
yum update PACKAGE-VERSION
降级:
yum downgrade PACKAGE_NAME
检查可用升级:
yum check-update
举例:
[root@localhost ~]# yum update createrepo
卸载yum erase|remove PACKAGE_NAME
注意:依赖于该指定程序包的其它包,会被一并卸载
举例:
[root@localhost ~]# yum remove createrepo
查询yum list
列出所有可安裝的软件清单
yum info PACKAGE_NAME
列出软件包信息
yum search KEYWORD
根据关键字模糊查询包名或包的sumary信息包含此KEYWORD的相关列表
yum provides|whatprovides /path/to/somefile
列出软件包提供哪些文件
举例:
[root@localhost ~]# yum list
[root@localhost ~]# yum info createrepo
[root@localhost ~]# yum provides createrepo
包组管理显示所有包组:
yum grouplist
显示某包组的相关信息:
yum groupinfo "GROUP_NAME"
安装包组:
yum groupinstall "GROUP_NAME"
或
yum install @GROUP_NAME 引号加不加都可以
卸载包组:
yum groupremove "GROUP_NAME"
yum remove @"GROUP_NAME"
升级包组:
yum groupupdate "GROUP_NAME"
举例:
[root@localhost ~]# yum groupremove "Development tools"
从yum仓库下载rpm包yumdownloader --resolve PACKAGE_FILE …
--destdir DIR
指定下载目标目录。默认为当前目录。
--urls
而不是下载RPM包,列出将要下载的网址
--resolve
当下载RPM包,解决依赖关系,并下载所需的软件包
--source
而不是下载的二进制RPM包,下载源RPM包
举例:
[root@localhost ~]# yumdownloader --resolve glances
从RPM文件中提取文件(RPM2CPIO, CPIO的使用)如果下载一个 RPM,需要检查它的内容而不是安装它,可以使用 rpm2cpio 命令把内容转换为 cpio 存档,然后通过 cpio 命令提取出包中的某些或所有文件。对 bind 包执行转换,然后显示提取出的文件(和目录)。关于 rpm2cpio 和 cpio 命令的更多信息参见它们的手册页
参考链接:http://blog.chinaunix.net/uid-26435987-id-3399279.html
举例:
[root@localhost ~]# rpm2cpio ./bind-9.8.2-0.17.rc1.el6.x86_64.rpm| cpio -idv
yum命令还可用安装本地rpm包文件yum localinstall /path/to/rpm_package_file ...
安装本地rpm包
选项:
--enablerepo=启用某yum仓库
--disablerepo=禁用某yum仓库
注意:优先级高于/etc/yum.repos.d/*.repo配置文件中定义的属性;
-y: 自动回答为yes
--nogpgcheck:不验证包的来源和完整性
举例:
[root@localhost ~]# yum -y localinstall /tmp/repos/glibc-common-2.6.32-358.el6.i386.rpm
来源:http://www.centoscn.com/CentOS/help/2014/1128/4200.html