yum,是Yellow dog Updater, Modified 的简称,是杜克大学为了提高RPM 软件包安装性而开发的一种软件包管理器。起初是由yellow dog 这一发行版的开发者Terra Soft 研发,用python 写成,那时还叫做yup(yellow dog updater),后经杜克大学的Linux@Duke 开发团队进行改进,遂有此名。yum 的宗旨是自动化地升级,安装/移除rpm 包,收集rpm 包的相关信息,检查依赖性并自动提示用户解决。yum 的关键之处是要有可靠的repository,顾名思义,这是软件的仓库,它可以是http 或ftp 站点,也可以是本地软件池,但必须包含rpm 的header,header 包括了rpm 包的各种信息,包括描述,功能,提供的文件,依赖性等。正是收集了这些header 并加以分析,才能自动化地完成余下的任务。

  yum 的理念是使用一个中心仓库(repository)管理一部分甚至一个distribution 的应用程序相互关系,根据计算出来的软件依赖关系进行相关的升级、安装、删除等等操作,减少了Linux 用户一直头痛的dependencies 的问题。这一点上,yum 和apt 相同。apt 原为debian 的deb 类型软件管理所使用,但是现在也能用到RedHat下的rpm了。

  yum 主要功能是更方便的添加/删除/更新RPM 包,自动解决包的依赖性问题,便于管理大量系统的更新问题。

  yum 可以同时配置多个资源库(Repository),简洁的配置文件(/etc/yum.conf),自动解决增加或删除rpm 包时遇到的依赖性问题,保持与RPM 数据库的一致性。

    repo配置文件格式

所有repository服务器设置都应遵循如下格式:

[serverid]

name=Some name for this server

baseurl=url://path/to/repository/

serverid 用于区别各个不同的repository,必须有一个独一无二的名称

name 是对repository 的描述,支持像$releasever $basearch这样的变量

baseurl是服务器设置中最重要的部分,只有设置正确,才能从yum仓库获取软件包。

    格式:

      baseurl=url://server1/path/to/repository/

          url://server2/path/to/repository/

          url://server3/path/to/repository/

        其中url支持的协议有http:// ftp:// file:// 三种,baseurl后可以跟多个url。

        但baseurl只能有一个,可以自己选择速度较快的镜像站。

    变量:

      $releasever:代表发行版的版本,从[main]部分的distroverpkg获取,如果没有,则根据redhat-release包进行判断。

      $arch:cpu体系,如i686,athlon等

      $basearch:cpu的基本体系组,如i686和athlon同属i386,alpha和alphaev6同属alpha。

    yum的配置文件分为两部分:main 和repository

main部分定义了全局配置选项,整个yum 配置文件应该只有一个main。位于/etc/yum.conf 中。

repository 部分定义了每个源/服务器的具体配置,可以有一到多个。位于/etc/yum.repo.d目录下以.repo为后缀的各文件中。

yum.conf 文件一般位于/etc目录下,一般其中只包含main部分的配置选项。

  #cat /etc/yum.conf

[main]

cachedir=/var/cache/yum

  //yum 缓存的目录,yum 在此存储下载的rpm包和数据库,默认设置为/var/cache/yum

keepcache=0

  //安装完成后是否保留软件包,0为不保留(默认为0),1为保留

debuglevel=2

  //Debug 信息输出等级,范围为0-10,缺省为2

logfile=/var/log/yum.log

  //yum 日志文件位置。用户可以到/var/log/yum.log 文件去查询过去所做的更新。

pkgpolicy=newest

  //包的策略。一共有两个选项,newest 和last,这个作用是如果你设置了多个repository,而同一软件在不同的repository 中同时存在,yum 应该安装哪一个,如果是newest,则yum 会安装最新的那个版本。如果是last,则yum 会将服务器id 以字母表排序,并选择最后的那个服务器上的软件安装。一般都是选newest。

distroverpkg=redhat-release

  //指定一个软件包,yum 会根据这个包判断你的发行版本,默认是redhat-release,也可以是安装的任何针对自己发行版的rpm 包。

tolerant=1

  //有1和0两个选项,表示yum 是否容忍命令行发生与软件包有关的错误,比如你要安装1,2,3三个包,而其中3此前已经安装了,如果你设为1,则yum 不会出现错误信息。默认是0。

exactarch=1

  //有1和0两个选项,设置为1,则yum 只会安装和系统架构匹配的软件包,例如,yum 不会将i686的软件包安装在适合i386的系统中。默认为1。

retries=6

  //网络连接发生错误后的重试次数,如果设为0,则会无限重试。默认值为6.

obsoletes=1

  //这是一个update 的参数,具体请参阅yum(8),简单的说就是相当于upgrade,允许更新陈旧的RPM包。

plugins=1

  //是否启用插件,默认1为允许,0表示不允许。我们一般会用yum-fastestmirror这个插件。

bugtracker_url=http://bugs.centos.org/set_project.php?project_id=16&ref=http://bugs.centos.org/bug_report_page.php?category=yum

# Note: yum-RHN-plugin doesn't honor this.

metadata_expire=1h

installonly_limit = 5

# PUT YOUR REPOS HERE OR IN separate files named file.repo

# in /etc/yum.repos.d    

    注: /etc/yum.repos.d/目录

      CentOS-Base.repo    表示yum网络源配置文件  

      CentOS-Media.repo   表示yum本地源配置文件

    须将yum网络源配置文件更名为CentOS-Base.repo.bak,否则会先在网络源中寻找适合的包,更名之后直接从本地源读取。

    如配置文件中定义多个yum源路径,须定义cost值,值小者优先查找。


    yum仓库分类创建:

      本地yum仓库创建: 

 例:以本地光盘镜像为yum源创建yum仓库

 yum本地及网络仓库创建_repo

 yum本地及网络仓库创建_yum源_02

 例:以本地文件为yum源创建yum仓库

    createrepo:自动抽取每个RPM源数据,生成依赖文件关系,生成xml文档,此文件存放在repodata目录。使用createrepo创建本地yum仓库。创建只需要指定文件路径,此路径须为repodata父目录,创建后会自动产生repodata文件。

    repodata目录中文件:        

      primary.xml.gz文件:主要记录yum仓库中所有软件包的包名和相互之间的依赖关系,还包含了每一个rpm包的安装要生成哪些文件。 

      filelists.xml.gz文件:存放yum仓库中每一个RPM包中的文件列表信息 

      other.xml.gz文件:存放额外信息,如使用changelog选项显示的信息等。 

      repomd.xml文件:存放上面三个文件的校验码和时间戳。

以上四个文件,在第一次使用yum命令的时候下载到yum缓存中,如果yum仓库中有软件更新,则primary.xml.gz,filelists.xml.gz,other.xml.gz这三个文件内容就会改变,检测到变更之后,就会从yum仓库下载新的文件。

 yum本地及网络仓库创建_yum源_03

 yum本地及网络仓库创建_网络源_04

 yum本地及网络仓库创建_repo_05

 yum本地及网络仓库创建_repo_06

 yum本地及网络仓库创建_repo_07

    

    网络yum仓库创建:

 例:以网络镜像yum源创建yum仓库 

 yum本地及网络仓库创建_repo_08

 yum本地及网络仓库创建_yum仓库_09

文中如有错误之处,望请大家指点!