龙空技术网

搭建本机和局域网yum源

聚财账务 177

前言:

现在小伙伴们对“centos访问url”大致比较关注,姐妹们都想要了解一些“centos访问url”的相关资讯。那么小编也在网摘上收集了一些关于“centos访问url””的相关文章,希望各位老铁们能喜欢,各位老铁们一起来学习一下吧!

背景

搭建本地yum源大概有下面三种情况:

ISO镜像搭建本机使用的yum仓库ISO镜像搭建局域网使用的yum仓库第三方镜像搭建局域网使用的yum仓库

不管怎样,核心有两点:yum包仓库搭建、repo配置url。

另外,由于包受限于选择的仓库来源,故包的版本取决于选择的仓库,极有可能不是最新版、或者不是自己想要的版本。比如ansible在本次所选择的epel源版本是2.7.2,这是老版本

[root@node1 yum.repos.d]#yum list|grep ansibleansible.noarch                           2.7.2-1.el7                   @epel    ansible.noarch                           2.9.15-1.el7                  epel     ansible-doc.noarch                       2.9.15-1.el7                  epel     ansible-inventory-grapher.noarch         2.4.4-1.el7                   epel     ansible-lint.noarch                      3.5.1-1.el7                   epel     ansible-openstack-modules.noarch         0-20140902git79d751a.el7      epel     ansible-python3.noarch                   2.9.15-1.el7                  epel     ansible-review.noarch                    0.13.4-1.el7                  epel     centos-release-ansible-27.noarch         1-1.el7                       extras   centos-release-ansible-28.noarch         1-1.el7                       extras   centos-release-ansible-29.noarch         1-1.el7                       extras   centos-release-ansible26.noarch          1-3.el7.centos                extras   kubernetes-ansible.noarch                0.6.0-0.1.gitd65ebd5.el7      epel     python2-ansible-runner.noarch            1.0.1-1.el7                   epel     python2-ansible-tower-cli.noarch         3.3.9-1.el7                   epel     vim-ansible.noarch                       3.0-1.el7                     epel     [root@node1 yum.repos.d]#rpm -qa|grep ansibleansible-2.7.2-1.el7.noarch
环境
[root@node1 yum.repos.d]#cat /etc/redhat-release CentOS Linux release 7.5.1804 (Core)无防火墙、selinux关闭
搭建步骤1. ISO镜像搭建本机使用的yum仓库,最简单

挂载镜像->修改repo->使用

假定系统识别的镜像在/dev/cdrom

mount /dev/cdrom /mnt    // 挂载到mnt目录,mnt目录可以按自己习惯修改
备份原repo文件,创建新的repo文件
mkdir /etc/yum.repos.d/bak&&mv /etc/yum.repos.d/*repo  /etc/yum.repos.d/bakcat <<EOF >yum.repo [local]name=Local_centosbaseurl=      //mnt是挂载目录enable=1gpcheck=0EOF

3.使用

yum clean all //删除缓存[root@node2 yum.repos.d]# yum repolist   //查看仓库情况已加载插件:fastestmirrorLoading mirror speeds from cached hostfile源标识                                         源名称                                                状态local                                       Local_centos                                          4,070repolist: 4,070
yum install * //安装
2. ISO镜像搭建局域网使用的yum仓库

此步骤需要配合http服务,推荐nginx,不赘述

nginx改局域网yum仓库的html路径。

worker_processes  1;events {    worker_connections  1024;}http {    include       mime.types;    default_type  application/octet-stream;    sendfile        on;    keepalive_timeout  65;    server {        listen       8080;        server_name  localhost;        location / {            autoindex  on; //重要            root   /mnt/; # (这里请换成你的实际目录路径)        }    }}

理论上加入server{}内容,nginx -t检查错语法,重启nginx即可,但是这样修改后在客户端总是404

[root@node2 yum.repos.d]# cat yum.repo //客户端已备份原有repo,创建repo配置[centos]name=Local_centosbaseurl=

404报错

[root@node2 yum.repos.d]# yum makecache已加载插件:fastestmirrorLoading mirror speeds from cached hostfile: [Errno 14] HTTP Error 404 - Not Found正在尝试其它镜像。To address this issue please refer to the below wiki article  above article doesn't help to resolve this issue please use .元数据缓存已建立

猜想原因是nginx为yum安装,/etc/nginx/nginx.conf加入的server配置其实根本没有生效,验证手段:改端口80位8081,重启服务,查看端口,发现仍旧是80。说明猜想正确。

[root@node1 yum.repos.d]#netstat -antp|grep nginxtcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      2883/nginx: master 
故采取了手动生成yum仓库的办法进入nginx默认html目录,手动创建包仓库信息
cd /usr/share/nginx/html/mkdir yum ln -s /mnt/Packages Packages //关键,创建包的软连接。直接拷贝过来也行createrepo yum/                          //创建仓库索引信息,createrepo可能需要安装

createrepo之后,yum的目录结构:包、html索引

[root@node1 logs]#ll /usr/share/nginx/html/yum/总用量 4lrwxrwxrwx 1 root root   13 11月 26 19:08 Packages -> /mnt/Packagesdrwxr-xr-x 2 root root 4096 11月 26 19:10 repodata

修改客户端repo配置文件的url目录

[root@node2 yum.repos.d]# cat yum.repo //客户端已备份原有repo,创建repo配置[centos]name=Local_centosbaseurl=   //比之前多了yumenable=1gpcheck=0

客户端再次yum clean all和yum makecache不再报错

[root@node2 yum.repos.d]# yum clean all已加载插件:fastestmirror正在清理软件源: centosCleaning up everythingMaybe you want: rm -rf /var/cache/yum, to also free up space taken by orphaned data from disabled or removed reposCleaning up list of fastest mirrors[root@node2 yum.repos.d]# yum makecache已加载插件:fastestmirrorLoading mirror speeds from cached hostfilecentos                                                                             | 2.9 kB  00:00:00     元数据缓存已建立[root@node2 yum.repos.d]# yum repolist已加载插件:fastestmirrorDetermining fastest mirrorscentos                                                                             | 2.9 kB  00:00:00     centos/primary_db                                                                  | 3.3 MB  00:00:00     源标识                                         源名称                                                状态centos                                         Local_centos                                          4,070repolist: 4,070
3. 第三方镜像搭建局域网使用的yum仓库,比如阿里云repo和epel

举一反三,由步骤2引出第三个方法,如果有第三方的包,那本地全部下载后重复步骤2,创建包目录、仓库索引页。这样会生成一个更全的仓库,因为毕竟centos镜像文件还是会缺包,比如nginx就没有。

参考

下载工具

yum install createrepo    yum-utils -y//yum-utils -y包含reposync 很重要
备份repo,下载阿里云repo/epel
wget -O /etc/yum.repos.d/CentOS-Base.repo  -O /etc/yum.repos.d/epel.repo [root@node1 yum.repos.d]#ll总用量 12drwxr-xr-x  2 root root  263 11月 26 20:36 bak-rw-r--r--  1 root root 2523 6月  16 2018 CentOS-Base.repo-rw-r--r--  1 root root  664 5月  11 2018 epel.repo
同步镜像到本地,包很大,约30G。
[root@prometheus yum.repos.d]# yum clean all   #清除之前的yum源缓存[root@prometheus yum.repos.d]# yum makecache  #创建缓存[root@prometheus yum.repos.d]# yum repolist   #查看当前可用的YUM源
cd ~ //切换到用户家目录[root@prometheus ~]# reposync -r base  #reposync将根据刚下载的repo下载rpm包到指定文件夹[root@prometheus ~]# reposync -r extras[root@prometheus ~]# reposync -r updates[root@prometheus ~]# reposync -r epel
创建yum仓库索引
[root@prometheus ~]# cd /root/base[root@prometheus ~]# createrepo ./[root@prometheus ~]# cd /root/extras[root@prometheus ~]# createrepo ./[root@prometheus ~]# cd /root/updates[root@prometheus ~]# createrepo ./[root@prometheus ~]# cd /root/epel[root@prometheus ~]# createrepo ./

此时/root/下面主要目录是下面四个,每个目录下面会有Packages和repodata两个目录,打包拷贝到现场。

9.0G    ./base748M    ./extras3.4G    ./updates16G     ./epel29G     .
现场客户端备份、创建repo配置文件。

5.1 无nginx,只创建本机仓库 ,即本机就是客户端 。 解压包到/root/yum

[root@node1 ~]# vim /etc/yum.repos.d/base.repo [base]name=CentOS-Basebaseurl=   #是否将该仓库做为软件包提供源gpgcheck=0  #是否进行gpg校验[updates]name=CentOS-Updatesbaseurl=[extras]name=CentOS-Extrasbaseurl=[root@node1 ~]# vim /etc/yum.repos.d/epel.repo[epel]name=CentOS-Epelbaseurl=

使用前

yum clean all&&yum makecache

5.2 有nginx,此时可以搭建局域网仓库

解压包到nginx的默认html目录,如/usr/share/nginx/html/yum/

[root@node1 ~]# vim /etc/yum.repos.d/base.repo[base]name=CentOS-Basebaseurl=   #是否将该仓库做为软件包提供源gpgcheck=0  #是否进行gpg校验[updates]name=CentOS-Updatesbaseurl=[extras]name=CentOS-Extrasbaseurl=[root@node1 ~]# vim /etc/yum.repos.d/epel.repo[epel]name=CentOS-Epelbaseurl=

使用前

yum clean all&&yum makecache

标签: #centos访问url #更换yum源会导致系统重启不来吗 #yum安装netstat