本地YUM仓库搭建实战

YUM主要用于自动安装、升级rpm软件包,它能自动查找并解决rpm包之间的依赖关系。要成功的使用YUM工具安装更新软件或系统,就需要有一个包含各种rpm软件包的repository(软件仓库),这个软件仓库我们习惯称为yum源。网络上有大量的yum源,但由于受到网络环境的限制,导致软件安装耗时过长甚至失败。特别是当有大量服务器大量软件包需要安装时,缓慢的进度条令人难以忍受。因此我们在优化系统时,都会更换国内的源。
相比较而言,本地YUM源服务器最大优点是局域网的快速网络连接和稳定性。有了局域网中的YUM源服务器,即便在Internet连接中断的情况下,也不会影响其他YUM客户端的软件安装和升级。

1.1 服务端配置
mkdir -p /application/yum/centos6.6/x86_64/ 1.创建yum仓库目录,rpm包都上至此目录
yum -y install createrepo 2.安装createrepo软件
createrepo -pdo /application/yum/centos6.6/x86_64/ /application/yum/centos6.6/x86_64/ 3.初始化repodata索引文件
cd /application/yum/centos6.6/x86_64/ 4.进入需要提供仓库的目录
python -m SimpleHTTPServer 80 &>/dev/null & 5.可以用Apache或nginx提供web服务,但用Python的http模块更简单,适用于内网环境, 可以通过浏览器输入本机IP查看。
createrepo --update /application/yum/centos6.6/x86_64/ 6.每加入一个rpm包就要更新一下
sed -i ‘s#keepcache=0#keepcache=1#g‘ /etc/yum.conf 修改yum配置文件keepacache=0改为1,保存下载过的软件
cachedir=/var/cache/yum/$basearch/$releasever 安装包存储目录= /var/cache/yum/x86_64/6/base/packages
1.2客户端配置
cd /etc/yum.repos.d
[[email protected] yum.repos.d]# vi oldboy.repo 连接本地yum源
[xuliangwei]
name=Server
baseurl=http://10.0.0.5
enable=1
gpgcheck=0
[[email protected] ~]# yum --enablerepo=xuliangwei--disablerepo=base,extras,updates,epel list 指定使用xuliangwei库(临时生效)
[[email protected] yum.repos.d]# vim /etc/yum.repos.d/CentOS-Base.repo
# 在每一个启动的源加上
# enabled=0 #改为1就启用,没有此参数也是启用。
[base]
…………
enabled=0

[updates]
…………
enabled=0

[extras]
…………
enabled=0
# 还有其他开启的仓库就使用这个办法关闭
2.Yum服务配置文件
2.1全局配置文件
main部分定义了全局配置选项,整个yum配置文件应该只有一个main,位于/etc/yum.cof
[[email protected] ~]# cat /etc/yum.conf
[main]
cachedir=/var/cache/yum/$basearch/$releasever yum缓存的目录,存储下载的rpm包和数据库
keepcache=0 安装完成后是否保留软件包,0为不保留(默认为0),1为保留
debuglevel=2 Debug信息输出等级,范围为0-10,缺省为2
logfile=/var/log/yum.log 日志文件位置
exactarch=1 有1和0两个选项,设置为1,则yum只会安装和系统架构匹配的软件包。
obsoletes=1 update的参数,相当于upgrade,允许更新陈旧的RPM包。
gpgcheck=1
plugins=1 是否启用插件,默认1为允许,0表示不允许
installonly_limit=5
bugtracker_url=http://bugs.centos.org/set_project.php?project_id=16&ref=http://bugs.centos.org/bug_report_page.php?category=yum
distroverpkg=centos-release 指定一个软件包,yum会根据这个包判断发行版本
2.2yum仓库配置文件
repository部分定义了每个源服务器的具体配置,可以有一到多个,位于/etc/yum.repos.d/目录下的各文件中
[[email protected] ~]# ll /etc/yum.repos.d/
CentOS-Base.repo 网络源的配置文件
CentOS-Media.repo 本地源的配置文件
epel.repo 第三方源的配置文件
2.3配置本地yum源
[[email protected] ~]# grep -v "^#" /etc/yum.repos.d/CentOS-Media.repo

[c6-media]
name=CentOS-$releasever - Media
baseurl=file:///media/CentOS/
file:///media/cdrom/ 修改为/mnt/cdrom(即为光盘挂载点)
file:///media/cdrecorder/
gpgcheck=1
enabled=0 改为1就启动,没有此参数也是启用。
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6
#当然也可以像上面自己写一个文件,然后指定为下载点即可。
3.企业yum仓库搭建实战
上面只是将自己制作的rpm包,放入yum源。但还有一种企业需求,说的更具体一点,平时学生上课yum安装软件都是从公网下载的,占用带宽,因此在学校里搭建一个内网yum服务器,但又考虑到学生回家也要使用yum安装软件,如果yum软件的数据库文件repodata不一样,就会有问题。因此我想到的解决方法就是直接使用公网yum源的repodata。

镜像同步公网yum源上游yum源必须要支持rsync协议,否则不能使用rsync进行同步。http://mirrors.ustc.edu.cn/status/
CentOS官方标准源:rsync://mirrors.ustc.edu.cn/centos/
epel源:rsync://mirrors.ustc.edu.cn/epel/
同步命令:
# 使用rsync同步yum源,为了节省带宽、磁盘和下载时间,我只同步了CentOS6的rpm包,这样所有的rpm包只占用了21G,全部同步需要300G左右。
# 同步base源,小技巧,我们安装系统的光盘镜像含有部分rpm包,大概3G,这些就不用重新下载。
/usr/bin/rsync -av rsync://mirrors.ustc.edu.cn/centos/6/os/x86_64/ /data/yum_data/centos/6/os/x86_64/
/usr/bin/rsync -av rsync://mirrors.ustc.edu.cn/centos/6/extras/x86_64/ /data/yum_data/centos/6/extras/x86_64/
/usr/bin/rsync -av rsync://mirrors.ustc.edu.cn/centos/6/updates/x86_64/ /data/yum_data/centos/6/updates/x86_64/
# epel源
/usr/bin/rsync -av --exclude=debug rsync://mirrors.ustc.edu.cn/epel/6/x86_64/ /data/yum_data/epel/6/x86_64/
学生使用内网yum源方法
# 可以自建一个内网dns,如果没有,可使用hosts解析。
echo ‘192.168.0.200 mirrors.aliyun.com‘ >>/etc/hosts

时间: 2024-08-29 03:49:33

本地YUM仓库搭建实战的相关文章

本地Yum仓库搭建部署

本地yum仓库搭建: 系统:Centos6.5 去阿里镜像下载Centos6的yum源,安装系统eple-release源: #wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-6.repo #yum install epel-release -y 安装nginx服务和createrepo 创建yum仓库的命令: #yum install nginx -y # yum install c

Firewalld共享上网及本地yum仓库搭建

1.firewalld共享上网 1.服务端操作(有外网的服务器) 1.开启防火墙并加入开机自启动 [[email protected] ~]# systemctl start firewalld [[email protected] ~]# systemctl enable firewalld 2.移除默认所有人能访问ssh的规则 [[email protected] ~]# firewall-cmd --remove-service=ssh --permanent 3.添加只允许10.0.0.

RedHat6.7 Linux本地yum仓库搭建

RedHat6.7 yum本地仓库搭建 准备工作: 1.RedHat6.7光盘 2.挂载光盘: 插入光盘并确保系统能识别光盘 光盘设备默认在/dev/cdrom下 # ls /dev/cdrom 如果没有找到光盘----查找光盘 # ls -l /dev | grep cdrom 1)触发挂载 Ls /misc/cd 2)手动挂载 mkdir /my-yong      在跟下面创建一个my-yong目录 mount /dev/cdrom /my-yong   挂载光盘到my-yong目录下,m

vsftpd-本地yum仓库搭建介绍

首先,下载一个yum库,我这里为了演示用的是局域网的.[[email protected] yum.repos.d]# wget http://172.16.0.1/centos6.6.repo[[email protected] yum.repos.d]# yum makecache1安装lftp[[email protected] yum.repos.d]# yum -y install lftp[[email protected] xen]# lftp 172.16.0.1lftp 172

在linux上搭建本地yum源

准备yum仓库的光盘镜像IOS文件: 设置光驱加载本地磁盘的yum仓库的光盘镜像文件: 在linux的命令行输入setup命令打开设置窗口,选择"System Service": 在打开的系统服务列表中找到httpd服务,确保它处于选中状态: 然后重启机器,使httpd服务启动生效,待虚拟机启动后,在浏览器中访问此机器的主机名,比如我的这台机器的主机名为hadoop01,那么就在浏览器中访问http://hadoop01/,如果出现如下界面,说明httpd服务成功启动: 然后使用SSH

centos 的yum仓库搭建

一.yum仓库说明1.搭建yum仓库必要性内网环境下,为了实现自动化和自定义的人性化便捷快速的增加部署服务,搭建yum仓库是首选,可以公司网环境下搭建yum源,供公司内部员工使用,并且能够通过定制rpm包,完成一件安装.2.yum仓库简介yum(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat中的Shell前端软件包管理器.基於RPM包管理,能够从指定的服务器自动下载RPM包并且安装,可以自动处理依赖性关系,并且一次安装所有依赖的软体包,无须繁

软件包管理之YUM仓库搭建

上一篇介绍了YUM的基本安装和卸载等功能的使用,这里就介绍一下如何搭建本地YUM仓库以及系统刚安装完成YUM仓库的配置信息. YUM仓库:存储了众多RPM包以及包的相关元数据(repodata)的文件服务器 可做YUM仓库的类型:http.ftp.nfs.file(本地) 先来看下yum客户端的配置文件: 它的配置文件由两部分组成:主配置文件和其他配置文件 主配置文件: 这个文中定义了使用yum安装时的缓存文件保存的目录,是否保留安装完成后rpm包,日志文件路径,是否启用插件,是否校验包的完整性

yum,仓库搭建

yum仓库搭建分为以下几步骤: 1.搜集rpm包 2.安装httpd 服务 3.生成rpm包的依赖关系 4.创建配置文件 5.测试 步骤: 首先检查系统的版本: [[email protected] ~]# uname -r 2.6.32-573.el6.x86_64 [[email protected] ~]# cat /etc/centos-release  CentOS release 6.7 (Final) 1.搜集rpm包 [[email protected] ~]# grep "ke

局域网yum仓库搭建-http和ftp方式

#局域网yum仓库搭建-http方式和ftp方式[[email protected] ~]# uname -aLinux YUM01 2.6.32-696.23.1.el6.x86_64 #1 SMP Tue Mar 13 22:44:18 UTC 2018 x86_64 x86_64 x86_64 GNU/Linux[[email protected] ~]# cat /etc/redhat-release CentOS release 6.9 (Final) http服务器端设置[[emai