原文地址:http://www.ttlsa.com/archives/732
作者:滕赖赖
CentOS RedHat 5 Yum源使用配置及相关参数详解

本文属于Linux下的工具类基础文章,所以高手,老鸟,敬请略过
本文環境是CentOS-5.7
待安裝好系統後,CentOS會自帶2個yum的配置文件
# cd /etc/yum.repos.d/
# ls
CentOS-Base.repo  CentOS-Media.repo
如果你的服務器在國外,那麼通過這兩個配置文件就可以直接安裝需要的服務器組件
但是國內用戶相對下載較慢
所以這裡推荐国内的Yum源,这里我原来比较常用的是CN99的源,但是后来被163收购以后,其实访问163是一样的
地址是:http://mirrors.163.com/
进入以后可以看到浏览器右边会有帮助信息,如图1:

 

 

  

由于我是CentOS,所以就点CentOS使用帮助
弹出新的页面,这时候点击对应版本的使用说明
我是CentOS5,所以就选择了CentOS5,如图2:

 

 

 http://mirrors.163.com/.help/CentOS5-Base-163.repo
有些可能对Linux接触不深的同学看到这里不知道这个页面显示的是什么?
这里就repo和yum的协作略加讲解
这个就如同CentOS-Base.repo和CentOS-Media.repo,俗称repo文件或者软件仓库,在repo文件前面的文件名可以根据自己的习惯来命名,如:base.repo,centos.repo等。

以下内容节选自:http://tc.itkee.com/os/detail-d80.html
repo文件定義了一個或者多個軟件倉庫的細節內容,例如我們將從哪裏下載需要安裝或者升級的軟件包,repo文件中的設置內容將被yum讀取和應用!
YUM的工作原理並不複雜,每一個RPM軟件的頭(header)裏面都會紀錄該軟件的依賴關係,那麼如果可以將該頭的內容紀錄下來並且進行分析,可以知道每個軟件在安裝之前需要額外安裝哪些基礎軟件。也就是說,在服務器上面先以分析工具將所有的RPM檔案進行分析,然後將該分析紀錄下來,只要在進行安裝或升級時先查詢該紀錄的文件,就可以知道所有相關聯的軟件。所以YUM的基本工作流程如下:
服務器端:在服務器上面存放了所有的RPM軟件包,然後以相關的功能去分析每個RPM文件的依賴性關係,將這些數據記錄成文件存放在服務器的某特定目錄內。
客戶端:如果需要安裝某個軟件時,先下載服務器上面記錄的依賴性關係文件(可通過WWW或FTP方式),通過對服務器端下載的紀錄數據進行分析,然後取得所有相關的軟件,一次全部下載下來進行安裝。

节选其中一段讲解下其中参数的意义
[base]
name=CentOS-$releasever - Base - 163.com
baseurl=http://mirrors.163.com/centos/$releasever/os/$basearch/
#mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=os
gpgcheck=1
gpgkey=http://mirror.centos.org/centos/RPM-GPG-KEY-CentOS-5

1、[base]
在这里中括号"[]"中的内容我们统称他为serverid
其中serverid是用於區別各個不同的repository,必須有一個獨一無二的名稱。 重複了后面覆蓋前面
2、name
是對repository的描述,支持像$releasever $basearch這樣的變量,也可以是自己自定义的名字,总而言之,这个name=任意名字。
3、baseurl
baseurl是服務器設置中最重要的部分,只有設置正確,才能從上面獲取軟件。它的格式是:
baseurl=url://server1/path/to/repository/
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-$releasever&arch=$basearch
#上面的這一行是指定一個鏡像服務器的地址列表,通常是開啓的,本例中加了註釋符號禁用了,我們可以試試,將$releasever和$basearch替換成自己對應的版本和架構,例如10和i386,在瀏覽器中打開,我們就能看到一長串鏡可用的鏡像服務器地址列表。
4、相关变量
$arch,cpu體系,如i686,athlon等
$releasever,發行版的版本,從[main]部分的distroverpkg獲取,如果沒有,則根據redhat-release包進行判斷。
$basearch,cpu的基本體系組,如i686和athlon同屬i386,alpha和alphaev6同屬alpha。
5、gpgcheck
gpgchkeck= 有1和0兩個選擇,分別代表是否是否進行gpg校驗,如果沒有這一項,默認是檢查的。
6、gpgkey
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 官方軟件升級用的上。
注:有些时候会被这个gpgkey难住,而因此无法继续下去。所以,如果实在搞不定,或者觉得麻烦,可以直接将gpgcheck改成0,即可取消gpg验证,但是这样是不安全的。

测试
# yum update
Loaded plugins: rhnplugin, security
This system is not registered with RHN.
RHN support will be disabled.
Skipping security plugin, no data
Setting up Update Process
Resolving Dependencies
Skipping security plugin, no data
--> Running transaction check
---> Package Deployment_Guide-en-US.noarch 0:5.2-11.el5.centos set to be updated
---> Package ImageMagick.i386 0:6.2.8.0-4.el5_5.3 set to be updated
---> Package NetworkManager.i386 1:0.7.0-13.el5 set to be updated
---> Package NetworkManager-glib.i386 1:0.7.0-13.el5 set to be updated
---> Package NetworkManager-gnome.i386 1:0.7.0-13.el5 set to be updated
---> Package OpenIPMI.i386 0:2.0.16-11.el5_7.2 set to be updated
。。。。。。

OK大功告成

 

CentOS使用说明

CentOS使用说明

163 镜像

163 镜像