yum 和 epel 的詳解

1、概覽html

一、什麼是repo文件linux

repo文件是Fedora中yum源(軟件倉庫)的配置文件,一般一個repo文件定義了一個或者多個軟件倉庫的細節內容,例如咱們將從哪裏下載須要安裝或者升級的軟件包,repo文件中的設置內容將被yum讀取和應用數據庫

 

二、Yum的工做原理centos

YUM的工做原理並不複雜,每個 RPM軟件的頭(header)裏面都會紀錄該軟件的依賴關係,那麼若是能夠將該頭的內容紀錄下來而且進行分析,能夠知道每一個軟件在安裝以前須要額外安裝 哪些基礎軟件。也就是說,在服務器上面先以分析工具將全部的RPM檔案進行分析,而後將該分析紀錄下來,只要在進行安裝或升級時先查詢該紀錄的文件,就可 以知道全部相關聯的軟件瀏覽器

 

三、YUM的基本工做流程緩存

3.1、服務器端安全

在服務器上面存放了全部的RPM軟件包,而後以相關的功能去分析每一個RPM文件的依賴性關係,將這些數據記錄成文件存放在服務器的某特定目錄內。服務器

3.2、客戶端網絡

若是須要安裝某個軟件時,先下載服務器上面記錄的依賴性關係文件(可經過WWW或FTP方式),經過對服務器端下載的紀錄數據進行分析,而後取得全部相關的軟件,一次所有下載下來進行安裝。架構

 

四、Yum配置

4.1Yum的兩部分main 和repository

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變 量定義了系統的架構,能夠是i38六、x86_6四、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://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,在瀏覽器中打開,咱們就能看到一長串鏡可用的鏡像服務器地址列表。

 

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.四、導入每一個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 官方軟件升級用的上。

 

2、epel

一、epel是什麼

若是既想得到 RHEL 的高質量、高性能、高可靠性,又須要方便易用(關鍵是免費)的軟件包更新功能,那麼 Fedora Project 推出的 EPEL(Extra Packages for Enterprise Linux)正好適合你。EPEL(http://fedoraproject.org/wiki/EPEL) 是由 Fedora 社區打造,爲 RHEL 及衍生髮行版如 CentOS、Scientific Linux 等提供高質量軟件包的項目

 

二、如何獲取 EPEL 的軟件包

EPEL 包含一個叫作 ‘epel-release’ 的包,其中包含了用於軟件包簽名的 gpg 密鑰和軟件源的信息。安裝這個包到您的企業版 Linux 上以後,您將能夠經過使用相似於 yum 的工具來安裝軟件包和它們的依賴。在默認狀況下,EPEL 倉庫的穩定版本是開啓的。除了 epel-release 源,還有一個叫作 ‘epel-testing’ 倉庫 包含還沒有被視做穩定的軟件,請自行斟酌開啓的風險。 

CentOS 用戶能夠直接經過 yum install epel-release 安裝並啓用 EPEL 源。

 

三、使用心得:

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

二、epel會有不少源地址,若是一個下不到,會去另一個下

三、更新時若是下載的包不全,就不會進行安裝。這樣的話,依賴關係能夠保重

 

四、安裝yum install yum-priorities

Yum Priorities 插件能夠用來強制保護源。它經過給各個源設定不一樣的優先級,使得系統管理員能夠將某些源(好比 Linux 發行版的官方源)設定爲最高優先級,從而保證系統的穩定性(同時也可能沒法更新到其它源上提供的軟件最新版本)。

 

3、Yum源更換

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

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

Centos7:

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

3.運行如下命令生成緩存

yum clean all

yum makecache

 

4、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:重作第六步

5、國內開源鏡像站

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

阿里 (https://opsx.alibaba.com/mirror)

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

 

6、參考文檔

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

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

CentOS 7.0本地yum源地址及 配置yum地址優先級 (https://blog.csdn.net/tantexian/article/details/38895449)

yum源配置及詳解 (http://www.javashuo.com/article/p-pmaapcwu-br.html)

Linux man pages online (http://www.man7.org/linux/man-pages/index.html)

相關文章
相關標籤/搜索