yum前端软件包管理器

yum是什么

    Yum (Yellow dog Updater, Modified) 由Duke University团队,修改Yellow Dog Linux的Yellow Dog Updater开发而成,是一个基于 RPM 包管理的字符前端软件包管理器。能够从指定的服务器自动下载 RPM 包并且安装,可以处理依赖性关系,并且一次安装所有依赖的软件包,无须繁琐地一次次下载、安装。被Yellow Dog Linux本身,以及Fedora、Red Hat Enterprise Linux采用。

yum工作机制

    C/S架构:client –> server

    yum仓库(server端):

        保存rpm包以及元数据,如:包名、版本信息、各包所包含的文件列表、依赖关系、包分组信息等。

    yum客户端(client端):以安装过程为例

        第一步:获取仓库元数据,缓存于本地,缓存目录/var/cache/yum

        第二步:yum客户端读取并分析本地缓存的元数据文件,结合本地系统环境做出要安装的程序包的决策,如依赖关系

        第三步:根据决策联系yum仓库,下载各程序包缓存到本地,一并进行安装

yum仓库:

    可以理解为rpm包的文件服务器,repodata目录所在的父目录就是一个可用仓库。

    自建一个yum仓库:

        1、把rpm包放到一个目录

        2、通过createrepo命令分析该目录的rpm包,然后生成元数据目录repodata

        3、配置yum客户端使用此仓库即可,就是这么简单。

yum客户端:

    要想通过yum管理rpm包,需要读取yum仓库的配置文件,指明仓库访问路径及各种属性信息

    主配置文件:/etc/yum.conf

    一个或几个相关仓库的配置信息可保存为一个文件,文件名以.repo结尾:/etc/yum.repos.d

    文件格式:

[REPOID]
name=Some name for this repository    #设置该yum仓库的名称
baseurl=url://server1/path/to/repository/           #方式1:指定yum仓库访问路径,支持多种url,如:ftp、nfs、http等,可指定多个url
        http://mirror.centos.org/centos/$releasever/os/$basearch/     #URL中也支持$releasever 、$basearch这样的变量,指定系统版本号
        mirrorlist=/path/to/urlfile        #方式2:可以将多个url写入一个文件,然后读取这个文件    
enabled={0|1}        #是否启用该yum仓库,0为不启用,1为启用,默认为1
gpgcheck={0|1}       #是否校验rpm包,0为不启用,1为启用
gpgkey=URL           #如果校验,指定公钥文件路径

   yum配置文件中可用的四个变量:

          $releasever: 程序的版本,对Yum而言指的是redhat-release版本;只替换为主版本号,如RedHat 6.5,则替换为6;
          $arch: 系统架构
          $basearch: 系统基本架构,如i686,i586等的基本架构为i386;
          $uuid:
          $YUM0-9: 在系统中定义的环境变量,可以在yum中使用;

    一个配置文件支持多个yum仓库

    1、列出所有repo

[root@qin ~]# yum repolist  {enabled|disabled|all}      #enabled列出可用的,disabled列出禁用的,all列出所有(默认)

    2、列出rpm包及包组

[root@qin ~]# yum list {all|installed|available}    #all列出所有包(默认),installed列出已安装的包,available列出可安装的包
[root@qin ~]# yum list KEYWORD*    #列出指定前缀的所有包,支持文件名通配

    3、包的描述信息

[root@qin ~]# yum info package_name

    4、列出所有包组信息

[root@qin ~]# yum grouplist

    5、显示包组的信息:例如组中包含的程序包列表

[root@qin ~]# yum groupinfo "GROUP NAME"

    6、清理缓存

[root@qin ~]# yum clean {all|packages|metadata|expire-cache|rpmdb|plugins}

    7、安装程序包

[root@qin ~]# yum install package_name
[root@qin ~]# yum reinstall package_name    #重新安装

    8、包的升级和降级

[root@qin ~]# yum check-update    #检查可用的升级包
[root@qin ~]# yum update package_name    #可以指定升级包的版本号升级;如果不指定包名,就升级所有可用的升级包
[root@qin ~]# yum downgrade package_name    #包降级

    9、包的卸载

[root@qin ~]# yum {remove|erase} package_name

    10、查询某文件是由哪个包安装生成的

[root@qin ~]# yum {whatprovides|provides} /path/to/somefile

    11、安装包组

[root@qin ~]# yum groupinstall "GROUP NAME"

    12、卸载包组

[root@qin ~]# yum groupremove "GROUP NAME"

    13、只下载包,不安装

[root@qin ~]# yumdownloader package_name    #此命令由yum-utils包提供

    14、另外一些常用选项介绍

--nogpgcheck    #不对包做校验
--disablerepo=[repo]    #安装时禁用某些yum仓库
-y:    #对所有交互式操作返回yes
[root@qin ~]# yum history    #显示yum的历史记录
[root@qin ~]# yum history list X    #X是历史事务ID,显示指定事务明细操作
[root@qin ~]# yum history redo X    #重新执行指定事务
[root@qin ~]# yum history undo X    #回滚指定事务
[root@qin ~]# yum makecache         #生成元数据
[root@qin ~]# yum search  STRING    #查找包含指定关键字的包

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

(0)
秦
上一篇 2015-05-13 18:37
下一篇 2015-05-13 18:39

相关推荐

  • 马哥网络教育班第21期+第四周课程练习

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限 [root@CentOS6 ~]# cp -r /etc/skel /home/tuser1 [root@CentOS6 ~]# chmod&nb…

    Linux干货 2016-07-29
  • NFS

    NFS初探 NFS概述 NFS工作流程 NFS Server端设置 NFS工具与命令 NFS配置实例 NFS概述 NFS是什么? NFS,network file system(网络文件系统)的缩写,是一种实现文件共享的实现方式。 NFS的功能是什么 NFS基于RPC协议,实现远程系统调用,共享文件资源。 NFS工作流程 RPC,Remote Pr…

    Linux干货 2016-04-28
  • ​redis cluster 安装指南

    公司的很多项目在使用redis主从。由于coder的各种毁灭性操作,迫切需要一个能带故障恢复的架构。因此新版的cluster,开始了测试。 一、Cluster 理论基础 Cluster介绍 Redis集群是一个提供在多个Redis间节点间共享数据的程序集。 Redis集群并不支持处理多个keys的命令,因为这需要在不同的节点间移动数据,从而达不到像Redis…

    Linux干货 2016-02-14
  • yum源设置

      yum是我们经常用到的一个程序,我们主要用它来安装或删除安装包,下面我来介绍一下怎样配置yum安装源?    配置yum安装源主要有两种方法:一种是用本地镜像做安装源,二是用提供镜像下载的网站做安装源。    一 配置本地安装源    本地安装源需要有系统镜像,操作步骤如下:…

    Linux干货 2016-01-16
  • Linux用户和组管理

    进程以其发起者的身份运行; 进程对文件的访问权限,取决于发起此进程的用户的权限;   系统用户:为了能够让那后台进程或服务类进程以非管理员的身份运行,通常需要为此创建多个普通用户;这类用户从不用登录系统;     groupadd命令:添加组   groupadd [选项] group_name   -g G…

    Linux干货 2016-11-21
  • 【N25第五周作业】find命令以及相关练习

    find: 实时查找工具,通过遍历指定起始路径下文件系统层级结构完成文件查找; 工作特性: 查找速度略慢; 精确查找; 实时查找; 用法: find [OPTIONS]  [查找起始路径]  [查找条件]  [处理动作] 查找起始路径:指定具体搜索目标起始路径;默认为当前目录; 查找条件:…

    Linux干货 2016-12-27