前言:
现在小伙伴们对“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,0703. 第三方镜像搭建局域网使用的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