Linux系統下yum鏡像源環境部署記錄


之前介紹了Linux環境下本地yum源配置方法,不過這個是最簡單最基礎的配置,在yum安裝的時候可能有些軟件包不夠齊全,下面說下完整yun鏡像源系統環境部署記錄(yum源更新腳本下載地址:https://pan.baidu.com/s/1miMNPgc     提取密碼:hq6u):

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
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.com mirrors.kevin.com 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@veredholdings.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 .veredholdings.cn /centos/ $releasever /os/ $basearch/
gpgcheck=1
gpgkey=http: //mirrors .veredholdings.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 .veredholdings.cn /centos/ $releasever /updates/ $basearch/
gpgcheck=1
gpgkey=http: //mirrors .veredholdings.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 .veredholdings.cn /centos/ $releasever /extras/ $basearch/
gpgcheck=1
gpgkey=http: //mirrors .veredholdings.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 .veredholdings.cn /centos/ $releasever /centosplus/ $basearch/
gpgcheck=1
enabled=0
gpgkey=http: //mirrors .veredholdings.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 .veredholdings.cn /centos/ $releasever /contrib/ $basearch/
gpgcheck=1
enabled=0
gpgkey=http: //mirrors .veredholdings.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 .veredholdings.cn /epel/ $releasever/$basearch
#mirrorlist=https://mirrors.fedoraproject.org/metalink?repo=epel-6&arch=$basearch
failovermethod=priority
enabled=1
gpgcheck=1
gpgkey=http: //mirrors .veredholdings.cn /epel/RPM-GPG-KEY-EPEL- $releasever
  
[epel-debuginfo]
name=Extra Packages  for  Enterprise Linux 6 - $basearch - Debug
baseurl=http: //mirrors .veredholdings.cn /epel/ $releasever/$basearch /debug
#mirrorlist=https://mirrors.fedoraproject.org/metalink?repo=epel-debug-6&arch=$basearch
failovermethod=priority
enabled=0
gpgkey=http: //mirrors .veredholdings.cn /epel/RPM-GPG-KEY-EPEL- $releasever
gpgcheck=1
  
[epel- source ]
name=Extra Packages  for  Enterprise Linux 6 - $basearch - Source
baseurl=http: //mirrors .veredholdings.cn /epel/ $releasever /SRPMS
#mirrorlist=https://mirrors.fedoraproject.org/metalink?repo=epel-source-6&arch=$basearch
failovermethod=priority
enabled=0
gpgkey=http: //mirrors .veredholdings.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),比如每月更新一次

1
2
3
[root@yum ~] # crontab -e
#每個月1號的23:00點同步一次yum源
0 23 1 * *  /bin/bash  -x  /data/script/mirrors .sh >  /dev/null  2>&1


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM