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 <[email protected]> - 1.6.0-10
- Mass rebuild 2014-01-24

* Fri Dec 27 2013 Daniel Mach <[email protected]> - 1.6.0-9
- Mass rebuild 2013-12-27

...
...

* Mon Oct 20 1997 Otto Hammersmith <[email protected]>
- updated version
- fixed src url

* Fri Jul 18 1997 Erik Troan <[email protected]>
- 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

相关推荐

  • 第九周

    统计可登录shell与不能登陆shell的个数 2. 写一个脚本 3.写一个脚本    4、写一个脚本,完成如下功能 脚本能够接受一个参数。 (1) 如果参数1为quit,则显示退出脚本,并执行正常退出。 (2) 如果参数1为yes,则显示继续执行脚本。 (3) 否则,参数1为其它任意值,均执行非正常退出。    5、…

    Linux干货 2016-12-26
  • N25第九周作业

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash declare -a usersh nologin=0 login=0 usersh=($(cut -d’:’ -f7 /etc/passwd)) ##数组赋值时需…

    Linux干货 2017-03-04
  • linux 小命令

    设置自动登录、设置网络自动连接、字体颜色

    2017-11-19
  • 自动化运维跟安全配置

    安全相关工具rpm -qf /usr/bin/sshopenssh semanage port -a -t ssh_port_t -p tcp #PORTNUMBER/端口9527修改ssh的默认端口,ssh默认只能用22端口多台主机互联免口令1 ssh-keygen三台主机各自生成私钥公钥2 ssh-copy-id IP7三台主机各自复制公钥到同一台主机3…

    2018-02-06
  • inode总结

    inode的介绍以及影响inode号的命令

    2017-11-13
  • 随笔—SVN仓库转换为Git仓库

    假设需要转换的SVN仓库地址为:https://tmp/svn 1、使用git svn clone命令开始转换 $ git svn clone https://tmp/svn -T trunk -b branches -t tags #git svn…

    Linux干货 2016-07-04

评论列表(1条)

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

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