如你安好

时间就像海绵里的水,只要愿挤,总还是有的。 -- 鲁迅
如你安好 ,

便是晴天 。

repo文件解析及/etc/yum.repos.d目录

前情提要:目录下有哪些文件?

CentOS-Media 这个是使用光盘挂载后调用的文件
CentOS-Base 这个是联网后基础的源,一般都用这个
CentOS-Vault 这个是最近新版本的加入的老版本的yum源配置
CentOS-Debuginfo debug包尤其和内核相关的更新和软件安装

一、什么是repo文件?

repo文件是Fedora中yum源(软件仓库)的配置文件,通常一个repo文件定义了一个或者多个软件仓库的细节内容,例如我们将从哪里下载需要安装或者升级的软件包,repo文件中的设置内容将被yum读取和应用!
YUM的工作原理并不复杂,每一个 RPM软件的头(header)里面都会纪录该软件的依赖关系,那么如果可以将该头的内容纪录下来并且进行分析,可以知道每个软件在安装之前需要额外安装哪些基础软件。也就是说,在服务器上面先以分析工具将所有的RPM档案进行分析,然后将该分析纪录下来,只要在进行安装或升级时先查询有该记录的文件,就可以知道所有相关联的软件。所以YUM的基本工作流程如下:
服务器端:在服务器上面存放了所有的RPM软件包,然后以相关的功能去分析每个RPM文件的依赖性关系,将这些数据记录成文件存放在服务器的某特定目录内。
客户端:如果需要安装某个软件时,先下载服务器上面记录的依赖性关系文件(可通过WWW或FTP方式),通过对服务器端下载的纪录数据进行分析,然后取得所有相关的软件,一次全部下载下来进行安装。
1.Yum软件的配置文件详解:(不是yum源,是配置文件)

[root@localhost ~]# vi /etc/yum.conf
[main]
cachedir=/var/cache/yum

cachedir:yum缓存的目录,yum在这里保存下载的rpm包和数据库,一般是/var/cache/yum。

debuglevel=2

debuglevel:除错级别,0──10,默认是2,貌似只记录安装和删除记录。

logfile=/var/log/yum.log
pkgpolicy=newest

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

distroverpkg=centos-release

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

tolerant=1

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

exactarch=1

exactarch,有两个选项1和0,代表是否只升级和你安装软件包cpu体系一致的包,如果设为1,则如你安装了一个i386的rpm,则yum不会用1686的包来升级。

retries=20

retries,网络连接发生错误后的重试次数,如果设为0,则会无限重试。

obsoletes=1
gpgcheck=1

gpgchkeck有1和0两个选择,分别代表是否进行gpg校验,如果没有这一项,默认是检查的。

reposdir=/etc/yy.rm 

默认是/etc/yum.repos.d/下的 xx.repo后缀文件都会被include(包括)进来,也就是说/etc/yum.repos.d/下的xx.repo配置文件无论有多少个,每个里面有多少个[name],最后其实都被整合到一个里面运行,重复的[name]后面的将会覆盖前面的。

exclude=xxx

exclude排除某些软件在升级名单之外,可以用通配符,列表中各个项目要用空格隔开,这个对于安装了诸如美化包,中文补丁的朋友特别有用。

keepcache=1

keepcache有1和0两个选择,如果设置keepcache=1,yum在成功安装软件包之后将保留缓存的头文件 (headers)和软件包。默认值为 keepcache=0 不保存。

reposdir=[包含.repo文件的目录的绝对路径]

该选项用户指定.repo文件的绝对路径。.repo文件包含软件仓库的信息 (作用与/etc/yum.conf文件中的 [repository]片段相同)。

2.yum的repo包配置文件详解:(yum源)

[root@localhost ~]# vi /etc/yum.repo.d/xx.repo

注:这个字段其实也可以在yum.conf里面直接配置

[serverid]

其中serverid是用于区别各个不同的repository(仓库;贮藏室;博物馆;亲信),必须有一个独一无二的名称。 重复了 前面覆盖后面–还是反过来呢???用enabled 测试是后面覆盖前面

name=Some name for this server

name,是对repository的描述,支持像$releasever $basearch这样的变量;
例如:name=Fedora Core $releasever - $basearch - Released Updates

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

baseurl是服务器设置中最重要的部分,只有设置正确,才能从上面获取软件。它的格式是:

url://server2/path/to/repository/      √√(正确)√√
url://server3/path/to/repository/

其中url支持的协议有,http:// ftp:// file://三种。baseurl后可以跟多个url,你可以自己改为速度比较快的镜像站,但baseurl只能有一个,也就是说不能像如下格式:

baseurl=url://server1/path/to/repository/
baseurl=url://server2/path/to/repository/     ××(错误)××
baseurl=url://server3/path/to/repository/

其中url指向的目录必须是这个repository header目录的上一级,它也支持$releasever和$basearch这样的变量。

#mirrorlist=http://mirrors.fedoraproject.org/mirrorlist?repo=fedora-KaTeX parse error: Expected 'EOF', got '&' at position 11: releasever&̲arch=basearch

上面的这一行是指定一个镜像服务器的地址列表,通常是开启的,本例中加了注释符号禁用了,我们可以试试,将releasever和basearch替换成自己对应的版本和架构,例如10和i386,在浏览器中打开,我们就能看到一长串镜可用的镜像服务器地址列表。
url之后可以加上多个选项,如gpgcheck、exclude、failovermethod等。

gpgcheck=1
exclude=xxx

其中gpgcheck,exclude的含义和[main]部分相同,但只对此台服务器起作用。
gpgchkeck有1和0两个选择,分别代表是否进行gpg校验,如果没有这一项,默认是检查的。
exclude排除某些软件在升级名单之外,可以用通配符,列表中各个项目要用空格隔开,这个对于安装了诸如美化包,中文补丁的朋友特别有用。

failovermethod=priority

failovermethode有两个选项roundrobin和priority,意思分别是有多个url可供选择时,yum选择的次序。roundrobin是随机选择,如果连接失 败则使用下一个,依次循环;priority则根据url的次序从第一个开始。如果不指明,默认是roundrobin。

enabled=1

enabled有1和0两个选择,当某个软件仓库被配置成enabled=0 时,yum在安装或升级软件包时不会将该仓库做为软件包提供源,使用这个选项,可以启用或禁用软件仓库。
通过yum的--enablerepo=[repo_name]和--disablerepo=[repo_name]选项,或者通过 PackageKit的"添加/删除软件"工具,也能够方便地启用和禁用指定的软件仓库。
另外:

几个语句内的变量:

$releasever
发行版的版本,从[main]部分的distroverpkg获取,如果没有,则根据redhat-release包进行判断。
$arch
cpu体系,如i686,athlon等。
$basearch
cpu的基本体系组,如i686和athlon同属i386,alpha和alphaev6同属alpha。

还有一件事,reposity的GPG key:

那就是导入每个reposity的GPG key,前面说过,yum可以使用gpg对包进行校验,确保下载包的完整性,所以我们先要到各个repository站点找到gpg key,一般都会放在首页的醒目位置,一些名字诸如 RPM-GPG-KEY.txt之类的纯文本文件,把它们下载,然后用rpm --import xxx.txt命令将它们导入,最好把发行版自带GPG-KEY也导入,rpm --import /usr/share/doc/redhat-release-*/RPM-GPG-KEY 官方软件升级用的上。

二、什么是epel?

如果既想获得RHEL的高质量、高性能、高可靠性,又需要方便易用(关键是免费)的软件包更新功能,那么Fedora Project推出的EPEL(Extra Packages for Enterprise Linux)正好适合你。EPEL(http://fedoraproject.org/wiki/EPEL)
EPEL是由 Fedora 社区打造,为RHEL及衍生发行版如CentOS、Scientific Linux等提供高质量软件包的项目。
使用心得:
1,不用去换原来yum源,安装后会产生新repo
2,epel会有很多源地址,如果一个下不到,会去另外一个下

http://mirror.suhu.com/fedora-epel/6/x86_64/epel-release-6-8.noarch.rpm

3,更新时如果下载的包不全,就不会进行安装。这样的话,依赖关系可以保重
安装epel:
32位系统选择:

rpm -ivh http://mirror.suhu.com/fedora-epel/6/i386/epel-release-6-8.noarch.rpm

64位系统选择:

rpm -ivh http://mirror.suhu.com/fedora-epel/6/x86_64/epel-release-6-8.noarch.rpm

导入key:

rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-6

如果用比较新的软件,用epel-test.repo这个文件就行了
别忘了安装

[root@localhost]# yum install yum-priorities
[root@localhost yum.repos.d]# ls |grep epel
epel.repo
epel-testing.repo

愿望集合地

(仅限登陆用户评论)

这篇文章获得了个赞!