一、概覽
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)