rpm程序包管理器使用详解

rpm程序包管理器的使用详解

  说到程序包管理器,就会想到基于CentOS系统上的rpm命令与其对应的前端处理器yum。所谓程序包,是将源代码转换为二进制格式,再组织成一个或者多个包文件供用户安装使用。rpm程序包的命名格式如下:

  name-VERSION-release.arch.rpm

  软件名-版本号(分为主版本major和次版本minor)-发行版本号.架构型号.rpm后缀。比如:

lib-1.2.7-15.el7.i686.rpm
zlib-1.2.7-15.el7.x86_64.rpm
zlib-devel-1.2.7-15.el7.i686.rpm
zlib-devel-1.2.7-15.el7.x86_64.rpm
zlib-static-1.2.7-15.el7.i686.rpm
zlib-static-1.2.7-15.el7.x86_64.rpm
zsh-5.0.2-14.el7.x86_64.rpm
zsh-html-5.0.2-14.el7.x86_64.rpm
zziplib-0.13.62-5.el7.i686.rpm
zziplib-0.13.62-5.el7.x86_64.rpm
zziplib-devel-0.13.62-5.el7.i686.rpm
zziplib-devel-0.13.62-5.el7.x86_64.rpm
zziplib-utils-0.13.62-5.el7.x86_64.rpm

  其中对于一种软件包分为主包和支包,支包的格式是在名字后面注明功能,比如:zziplib-0.13.62-5.el7.x86_64.rpm 是zziplib的主包

  zziplib-devel-0.13.62-5.el7.i686.rpm

  zziplib-devel-0.13.62-5.el7.x86_64.rpm

  zziplib-utils-0.13.62-5.el7.x86_64.rpm

  这三个为zziplib的支包,红色字体分别代表支包的不同功能。

  当我们查找到合法来源程序包并验证其安全信息后,使用rpm命令就可随意对其装、删、查、改了,下面一一介绍rpm的使用。

    一.使用rpm安装程序包

  rpm -ivh /PATH/TO/Package_FILE,是最常用的程序包安装方法,-i表示install安装,-v表示安装的详细信息,-h表示安装进度。比如我们安装光驱上的某个程序包:

[root@localhost ~]# rpm -ivh /media/Packages/zsh-5.0.2-14.el7.x86_64.rpm 
warning: /media/Packages/zsh-5.0.2-14.el7.x86_64.rpm: Header V3 RSA/SHA256 Signature, key ID f4a80eb5: NOKEY
Preparing...                          ################################# [100%]
Updating / installing...
   1:zsh-5.0.2-14.el7                 ################################# [100%]

  安装zsh5.0.2版本成功。

  除此之外还有:

  –test:测试安装,显示安装过程,并不真正安装

  –repalcepkgs:重新安装,重装。

    二.使用rpm升级程序包

  升级程序包的安装使用-U或者-F选项。同样后面要接新版程序包的完整路径:

  rpm -U或-F /PATH/TO/Package_FILE。其中-U与-F是有区别的。

  -U:如果之前没有这个程序包,那么直接安装新版程序包,如果有,就更新。所以安装程序包也可以使用-Uvh。

  -F:只有升级的功能,如果之前没有此程序包,会提醒错误信息。

  –oldpackage:降级程序包,也就是还原之前版本,当新版本不好用bug多时需要进行还原操作恢复生产。

  –force:强制安装。因为rpm安装程序包之间有互相依存关系,有时安装a需要若干b c d程序包,这个选项就将其完全忽略,就是安装,用不了也装。

[root@localhost ~]# rpm -Uvh /media/Packages/zsh-5.0.2-14.el7.x86_64.rpm 
warning: /media/Packages/zsh-5.0.2-14.el7.x86_64.rpm: Header V3 RSA/SHA256 Signature, key ID f4a80eb5: NOKEY
Preparing...                          ################################# [100%]
	package zsh-5.0.2-14.el7.x86_64 is already installed

  使用-U选项,这里提示已经安装过了。

    三.使用rpm卸载程序包

  这个很好理解,就是卸载,不同的是安装和升级都要提供完整路径,而卸载只需要提供程序包名称即可。使用-e选项:

[root@localhost ~]# rpm -e zsh 
[root@localhost ~]# rpm -q zsh 
package zsh is not installed

  将刚才安装的zsh程序包卸载,-q选项是查询,下面会讲。

    四.使用rpm进行程序包查询

  这个是很重要的命令选项,今后会常常使用,为-q选项。其后面可以跟上其他的查询选项,所以完整格式为:rpm -q [select-options] [query-options]。

  select-options:

  -a:查询所有安装的包 rpm -qa,查找一系列的包文件常常使用rpm -qa | grep “###”的格式。比如:

[root@localhost ~]# rpm -qa | grep "^bash"
bash-4.2.46-19.el7.x86_64
bash-completion-2.1-6.el7.noarch

  查找安装的bash程序包。

  -f file:查询指定的文件由那个程序包生成。这个太有用了,用来查找文件来源:

[root@localhost ~]# rpm -qf /etc/passwd
setup-2.8.71-6.el7.noarch

 由此可见/etc/passwd文件由setup-2.8.71-6.e17.noarch这个程序包生成。

  -p Package_file:用于对未安装的程序包执行查询操作。比如:

[root@localhost ~]# rpm -qp /media/Packages/lohit-tamil-fonts-2.5.3-2.el7.noarch.rpm 
warning: /media/Packages/lohit-tamil-fonts-2.5.3-2.el7.noarch.rpm: Header V3 RSA/SHA256 Signature, key ID f4a80eb5: NOKEY
lohit-tamil-fonts-2.5.3-2.el7.noarch

  查到了未安装的程序包信息。

  query-options:

  –changelog:查询rpm包的历史。后接程序包名称。举例:

[root@localhost ~]# rpm -q --changelog tree
* Fri Jan 24 2014 Daniel Mach <dmach@redhat.com> - 1.6.0-10
- Mass rebuild 2014-01-24

* Fri Dec 27 2013 Daniel Mach <dmach@redhat.com> - 1.6.0-9
- Mass rebuild 2013-12-27

...
...

* Mon Oct 20 1997 Otto Hammersmith <otto@redhat.com>
- updated version
- fixed src url

* Fri Jul 18 1997 Erik Troan <ewt@redhat.com>
- built against glibc

  显示的是此程序包的历史发展。

  -l:列出程序包生成的所有文件。这个也非常有用。就不举例了

  -i:程序包的相关信息,包括版本号,发行号,大小,安装日期..等等一堆

  -c:查询程序包的所有配置文件

  -d:查询程序包提供的文档

    五.使用rpm校验程序包

  我们可以使用rpm -V命令校验程序包,举例:

[root@localhost media]# rpm -qc bash
/etc/skel/.bash_logout
/etc/skel/.bash_profile
/etc/skel/.bashrc
[root@localhost media]# vim /etc/skel/.bash
.bash_logout   .bash_profile  .bashrc        
[root@localhost media]# vim /etc/skel/.bashrc 
[root@localhost media]# rpm -V bash
S.5....T.  c /etc/skel/.bashrc

  这里我查找了bash的配置文件并对/etc/skel/.bashrc修改多加了一个空行,这时校验bash就如上所示得到结果。

  如果校验的文件有变动,结果一共有9项校验项目,使用8个字母来表示,从前往后依次含义为:

  S:文件大小更改了

  M:表示权限更改了

  5:表示MD5检查和    ?????

  D:表示主从设备号更改

  L:表示符号链接文件更改

  U:文件属主更改

  G:文件属组更改

  T:文件最后修改时间更改

  所以上例结果表示为:/etc/skel/.bashrc 文件大小、MD5检查和、最后修改时间被更改。

原创文章,作者:mcgeewang,如若转载,请注明出处:http://www.178linux.com/38426

(0)
mcgeewangmcgeewang
上一篇 2016-08-21 20:45
下一篇 2016-08-21 20:45

相关推荐

  • Nginx的安装及其一些配置

    nginx的编译安装    tar xf nginx-1.12.2.tar.gz   cd nginx-1.12.2     yum install pcre-devel  ./configure –help   groupadd -r nginx     useradd -g nginx -r nginx    id nginx     ./c…

    Linux干货 2017-10-25
  • 内键命令和外部命令

    命令的基本格式 COMMAND  [OPTIONS…]  [ARGUMENTS…]        命令 (COMMAND)       OPTIONS(选项):用于启用或关闭命令的某个或某些功能      …

    2017-05-23
  • 文件的从属权限和特殊权限

    基础权限   rwx     经过今天的洗礼,了解了文件的权限位(rwx),而权限对于目录和文件有着不同的意义     使用ls -l 命令后可以看到     -rw-r–r–. 1 root root 1…

    Linux干货 2016-08-04
  • Linux基础知识(1)

    在开源的世界当中,有许多的开源协议,其中著名的有Apache、BSD和GPL协议,它们支撑了开源世界,使得让那些开源程序变得丰富多彩,我们知道开源协定的发起人是Stallman,它主张的自由含义为自由学习和更改,自由使用;自由分发和自由创建衍生版。
    而Linux就是在这样的开源协定下在1991年的10月份起义成功,同时,它也有它的哲学思想:

    2017-09-10
  • ☞CentOS安装程序{ 源码包安装;rpm包安装;}&&恢复rpm功能

    ☞CentOS安装程序{ 源码包安装;rpm包安装;}&&恢复rpm功能 本文是继上一篇文章“CentOS程序安装的3种方式{ 源码包安装 | rpm包安装 | yum安装;}”的补充,上篇文章http://www.178linux.com/38812主要介绍了yum安装软件的方法以及归纳了详细的yum命令。本文继续介绍基于本地file、远程…

    Linux干货 2016-08-24
  • N26-第四周-孙逸

    1、  复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 cp –r /etc/skel /home/tuser1 chmod –R 700 /home/tuser1 2、  编辑/etc/group文件,添加组hadoop。 group文件的内容格式: &…

    2017-03-10

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-21 20:54

    rpm包管理器对的选项是比较多的,我们只需要对rpm包的查询语句熟练掌握就很好了。希望下来多加练习