linux repo就是指“repository”,表示安裝檔案的位置,同時,repo也是在linux環境中開發android主機環境需要的工具包名稱,用於進行版本控制;repo檔案是指Fedora中yum來源的設定文件,通常一個repo文件定義了一個或多個軟體倉庫的細節內容。
本教學操作環境:linux5.9.8系統、Dell G3電腦。
linux repo是什麼?
在linux作業系統中,repo=repository,表示安裝檔案的位置,同時,repo也是在linux環境中開發android主機環境所需的工具包名稱,用於進行版本控制。 REPO是Google用python腳本寫的呼叫Git的腳本,主要用來下載、管理android專案的軟體倉庫。
linux yum的設定檔repo檔詳解
#repo檔:
repo檔是Fedora中yum來源(軟體倉庫)的設定文件,通常一個repo文件定義了一個或多個軟體倉庫的細節內容,例如我們將從哪裡下載需要安裝或升級的軟體包,repo文件中的設定內容將被yum讀取和應用!
YUM的工作原理並不複雜,每個RPM軟體的頭(header)裡面都會記錄該軟體的依賴關係,那麼如果可以將該頭的內容記錄下來並且進行分析,可以知道每個軟體在安裝前需要額外安裝哪些基礎軟體。也就是說,在伺服器上面先以分析工具將所有的RPM檔案進行分析,然後將該分析紀錄下來,只要在進行安裝或升級時先查詢該紀錄的文件,就可以知道所有相關聯的軟體。所以YUM的基本工作流程如下:
伺服器端:在伺服器上面存放了所有的RPM軟體包,然後以相關的功能去分析每個RPM檔案的依賴性關係,將這些資料記錄成文件存放在伺服器的某特定目錄內。
客戶端:如果需要安裝某個軟體時,先下載伺服器上面記錄的依賴性關係檔(可透過WWW或FTP方式),透過對伺服器端下載的紀錄資料進行分析,然後取得所有相關的軟體,一次全部下載下來進行安裝。
vi /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 gpgcheck=1 #gpgchkeck= 有1和0两个选择,分别代表是否是否进行gpg校验,如果没有这一项,默认是检查的。 reposdir=/etc/yy.rm #默认是 /etc/yum.repos.d/ 低下的 xx.repo后缀文件
#預設都會被include 進來也就是說/etc/yum.repos.d/xx.repo 無論設定檔有多少個每個裡面有多少個[name] 最後其實都被整合到一個裡面看就是了重複的[name]後面的覆蓋前面的
exclude=xxx
#exclude 排除某些軟體在升級名單之外,可以用通配符,列表中各個項目要用空格隔開,這個對於安裝了諸如美化包,中文補丁的朋友特別有用。
keepcache=[1 or 0]
# 設定 keepcache=1,yum 在成功安裝軟體包之後保留快取的頭檔 (headers) 和軟體包。預設值為 keepcache=0 不儲存
reposdir=[包含 .repo 文件的目录的绝对路径]
# 此選項使用者指定 .repo 檔案的絕對路徑。 .repo 檔案包含軟體倉庫的資訊 (作用與 /etc/yum.conf 檔案中的 [repository] 片段相同)。
第二部分:
vi /etc/yum.repo.d/xx.repo
這個欄位其實也可以在yum.conf裡面直接設定
[serverid]
#其中serverid是用於區別各不同的repository,必須有一個獨特的名稱。重複了 前面覆蓋後面--還是反過來呢? ? ?用enabled 測試是後面覆蓋前面
name=Some name for this server
#name,是對repository的描述,支援像$releasever $basearch這樣的變數; name=Fedora Core $releasever - $basearch - Released Updates
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
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 的"新增/刪除軟體"工具,也能夠方便地啟用和停用指定的軟體倉庫
幾個變數
$releasever,發行版的版本,從[main]部分的distroverpkg取得,如果沒有,則根據redhat-release套件進行判斷。
$arch,cpu體系,如i686,athlon等
$basearch,cpu的基本體系組,如i686和athlon同屬i386,alpha和alphaev6同屬alpha。
對yum.conf設定完成,我們就可以好好體驗yum帶來的方便了。
還有一件事沒有做。那就是導入每個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 官方軟體升級用的上。
推薦學習:《linux影片教學》
以上是linux repo是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!