软件包管理器之二——YUM介绍及使用

一、前言

    之前我们介绍了RPM的应用(详细请查看http://www.178linux.com/archives/6383),发觉RPM安装软件有一个很繁琐的问题,那就是包与包之间的依赖关系,如果想正常安装和使用软件程序,就必须根据要求一步一步的解决软件之间的依赖关系。那么如果程序使用的包很多,将会很消耗使用人的时间和精力。那么有没有办法解决这一问题呢?

    在RPM中我们介绍了RPM软件会记录软件之间的安装信息,其中也包括了软件之间的依赖属性。那么如果我们在安装前就分析这个列表,那么在安装时就能根据软件之间的关系将所需的软件一次性安装起来,这样就能解决这一问题,这就是 YUM 的机制。


二、yum的介绍

    yum(Yellow dog Updater Modified)是CentOS中属于RPM前段软件包管理器,能从指定的服务器中下载RPM包,并自动分析和处理RPM包之间的依赖关系,最后将依次所依赖的软件包都安装了,而无需繁琐的一个一个安装。


三、yum repository:yum仓库

    yum仓库的组成部分

        3.1、数据

            包含所有的软件包文件

        3.2、元数据

            指的是数据文件:包括每个包的包名、版本信息、各包所包含的文件列表、包与包之间的依赖关系、包的分组信息

小扩展:元数据是怎么来的呢? 
    使用createrepo工具,能够简洁的快速的将我们所指定的存放大量RPM包的目录,里面所有的RPM包信息都读出来,分析他的依赖关系并生成元数据。所以createrepo可以理解为它是制作yum元数据的工具。     在光盘里其实也有这个元数据,路径在光盘中的 [root@www mnt]# cd repodata/ 里,然后是以 sqlite文件后缀
    备注:centos5 是以 xml 后缀,centos6、7是以sqlite数据库的方式存储的

四、yum的配置文件介绍

    yum的配置文件有2中 : 主配置文件 + 仓库配置文件

    4.1、主配置文件路径  /etc/yum.conf

    [main]    
    cachedir=/var/cache/yum/$basearch/$releasever     #下载RPM包的缓存目录
    keepcache=0                                       #RPM缓存的程序包安装完成后是否保存,0表示不保存,1表示保存
    buglevel=2                                        #调试级别 取值范围 0 - 10,默认值为2    
    logfile=/var/log/yum.log                          #yum相关日志存放路径
    exactarch=1                                       #是否要平台完全匹配才能安装
    obsoletes=1                                       #需不需要检查已过期的仓库
    gpgcheck=1                                        #是否检查包的完整性和合法性
    plugins=1                                         #是否允许支持yum的插件功能,0 表示不允许 ,1表示允许,建议允许,一般会用yum-fastestmirror这个插件           
    installonly_limit=5                               #允许保留多少个内核包
    bugtracker_url=http://bugs.centos.org/set_project.php?project_id=16&ref=http://bugs.centos.org/bug_report_page.php?category=yum
    distroverpkg=centos-release                       #指定一个软件包,yum 会根据这个包判断你的发行版本,默认是redhat-release,也可以是安装的任何针对自己发行版的rpm 包

    4.2、仓库配置文件路径 /etc/yum.repos.d/*.repo  

        仓库文件可以有多个,而且一个或几个相关的仓库的配置信息也可保存为一个文件,并且所以的仓库文件名都以 .repo结尾

[REPOID]             #容器名字,必须是唯一的
name=                #some name for this repository仓库的名字,仅作一个标识
baseurl=             #指定真正仓库所在的路径,可以指多个仓库
                        #例如:baseurl=file:///media/cdrom
                        #      ftp://172.168.1.1/path    #备注第二行不能顶格写,否则会出错
mirrorlist=          #列出容器可以使用站点,如果不想使用,可以再前面加 # 注释
enabled= {0 | 1}     #指是否启用这个仓库,0表示不启用,1表示启用
gpgcheck= {0 | 1}    #是否要检测软件包的合法性,0表示不检测,1表示不检查
gpgkey=              #软件包的公钥文件所在路径,例如:gpgkey=file:///media/cdrom/GPG-RPM-KEY-centos-6
cost=                #仓库优先级,比如一个软件包在多个仓库都有,那应该选择哪个安装呢?就是根据这个优先级,默认是100,数字越小表示越优先使用

         备注:默认各仓库的用法:

            base库:通常为系统发行版所提供的程序包(就是光盘)

            updates库:存放更新包

            extra库:存放额外包

            epel库:epel库文件

               库本身有优先级的,但是仅是在客户端有,服务器端是没有优先级的

     小贴士:yum可支持多个协议,包括 ftp、http、nfs和本地文件共享服务

        所以仓库配置文件中的 baseurl 一项可以有多个写法,下面是各写法的格式

            1)ftp

                格式:ftp://server/path/to/repository

            2)http

                格式:http://server/path/to/repository

            3)nfs

                格式:nft://server/nfs_path

            4)本地文件共享服务 

                格式:file:///path/to/repository


五、yum安装步骤

yum 安装步骤.png



六、yum命令的使用

    6.1、yum查询功能

        yum [option] [需要查询的信息][参数]

            -y:默认yum需要是交互模式,-y表示自动提供yes响应

            search:搜索某个软件名或关键字

            list:列出所有yum所管理的软件包和名称

            info:同上,也类似rpm -qai

            provides:查找该命令是由软件安装生成的,类似rpm -df的功能

            repolist:列出所有可用的repo 

例如:
[root@localhost ~]# yum provides bash

yum provides.png

[root@localhost ~]# yum repolist

yum repolist.png

    6.2、安装、升级、降级、卸载功能

        yum [option] [需要查询的信息][参数]

            install:后面接需要安装的软件

            reinstall:后面接需要重新安装的软件

            update:后面接需要升级到的软件

            check-update:检查可用的升级包

            downgrade:后面接需要降级到的版本

            remove:卸载软件

            erase:功能同上,卸载

例如:
[root@localhost yum.repos.d]#  yum install zlib-static

yum install.png

    6.3、和软件组相关的功能

        yum [组功能] [软件组]

            grouplist:列出所有可使用的组列表

            groupinfo:后面接group name,可用了解该group内含所有组的名称

            groupinstall:安装整组的软件

            groupremove:删除某个组的软件 

例如:
[root@localhost yum.repos.d]# yum grouplist
#所有的包组未一一列举,若想安装某组可使用groupinstall直接安装
Installed Groups:            #已经安装的软件组
   Additional Development
   Base
   Console internet tools
   Development tools
Installed Language Groups:   #已经安装的语言组
   Arabic Support [ar]
   Armenian Support [hy]
   Georgian Support [ka]
Available Groups:            #有效软件组包文件
   Backup Client    
   Backup Server
Available Language Groups:   #有效的语言组包文件
   Afrikaans Support [af]
   Albanian Support [sq]

    6.4、清理缓存

        yum clean { all | package | headers }

            all:将所有的数据删除,包括元数据和软件文件

            package:将所有已下载的软件文件删除

            headers:删除所有下载的元数据文件

例如
[root@localhost yum.repos.d]# yum clean all     #这样将会清除所有的已下载的元数据和软件文件
Loaded plugins: fastestmirror, security
Cleaning repos: base extras updates
Cleaning up Everything
Cleaning up list of fastest mirrors

七、知识小结

    7.1、yum是RPM包的前端工具,主要解决了程序包的依赖关系

    7.2、需要了解yum的配置文件

           主配置文件 /etc/yum.conf  和 仓库配置文件 /etc/yum.repos.d/*.repo  

        7.3、yum按住功能的流程

        7.4、yum的命令

            安装、卸载、更新、程序组、清理缓存、查询等功能

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

(0)
螃蟹螃蟹
上一篇 2015-07-21
下一篇 2015-07-23

相关推荐

  • 进程查看管理工具htop/dstat/top/ps

    ps:显示系统当前进程的运行情况         选项与参数(一):            a:所有与终端相关的进程;    x:所有与终端无关的进程;    u:以用户为中心组织进程状态信息显示;   &nb…

    2016-12-04
  • 实时获取MySQL的TPS、QPS(输出到屏幕)

    这个脚本挺好用的,例如我们在主库执行了一个大事务,结果导致从库的show slave status\G 一直卡在 system lock状态,我们用下面这个脚本就能知道到底是hang住了,还是只是执行缓慢(反应在脚本执行结果里面就是qps\tps是不停变动的)。 当然,从库一直处于system lock 状态,一般是因为我们从库也设置双1导致,只要…

    Linux干货 2017-05-07
  • GNU awk的输出格式化和操作符

    printf命令 格式化输出:printf “FORMAT”, item1, item2, … (1) 必须指定FORMAT (2) 不会自动换行,需要显式给出换行控制符,\n (3) FORMAT中需要分别为后面每个item指定格式符 格式符:与item一一对应 %c: 显示字符的ASCII码 %d, %i: 显示十进制整数 %e, %E:显示…

    2018-01-01
  • 8.2日作业

    8.2作业 1、在/data/testdir里创建的新文件自动属于g1组,组g2的成员如:alice能对这些新文件有读写权限,组g3的成员如:tom只能对新文件有读权限,其它用户(不属于g1,g2,g3)不能访问这个文件夹。   先将文件目录的属组变更为g1 ,chmod  g+s /data/testdir/    …

    Linux干货 2016-08-08
  • 新的篇章

    第一天,linux,努力,奋斗!

    Linux干货 2017-07-11
  • redis主/从配置及基于sentinel的故障转移

    一、NoSQL基础概念: ACID:原子性、一致性、隔离性、持久性;特性:数据量大、数据变化非常大(数据增长化、流量分布变化、数据间耦合结构变化)、数据源很多; CAP、BASECAP C:多个数据节点的的数据一致;A:用户发出请求后的有限时间范围内返回结果;P:network partition,网络发生分区后,服务是否依可用;CAP理论:一个分布式系统不…

    Linux干货 2014-10-15

评论列表(3条)

  • stanley
    stanley 2015-07-21 22:00

    螃蟹的文章越来越专业了,文章写法也自成一派

    • 螃蟹
      螃蟹 2015-07-22 18:06

      @stanley谢谢老师,我会继续努力的

  • wenjia0411
    wenjia0411 2015-08-05 13:42

    很好的分享