CentOS搭建本地yum源【HTTP方式】

本文轉自 開源中國
原文地址 https://my.oschina.net/u/1461927/blog/372147

YUM介紹

YUM主要用于自動升級、安裝\移除rpm軟件包,它能自動查找并解決rpm包之間的依賴關系,> 要成功的使用YUM工具更新系統(tǒng)和軟件,需要有一個包含各種rpm軟件包的repository(軟件 > 倉庫),提供軟件倉庫的服務器習慣上成為“源”服務器。網(wǎng)絡上有大量的源服務器,但是,由
于 受到網(wǎng)絡連接速度、帶寬的限制,導致軟件安裝耗時過長甚至失敗。特別是當有大量服務器> 大量軟件包需要升級時,更新的緩慢程序令人難以忍受。

相比較而言,本地YUM源服務器最大優(yōu)點在局域網(wǎng)的快速網(wǎng)絡連接和穩(wěn)定性。有了局域網(wǎng)中
的YUM源服務器,即便在Internet連接中斷的情況下,也不會影響其他YUM客戶端的軟件升級> 和安裝。

下面就介紹下 本地yum源的搭建。

一、啟動 httpd 服務(一般httpd服務已經(jīng)安裝)

取一臺 CentOS操作系統(tǒng)的機器作為源服務器。啟動服務器的httpd 服務:service httpd start

Paste_Image.png

可查看配置文件: /etc/httpd/conf/httpd.conf 了解httpd相關配置信息

這里我們配置的文檔根目錄為:/var/www/html/ 端口: Listen 80

vi /etc/httpd/conf/httpd.conf

Paste_Image.png

確認服務啟動,瀏覽器訪問: http://localhost:80 出現(xiàn)如下apache頁面(如果從其他機器訪問,請先關閉防火墻:service iptables stop )

Paste_Image.png

二、安裝 createrepo 工具 (若使用 linux iso 鏡像 則為非必須)

createrepo是linux下的創(chuàng)建倉庫的軟件包。

1、在機器聯(lián)網(wǎng)的情況下可直接安裝: yum install createrepo

2、可使用rpm -ivh createrepo-xxx.noarch.rpm 安裝由網(wǎng)上下載的rpm包,一般會有兩個依賴

3、linux常用工具rpm包,一般在鏡像文件中都存在

三、安裝 yum 源

1、使用 Linux ISO 鏡像中的RPM包安裝

(1)、將 ISO 文件 copy 到服務器上,并在文件夾: /var/www/html/ 下創(chuàng)建文件夾 CentOS

Paste_Image.png

(2)、將 ISO文件掛載至文件夾 /var/www/html/CentOS

執(zhí)行:mount -o loop /var/www/html/CentOS-6.4-x86_64-bin-DVD1.iso /var/www/html/CentOS

(取消掛載 umount /var/www/html/CentOS)

Paste_Image.png

(3)、查看文件夾 /var/www/html/CentOS

Paste_Image.png

可以看到 repodata 文件夾的存在,repodata作為軟件的倉庫信息文件。
ISO鏡像 yum源搭建OK
瀏覽器訪問:http://localhost:80/CentOS/

Paste_Image.png

2、使用 自己準備的 RPM 包 (這里以 apache ambari為例)

(1)、在目錄 /var/www/html/ 下建立一個文件夾,把準備的 RPM包放到里面

Paste_Image.png

(2)、創(chuàng)建倉庫信息文件,在目錄 /var/www/html/ 下執(zhí)行:createrepo ambari

Paste_Image.png

查看ambari目錄,可以看到 repodate 文件已經(jīng)生成

ambari yum源搭建OK

Paste_Image.png

四、使用yum源

(1)、編輯 repo 文件

在本機或其他機器上,進入文件夾:/etc/yum.repos.d/ 將其中的文件移除掉

Paste_Image.png

新建文件:CentOS.repo (可由 CentOS-Base.repo copy)

Paste_Image.png

(2)、更新 yum源

yum clean 清除yum源緩存

yum repolist 列出可用yum源

Paste_Image.png

(3)、使用 (嘗試安裝postgresql)

Paste_Image.png

同理可配置使用 ambari 源

Paste_Image.png

可將 repo 文件放置在源服務器 /var/www/html/ 目錄下,以供其他機器方便下載使用
五、可能會出現(xiàn)的問題

1、問題

you don't have permission to access / on this server(Apache Server權限訪問問題)

Apache Http Server已經(jīng)在linux上安裝完成,可是通過瀏覽器訪問,卻出現(xiàn)了“you don't have permission to access / on this server”.

解決:

(1)、在httpd.conf文件中,有這么一段

<Directory/> # 這里的目錄為自己的目錄

Options FollowSymLinks

AllowOverride None

Order deny,allow

Deny from all

</Directory>

可以嘗試把Deny改成Allow,然后重啟apache服務,訪問頁面,看問題是否解決。

(2)、查看相應的目錄是否擁有權限,如果你不知道怎么加權限之類,運行如下兩個命令:

chown apache.root 目錄名 -R # 此是更改目錄所屬用戶和用戶組

chmod 755 目錄名 -R # 此是更改目錄讀寫權限

然后重啟apache服務,訪問頁面,看問題是否解決。

(3)、終極絕殺,以上2條都還通不過的話(報相同的錯誤信息),運行如下兩個命令

setenforce 0 # 暫時禁用SELinux服務

service iptables stop #暫時禁用防火墻

訪問頁面,看問題是否解決;

2、問題:

Loaded plugins: fastestmirror, refresh-packagekit, security

Determining fastest mirrors

http://10.1.33.21/ambari/repodata/repomd.xml: [Errno 14] PYCURL ERROR 22 - "The requested URL returned error: 403 Forbidden"

Trying other mirror.

Error: Cannot retrieve repository metadata (repomd.xml) for repository: ambari-1.x. Please verify its path and try again

解決:

yum源服務器運行如下命令

setenforce 0               # 暫時禁用SELinux服務

3、問題:

yum install xxx.rpm

warning:

Package xxx.rpm is not signed

解決:

只要在在后面加上--nogpgcheck就可以了,格式如下

yum install *rpm --nogpgcheck

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

  • 今天我說一下如何在centos上搭建lamp環(huán)境,即linux+apache+mysql+php 這是一個標準的w...
    BetaMake閱讀 1,614評論 0 2
  • 1. 概述 日常的工作中,經(jīng)常要安裝和卸載軟件,在linux centos的版本里提供了rpm這個命令進行安裝,但...
    ghbsunny閱讀 4,056評論 0 3
  • http://blog.csdn.net/mathewsking/article/details/8211273 ...
    liuboxx1閱讀 6,235評論 1 1
  • 山崇崇,水長長。 舟橫江流江入江,安能渡來群花香。 只愿東風逐春浪,繞過青橋停柳旁。 燕剪絲,鶯吟芳。 留芳解燕語...
    天水居士閱讀 351評論 4 10
  • 迎著無邊的曠野的寒風, 一匹枯瘦的老馬, 跨過無數(shù)座拱橋, 張著嘴哼哧哼哧的吐著白氣, 一路走來背上的東西越來越重...
    一川野草閱讀 371評論 0 2

友情鏈接更多精彩內(nèi)容