Linux系統下本地yum鏡像源環境部署-完整記錄

 

以前介紹了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包路徑下.
相關文章
相關標籤/搜索