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:   [caption id="attachment_733" align="alignleft" width="648"] 163 镜像[/caption]                                               由于我是CentOS,所以就点CentOS使用帮助 弹出新的页面,这时候点击对应版本的使用说明 我是CentOS5,所以就选择了CentOS5,如图2: [caption id="attachment_736" align="alignleft" width="928"] CentOS使用说明[/caption]                       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大功告成

转载于:https://my.oschina.net/766/blog/210875

猜你喜欢

转载自blog.csdn.net/weixin_34060299/article/details/91546228