以前介紹了Linux環境下本地yum源配置方法,不過這個是最簡單最基礎的配置,在yum安裝的時候可能有些軟件包不夠齊全,下面說下完整yun鏡像源系統環境部署記錄(yum源更新腳本下載地址:https://pan.baidu.com/s/1miMNPgc 提取密碼:x49g):php
1)安裝nginx,用於yum鏡像源訪問配置 [root@yum ~]# yum -y install gcc pcre-devel zlib-devel openssl-devel [root@yum ~]# cd /data/software [root@yum software]# wget http://nginx.org/download/nginx-1.12.0.tar.gz [root@yum software]# tar -zvxf nginx-1.12.0.tar.gz [root@yum software]# cd nginx-1.12.0 添加www用戶,其中-M參數表示不添加用戶家目錄,-s參數表示指定shell類型 [root@yum nginx-1.12.0]# useradd www -M -s /sbin/nologin [root@yum nginx-1.12.0]# ./configure --prefix=/data/nginx --user=www --group=www --with-http_ssl_module --with-http_flv_module --with-http_stub_status_module --with-http_gzip_static_module --with-pcre [root@yum nginx-1.12.0]# make && make install 2)配置nginx [root@yum ~]# cat /data/nginx/conf/vhosts/mirrors.conf server { listen 80; server_name yum.kevin.cn mirrors.kevin.cn localhost; index index.html index.php index.htm; access_log /data/nginx/logs/access.log main; error_log /data/nginx/logs/error.log; location / { root /data/mirrors; autoindex on; autoindex_exact_size off; autoindex_localtime on; } } [root@yum ~]# /data/nginx/sbin/nginx -t nginx: the configuration file /data/nginx/conf/nginx.conf syntax is ok nginx: configuration file /data/nginx/conf/nginx.conf test is successful [root@yum ~]# /data/nginx/sbin/nginx [root@yum ~]# lsof -i:80 COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME nginx 7741 root 6u IPv4 28311 0t0 TCP *:http (LISTEN) nginx 7769 www 6u IPv4 28311 0t0 TCP *:http (LISTEN) nginx 7770 www 6u IPv4 28311 0t0 TCP *:http (LISTEN) nginx 7771 www 6u IPv4 28311 0t0 TCP *:http (LISTEN) nginx 7772 www 6u IPv4 28311 0t0 TCP *:http (LISTEN) nginx 7773 www 6u IPv4 28311 0t0 TCP *:http (LISTEN) nginx 7774 www 6u IPv4 28311 0t0 TCP *:http (LISTEN) nginx 7775 www 6u IPv4 28311 0t0 TCP *:http (LISTEN) nginx 7776 www 6u IPv4 28311 0t0 TCP *:http (LISTEN) 3)建立yum源數據目錄 [root@yum ~]# mkdir -p /data/mirrors [root@yum ~]# cd /data/mirrors/ [root@yum mirrors]# mkdir centos epel etc rpmforge [root@yum mirrors]# ls centos epel etc rpmforge 4)編寫yum源下載更新腳本(從mirrors.ustc.edu.cn鏡像網站下載和更新) [root@yum ~]# cat /data/script/mirrors.sh #!/bin/bash #========================================== # Program : /bin/update_yum_source.sh # Info : 按期同步官方 yum 源到本地 # Version : 2017.12.10 v1.0 # author :kevin # Usage : 3 3 * * * /bin/bash /data/script/mirrors.sh #========================================== Date=`date +%Y%m%d` LogFile="/data/logs/$Date.log" ReceiveMail="wangshibo@kevin.com" RsyncBin="/usr/bin/rsync" RsyncPerm="-avrt --delete --exclude=debug/ --exclude=isos/ --exclude=SRPMS/ --exclude=ppc/ --delete-excluded" #============ centos ============== CentOS_Path="/data/mirrors/centos" YumSiteList="rsync://mirrors.ustc.edu.cn/centos/" centosparm="--exclude=2*/ --exclude=3*/ --exclude=4*/ --exclude=5*/" #============ epel ============== epelSite="rsync://mirrors.ustc.edu.cn/fedora-epel" epelLocalPath="/data/mirrors/epel" epelparm="--include=7/x86_64 --include=7Server/x86_64 --include=6/x86_64 --include=6Server/x86_64" #============ rpmforge ============== rpmforgeSite="rsync://apt.sw.be/pub/freshrpms/pub/dag/redhat/" #rpmforgeSite="rsync://apt.sw.be/redhat/" rpmforgeLocalPath="/data/mirrors/rpmforge/" rpmforgeparm="--exclude=ppc/ --exclude=el2.1/ --exclude=el3/ --exclude=el4/ --exclude=el5/" echo "---- $Date `date +%T` Begin ----" >>$LogFile # centos $RsyncBin $RsyncPerm $centosparm $YumSiteList $CentOS_Path >> $LogFile # epel $RsyncBin $RsyncPerm $epelparm $epelSite $epelLocalPath >> $LogFile # rpmforge $RsyncBin $RsyncPerm $rpmforgeparm $rpmforgeSite $rpmforgeLocalPath >> $LogFile echo "---- $Date `date +%T` End ----" >> $LogFile #/bin/mail -s "opt001 - update yum source - $Date" $ReceiveMail<$LogFile 以上腳本中須要注意的幾點: --exclude 表示rsync同步的時候,須要排除的目錄(具體表現:同步下來的目錄裏面爲空,大小爲0) --include 表示rsync同步的時候,只想同步的目錄 因爲本案例是部署yum源,用於linux服務器上本地yum方案安裝,不須要同步isos鏡像(同時也能夠節省機器空間資源),因此在同步的時候將isos鏡像目錄屏蔽 執行同步腳本。這個過程比較長,大概要下載將近180G的內容。須要耐心等待~~ [root@yum ~]# sh -x /data/script/mirrors.sh [root@yum ~]# du -sh /data/mirrors/* 93G /data/mirrors/centos 80G /data/mirrors/epel 4.0K /data/mirrors/etc 4.0K /data/mirrors/rpmforge 410M /data/mirrors/software [root@yum ~]# ls /data/mirrors/centos/ 2 3.6 6.0 6.6 7.1.1503 dostools RPM-GPG-KEY-CentOS-3 RPM-GPG-KEY-CentOS-Debug-6 timestamp.txt 3 3.7 6.1 6.7 7.2.1511 filelist.gz RPM-GPG-KEY-centos4 RPM-GPG-KEY-CentOS-Debug-7 3.1 3.8 6.2 6.8 7.3.1611 graphics RPM-GPG-KEY-CentOS-4 RPM-GPG-KEY-CentOS-Security-6 3.3 4 6.3 6.9 7.4.1708 HEADER.html RPM-GPG-KEY-CentOS-5 RPM-GPG-KEY-CentOS-Testing-6 3.4 5 6.4 7 build HEADER.images RPM-GPG-KEY-CentOS-6 RPM-GPG-KEY-CentOS-Testing-7 3.5 6 6.5 7.0.1406 dir_sizes RPM-GPG-KEY-beta RPM-GPG-KEY-CentOS-7 TIME [root@yum ~]# ls /data/mirrors/epel/ 4 5Client 7Server fullfilelist.KDUVzc9WPK RPM-GPG-KEY-EPEL-4 RPM-GPG-KEY-EPEL-7Server 4AS 5Server epel-release-latest-6.noarch.rpm fullfiletimelist-epel RPM-GPG-KEY-EPEL-5 testing 4ES 6 epel-release-latest-7.noarch.rpm fullfiletimelist-epel.WaO7KUHvYz RPM-GPG-KEY-EPEL-6 4WS 6Server fullfilelist imagelist-epel RPM-GPG-KEY-EPEL-6Server 5 7 fullfilelist.AwiES3LjSB RPM-GPG-KEY-EPEL RPM-GPG-KEY-EPEL-7 5)替換linux本機的yum源地址 [root@yum ~]# cd /etc/yum.repos.d/ [root@yum yum.repos.d]# ls CentOS-Base.repo CentOS-Debuginfo.repo CentOS-fasttrack.repo CentOS-Media.repo CentOS-Vault.repo [root@yum yum.repos.d]# mkdir bak [root@yum yum.repos.d]# mv *.repo bak/ [root@yum yum.repos.d]# ls bak 編寫yum源文件 [root@yum yum.repos.d]# cat CentOS-Base.repo # CentOS-Base.repo # # The mirrors system uses the connecting IP address of the client and the # update status of each mirrors to pick mirrors that are updated to and # geographically close to the client. You should use this for CentOS updates # unless you are manually picking other mirrorss. # # If the mirrorslist= does not work for you, as a fall back you can try the # remarked out baseurl= line instead. # # [base] name=CentOS-CentOS-$releasever - Base #mirrorslist=http://mirrorlist.centos.org/?release=CentOS-$releasever&arch=$basearch&repo=os&infra=$infra baseurl=http://mirrors.kevin.cn/centos/$releasever/os/$basearch/ gpgcheck=1 gpgkey=http://mirrors.kevin.cn/centos/RPM-GPG-KEY-CentOS-$releasever #released updates [updates] name=CentOS-CentOS-$releasever - Updates #mirrorslist=http://mirrorlist.centos.org/?release=CentOS-$releasever&arch=$basearch&repo=updates&infra=$infra baseurl=http://mirrors.kevin.cn/centos/$releasever/updates/$basearch/ gpgcheck=1 gpgkey=http://mirrors.kevin.cn/centos/RPM-GPG-KEY-CentOS-$releasever #additional packages that may be useful [extras] name=CentOS-CentOS-$releasever - Extras #mirrorslist=http://mirrorlist.centos.org/?release=CentOS-$releasever&arch=$basearch&repo=extras&infra=$infra baseurl=http://mirrors.kevin.cn/centos/$releasever/extras/$basearch/ gpgcheck=1 gpgkey=http://mirrors.kevin.cn/centos/RPM-GPG-KEY-CentOS-$releasever #additional packages that extend functionality of existing packages [centosplus] name=CentOS-CentOS-$releasever - Plus #mirrorslist=http://mirrorlist.centos.org/?release=CentOS-$releasever&arch=$basearch&repo=centosplus&infra=$infra baseurl=http://mirrors.kevin.cn/centos/$releasever/centosplus/$basearch/ gpgcheck=1 enabled=0 gpgkey=http://mirrors.kevin.cn/centos/RPM-GPG-KEY-CentOS-$releasever #contrib - packages by Centos Users [contrib] name=CentOS-CentOS-$releasever - Contrib #mirrorslist=http://mirrorlist.centos.org/?release=CentOS-$releasever&arch=$basearch&repo=contrib&infra=$infra baseurl=http://mirrors.kevin.cn/centos/$releasever/contrib/$basearch/ gpgcheck=1 enabled=0 gpgkey=http://mirrors.kevin.cn/centos/RPM-GPG-KEY-CentOS-$releasever [root@yum yum.repos.d]# cat epel.repo [epel] name=Extra Packages for Enterprise Linux $releasever - $basearch baseurl=http://mirrors.kevin.cn/epel/$releasever/$basearch #mirrorlist=https://mirrors.fedoraproject.org/metalink?repo=epel-6&arch=$basearch failovermethod=priority enabled=1 gpgcheck=1 gpgkey=http://mirrors.kevin.cn/epel/RPM-GPG-KEY-EPEL-$releasever [epel-debuginfo] name=Extra Packages for Enterprise Linux 6 - $basearch - Debug baseurl=http://mirrors.kevin.cn/epel/$releasever/$basearch/debug #mirrorlist=https://mirrors.fedoraproject.org/metalink?repo=epel-debug-6&arch=$basearch failovermethod=priority enabled=0 gpgkey=http://mirrors.kevin.cn/epel/RPM-GPG-KEY-EPEL-$releasever gpgcheck=1 [epel-source] name=Extra Packages for Enterprise Linux 6 - $basearch - Source baseurl=http://mirrors.kevin.cn/epel/$releasever/SRPMS #mirrorlist=https://mirrors.fedoraproject.org/metalink?repo=epel-source-6&arch=$basearch failovermethod=priority enabled=0 gpgkey=http://mirrors.kevin.cn/epel/RPM-GPG-KEY-EPEL-$releasever gpgcheck=1 [root@yum yum.repos.d]# yum clean all [root@yum yum.repos.d]# yum makecache 其餘服務器要是想用本yum源,就按照上面操做,將/etc/yum.repos.d目錄下的repo文件都移除,而後將上面編寫的兩個文件放進去,執行yum clean all和yum makecache便可! ============================================================================ 舒適提示:以上的yum源配置及兩個yum文件在centos6和centos7系統下都適用!已經驗證!! ============================================================================ 更新以上yum源的腳本: 能夠將上面兩個文件放到http://mirrors.kevin.com/software裏面,用於腳本中下載 [root@yum ~]# cd /data/mirrors/software/ [root@yum software]# ls yum_reset.sh CentOS-Base.repo epel.repo [root@yum software]# cat yum_reset.sh #!/bin/bash cd /etc/yum.repos.d/ /bin/mkdir /etc/yum.repos.d/bak mv /etc/yum.repos.d/*.repo /etc/yum.repos.d/bak wget http://mirrors.kevin.com/software/CentOS-Base.repo wget http://mirrors.kevin.com/software/epel.repo /usr/bin/yum clean all /usr/bin/yum makecache 只須要將上面的yum_reset.sh腳本下載到目標服務器上,而後執行,就能夠將目標服務器的yum源更新了。 # wget http://mirrors.kevin.com/software/yum_reset.sh # sh -x yum_reset.sh
能夠按期更新以上的yum源同步腳本(mirros.sh),好比每個月更新一次html
[root@yum ~]# crontab -e #每一個月1號的23:00點同步一次yum源 0 23 1 * * /bin/bash -x /data/script/mirrors.sh > /dev/null 2>&1
如何將新的rpm包添加到本地部署的內部yum源裏 linux
根據上面部署的內部yum源路徑,將新的rpm包拷貝到centos6或centos7對應的yum源的Packages包內便可. 好比將新的rpm包拷貝到centos6對應的/data/mirrors/centos/6/os/x86_64/Packages的rpm包路徑下,而後執行: # yum clean all # yum makecache 若是是centos7下添加新rpm包,同理拷貝到/data/mirrors/centos/7/os/x86_64/Packages的rpm包路徑下.