天天看點

yum和epel

一、概覽

1、什麼是repo檔案

repo檔案是Fedora中yum源(軟體倉庫)的配置檔案,通常一個repo檔案定義了一個或者多個軟體倉庫的細節内容,例如我們将從哪裡下載下傳需要安裝或者更新的軟體包,repo檔案中的設定内容将被yum讀取和應用。

2、Yum的工作原理

YUM的工作原理并不複雜,每一個 RPM軟體的頭(header)裡面都會紀錄該軟體的依賴關系,那麼如果可以将該頭的内容紀錄下來并且進行分析,可以知道每個軟體在安裝之前需要額外安裝 哪些基礎軟體。也就是說,在伺服器上面先以分析工具将所有的RPM檔案進行分析,然後将該分析紀錄下來,隻要在進行安裝或更新時先查詢該紀錄的檔案,就可 以知道所有相關聯的軟體。

3、YUM的基本工作流程

3.1、伺服器端

在伺服器上面存放了所有的RPM軟體包,然後以相關的功能去分析每個RPM檔案的依賴性關系,将這些資料記錄成檔案存放在伺服器的某特定目錄内。

3.2、用戶端

如果需要安裝某個軟體時,先下載下傳伺服器上面記錄的依賴性關系檔案(可通過WWW或FTP方式),通過對伺服器端下載下傳的紀錄資料進行分析,然後取得所有相關的軟體,一次全部下載下傳下來進行安裝。

4、Yum配置

4.1、Yum的兩部分main 和repository

main:定義了全局配置選項,整個yum 配置檔案應該隻有一個main。常位于/etc/yum.conf 中。

repository:定義了每個源/伺服器的具體配置,可以有一到多個。常位于/etc/yum.repo.d/ 目錄下的各檔案中。

yum 的配置方式也分兩種:

直接配置/etc目錄下的yum.conf檔案,增加repository片段

在/etc/yum.repos.d目錄下增加.repo檔案

4.2、/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是否容忍指令行發生與軟體包有關的錯誤,比如你要安裝1,2,3三個包,而其中3此前已經安裝了,如果你設為1,則yum不會出現錯誤資訊。預設是0。

exactarch=1

#exactarch,有兩個選項1和0,代表是否隻更新和你安裝軟體包cpu體系一緻的包,如果設為1,則如你安裝了一個i386的rpm,則yum不會用1686的包來更新。

retries=20

#retries,網絡連接配接發生錯誤後的重試次數,如果設為0,則會無限重試。

obsoletes=1

#這是一個update的參數,具體請參閱yum(8),簡單的說就是相當于upgrade,允許更新陳舊的RPM包

gpgcheck=1

#gpgchkeck= 有1和0兩個選擇,分别代表是否進行gpg校驗,以确定rpm 包的來源是有效和安全的,如果沒有這一項,預設是檢查的。

exclude=xxx

#exclude 排除某些軟體在更新名單之外,可以用通配符,清單中各個項目要用空格隔開,這個對于安裝了諸如美化包,中文更新檔的朋友特别有用。

keepcache=[1 or 0]

#設定 keepcache=1,yum 在成功安裝軟體包之後保留緩存的頭檔案 (headers) 和軟體包。預設值為 keepcache=0 不儲存

reposdir=[包含 .repo 檔案的目錄的絕對路徑]

#該選項使用者指定 .repo 檔案的絕對路徑。.repo 檔案包含軟體倉庫的資訊 (作用與 /etc/yum.conf 檔案中的 [repository] 片段相同)。

4.3、/etc/yum.repo.d/xx.repo

這個字段其實也可以在yum.conf裡面直接配置

[serverid] # 軟體源/倉庫名,必須有一個獨一無二的名稱,如果重複,用enabled 測試是後面覆寫前面

name=Some name for this server

#name,是對repository的描述,支援像$releasever $basearch這樣的變量,

#可以寫成【name=Fedora Core $releasever - $basearch - Released Updates】

$ releasever變量定義了發行版本,通常是8,9,10等數字,$basearch變 量定義了系統的架構,可以是i386、x86_64、ppc等值

#這兩個變量根據目前系統的版本架構不同而有不同的取值,這可以友善yum更新的時候選擇 适合目前系統的軟體包,以下同

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

#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://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,在浏覽器中打開,我們就能看到一長串鏡可用的鏡像伺服器位址清單。

url之後可以加上多個選項,如gpgcheck、exclude、failovermethod等,比如:

gpgcheck=1 # 是否進行gpg校驗

exclude=gaim # 排除某些軟體在更新名單之外

#其中gpgcheck,exclude的含義和[main]部分相同,但隻對此伺服器起作用

failovermethod=priority

#failovermethode 有兩個選項roundrobin和priority,意思分别是有多個url可供選擇時,yum選擇的次序,roundrobin是随機選擇,如果連接配接失 敗則使用下一個,依次循環,priority則根據url的次序從第一個開始。如果不指明,預設是roundrobin。

enabled=[1 or 0]

#當某個軟體倉庫被配置成 enabled=0 時,yum 在安裝或更新軟體包時不會将該倉庫做為軟體包提供源。使用這個選項,可以啟用或禁用軟體倉庫。

#通過 yum 的 --enablerepo=[repo_name] 和 --disablerepo=[repo_name] 選項,或者通過 PackageKit 的"添加/删除軟體"工具,也能夠友善地啟用和禁用指定的軟體倉庫

4.3、幾個變量

$releasever:發行版的版本,從[main]部分的distroverpkg擷取,如果沒有,則根據redhat-release包進行判斷。

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

$basearch:cpu的基本體系組,如i686和athlon同屬i386,alpha和alphaev6同屬alpha。

4.4、導入每個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

1、epel是什麼

如果既想獲得 RHEL 的高品質、高性能、高可靠性,又需要友善易用(關鍵是免費)的軟體包更新功能,那麼 Fedora Project 推出的 EPEL(Extra Packages for Enterprise Linux)正好适合你。EPEL(http://fedoraproject.org/wiki/EPEL) 是由 Fedora 社群打造,為 RHEL 及衍生發行版如 CentOS、Scientific Linux 等提供高品質軟體包的項目。

2、如何擷取 EPEL 的軟體包

EPEL 包含一個叫做 ‘epel-release’ 的包,其中包含了用于軟體包簽名的 gpg 密鑰和軟體源的資訊。安裝這個包到您的企業版 Linux 上之後,您将可以通過使用類似于 yum 的工具來安裝軟體包和它們的依賴。在預設情況下,EPEL 倉庫的穩定版本是開啟的。除了 epel-release 源,還有一個叫做 ‘epel-testing’ 倉庫 包含尚未被視作穩定的軟體,請自行斟酌開啟的風險。

CentOS 使用者可以直接通過 yum install epel-release 安裝并啟用 EPEL 源。

3、使用心得:

1、不用去換原來yum源,安裝後會産生新repo

2、epel會有很多源位址,如果一個下不到,會去另外一個下

3、更新時如果下載下傳的包不全,就不會進行安裝。這樣的話,依賴關系可以保重

4、安裝yum install yum-priorities

Yum Priorities 插件可以用來強制保護源。它通過給各個源設定不同的優先級,使得系統管理者可以将某些源(比如 Linux 發行版的官方源)設定為最高優先級,進而保證系統的穩定性(同時也可能無法更新到其它源上提供的軟體最新版本)。

三、Yum源更換

1、備份/etc/yum.repos.d/CentOS-Base.repo

cp /etc/yum.repos.d/CentOS-Base.repo{,.bak}           

2、下載下傳對應版本repo檔案, 放入/etc/yum.repos.d/(操作前請做好相應備份)

Centos7:

wget -O /etc/yum.repos.d/Centos-Base.repo http://mirrors.163.com/.help/CentOS7-Base-163.repo

3.運作以下指令生成緩存

yum clean all

yum makecache

四、Yum指令

yum指令選項

--nogpgcheck:禁止進行gpgcheck

-y: 自動回答為“yes”

-q:靜默模式

--disablerepo=repoidglob:臨時禁用此處指定的repo

--enablerepo=repoidglob:臨時啟用此處指定的repo

--noplugins:禁用所有插件

yum源清單

yum repolist [all|enabled|disabled]:顯示倉庫清單

yum grouplist:顯示包組

yum list {available|installed|updates} :顯示包清單

yum list vsftpd* 顯示和vsftpd比對的包

yum安裝解除安裝

yum install package

yum restall package:重做

yum update package:更新包

yum check-update :檢查更新包

yum remove package1 [package2] :解除安裝包

包組的安裝基本和包的安裝類似,隻是在install,restall等操作前加上group即可。比如:yum -y groupinstall "Development Tools",如果有空格,要使用雙引号包括。

如果在安裝系統時候,沒有安裝桌面,則可以使用此指令安裝:yum -y groupinstall "GNOME Desktop"即可安裝圖形界面

yum查詢

yum info 檢視程式包資訊

yum provides feature1

yum search xxx :搜尋帶有某個關鍵字的安裝包

yum 緩存

yum makecache :建構緩存

yum clean all:清除所有緩存

yum 曆史

yum history:顯示yum操作曆史,是按照/var/log/yum.log進行的查找

yum history info 6檢視第六條資訊

yum history undo 6:撤銷第六步,如果第六步是安裝,則執行此指令,将删除第六步所安裝的程式,。如果第六步是解除安裝,那麼執行此指令,則進行安裝解除安裝掉的程式

yum history redo 6:重做第六步

五、國内開源鏡像站

網易 (http://mirrors.163.com/)

阿裡 (http://mirrors.aliyun.com/)

清華 (https://mirror.tuna.tsinghua.edu.cn/)

六、參考文檔

yum的repo檔案詳解、以及epel簡介、yum源的更換 (https://www.cnblogs.com/nineep/p/6795692.html)

yum配置與使用(很詳細) (https://www.cnblogs.com/xiaochaohuashengmi/archive/2011/10/09/2203916.html)