centos7的yum搭建与配置详解
######################
创建yum源:
操作步骤: 1. yum install httpd 2. 注释掉 /etc/httpd/conf.d/welcome.conf <LocationMatch > 下的字段 3. systemctl restart httpd 4. 在 /var/www/html/your_dir 下创建自己的rpm包目录 5. 然后将rpm下载到该目录下(your_dir). 6. 使用createrepo your_dir 命令创建本地repo
使用yum源:
在需要yum源的/etc/yum.repos.d/下创建自己的repo,下面是实例:igoodful.repo
[igoodful] name=igoodful #baseurl=http://yum_server:port/your_dir/ baseurl=http://127.0.0.1/glc/igoodful/ enable=1 gpgcheck=0 priority=1
同步:
同步其他服务器上的rpm到本地的方法可以使用reposync命令,其中reposync后面跟的是repo的源名称,可以通过 yum repolist来查看需要同步的源名称.
reposync -r igoodful
更换外网yum源:
以下的yum源适用于能够访问外网的机器,选择其中一个yum源即可。 cd /etc/yum.repos.d/ 阿里源:wget http://mirrors.aliyun.com/repo/Centos-7.repo 网易源:wget http://mirrors.163.com/.help/CentOS7-Base-163.repo
############################################################
什么是yum ?
yum,是Yellow dog Updater Modified的简称,起初是由yellow dog这一发行版的开发者Terra Soft研发,用python写成,那时还叫做yup(yellow dog updater),后经杜克大学的Linux@Duke开发团队进行改进,遂有此名。
众所周知,Redhat和Fedora的软件安装命令是rpm,但是用rpm安 装软件最大的麻烦就是需要手动寻找安装该软件所需要的一系列依赖关系,超级麻烦不说,要是软件不用了需要卸载的话由于卸载掉了某个依赖关系而导致其他的软 件不能用是非常恼人的。令人高兴的是,Fedora终于推出了类似于ubuntu中的apt的命令yum,令Fedora的软件安装变得简单容易。
yum有以下特点:
可以同时配置多个资源库(Repository) 简洁的配置文件(/etc/yum.conf)
自动解决增加或删除rpm包时遇到的倚赖性问题 使用方便
*保持与RPM数据库的一致性
什么是yum仓库?
yum仓库就是使用yum命令下载软件的镜像地址
我们通常使用 yum install 命令来在线安装linux系统的软件, 这种方式可以自动处理依赖性关系,并且一次安装所有依赖的软体包,但是经常会遇到从国外镜像下载速度慢,无法下载的情况.那么此时我们就需要把我们的yum 源改为国内的镜像,
centOs 中yum 的配置文件在 /etc/yum.repos.d 目录下, 其中有多个配置文件,每一个配置文件中都可以配置一个或多个repository, 但是最终会被合并为一个交给系统,所以多个文件只是为了方便管理
下边我们就设置一下自己的yum仓库
步骤:
cd /etc/yum.repos.d #进入配置文件目录
mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup #备份原文件
touch local.repo # 创建自己的配置文件
vi local.repo 在其中输入以下内容:
其中repository_url是存储库目录所在repodata目录的URL : 如果存储库可通过 HTTP 访问,请使用: http://path/to/repo 如果存储库可通过 FTP 访问,请使用: ftp://path/to/repo 如果存储库在机器本地,请使用: file:///path/to/local/repo 如果特定的在线存储库需要基本的 HTTP 身份验证,您可以通过将其作为. 例如,如果 http://www.example.com/repo/ 上的存储库需要用户名“ user ”和密码“ password ”,则可以将链接指定为。 username:password@linkbaseurlhttp://user:password@www.example.com/repo/
# CentOS-Base.repo # # The mirror system uses the connecting IP address of the client and the # update status of each mirror 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 mirrors. # # If the mirrorlist= does not work for you, as a fall back you can try the # remarked out baseurl= line instead. # # [base] name=CentOS-$releasever - Base - mirrors.aliyun.com failovermethod=priority baseurl=http://mirrors.aliyun.com/centos/$releasever/os/$basearch/ http://mirrors.aliyuncs.com/centos/$releasever/os/$basearch/ #mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=os gpgcheck=1 gpgkey=http://mirrors.aliyun.com/centos/RPM-GPG-KEY-CentOS-7 #released updates [updates] name=CentOS-$releasever - Updates - mirrors.aliyun.com failovermethod=priority baseurl=http://mirrors.aliyun.com/centos/$releasever/updates/$basearch/ http://mirrors.aliyuncs.com/centos/$releasever/updates/$basearch/ #mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=updates gpgcheck=1 gpgkey=http://mirrors.aliyun.com/centos/RPM-GPG-KEY-CentOS-7 #additional packages that may be useful [extras] name=CentOS-$releasever - Extras - mirrors.aliyun.com failovermethod=priority baseurl=http://mirrors.aliyun.com/centos/$releasever/extras/$basearch/ gpgkey=http://mirrors.aliyun.com/centos/RPM-GPG-KEY-CentOS-7
ps:还有简单方式
wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
yum make cache
5.保存退出,并测试
yum list #显示yum包
yum clean all #清除yum缓存
yum makecache #缓存本地yum仓库中的软件包信息
yum install httpd #安装apache
rpm -ql httpd #查询所有安装httpd的目录和文件
配置本地Yum仓库
搭建一个本地Yum,将光盘挂载到/media
mount /dev/cdrom /media/
将本地设置为客户端,进行Yum验证
命令操作如下所示:
cp CentOS-Base.repo local.repo #复制一个模板文件
修改文件为如下内容
name=Red Hat Enterprise Linux 6 //此为描述信息,可以看情况填写 baseurl=file:///media/ //此项为yum软件仓库位置,指向光盘挂载点 enabled=1 //此项为是否开启,1为开启0为不开启 gpgcheck=1 //此项为是否检查签名,1为监测0为不检测 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release //签名认证信息的路径
yum repolist 查看是否有该仓库
repo文件详解
repo文件是Fedora中yum仓库(软件仓库)的配置文件,通常一个repo文件定义了一个或者多个软件仓库的细节内容,例如我们将从哪里下载需要安装或者升级的软件包,repo文件中的设置内容将被yum读取和应用!
YUM的工作原理并不复杂,每一个 RPM软件的头(header)里面都会纪录该软件的依赖关系,那么如果可以将该头的内容纪录下来并且进行分析,可以知道每个软件在安装之前需要额外安装 哪些基础软件。也就是说,在服务器上面先以分析工具将所有的RPM档案进行分析,然后将该分析纪录下来,只要在进行安装或升级时先查询该纪录的文件,就可 以知道所有相关联的软件。所以YUM的基本工作流程如下:
服务器端:在服务器上面存放了所有的RPM软件包,然后以相关的功能去分析每个RPM文件的依赖性关系,将这些数据记录成文件存放在服务器的某特定目录内。
客户端:如果需要安装某个软件时,先下载服务器上面记录的依赖性关系文件(可通过WWW或FTP方式),通过对服务器端下载的纪录数据进行分析,然后取得所有相关的软件,一次全部下载下来进行安装。
yum 相关配置文件
yum 的配置文件分为两部分:main 和repository
- main 部分定义了全局配置选项,整个yum 配置文件应该只有一个main。常位于/etc/yum.conf 中。
- repository 部分定义了每个源/服务器的具体配置,可以有一到多个。常位于/etc/yum.repo.d 目录下的各文件中。
/etc/yum.conf详解:
[main] cachedir=/var/cache/yum #cachedir:yum缓存的目录,yum在此存储下载的rpm包和数据库,一般是/var/cache/yum。 debuglevel=2 #debuglevel:除错级别,0──10,默认是2 貌似只记录安装和删除记录 logfile=/var/log/yum.log pkgpolicy=newest #pkgpolicy: 包的策略。一共有两个选项,newest和last,这个作用是如果你设置了多个repository,而同一软件在不同的repository中同时存 在,yum应该安装哪一个,如果是newest,则yum会安装最新的那个版本。如果是last,则yum会将服务器id以字母表排序,并选择最后的那个 服务器上的软件安装。一般都是选newest。 distroverpkg=centos-release #指定一个软件包,yum会根据这个包判断你的发行版本,默认是redhat-release,也可以是安装的任何针对自己发行版的rpm包。 tolerant=1 #tolerent,也有1和0两个选项,表示yum是否容忍命令行发生与软件包有关的错误,比如你要安装1,2,3三个包,而其中3此前已经安装了,如果你设为1,则yum不会出现错误信息。默认是0。 exactarch=1 #exactarch,有两个选项1和0,代表是否只升级和你安装软件包cpu体系一致的包,如果设为1,则如你安装了一个i386的rpm,则yum不会用1686的包来升级。 retries=20 #retries,网络连接发生错误后的重试次数,如果设为0,则会无限重试。 obsoletes=1 gpgcheck=1 #gpgchkeck= 有1和0两个选择,分别代表是否是否进行gpg校验,如果没有这一项,默认是检查的。 reposdir=/etc/yum.repos.d #默认是 /etc/yum.repos.d/ 低下的 xx.repo后缀文件 #默认都会被include 进来 也就是说 /etc/yum.repos.d/xx.repo 无论配置文件有多少个 每个里面有多少个[name] 最后其实都被整合到 一个里面看就是了 重复的[name]后面的覆盖前面的 exclude=xxx #exclude 排除某些软件在升级名单之外,可以用通配符,列表中各个项目要用空格隔开,这个对于安装了诸如美化包,中文补丁的朋友特别有用。 keepcache=[1 or 0] # 设置 keepcache=1,yum 在成功安装软件包之后保留缓存的头文件 (headers) 和软件包。默认值为 keepcache=0 不保存 reposdir=[包含 .repo 文件的目录的绝对路径] # 该选项用户指定 .repo 文件的绝对路径。.repo 文件包含软件仓库的信息 (作用与 /etc/yum.conf 文件中的 [repository] 片段相同)。
/etc/yum.repo.d/xx.repo文件详解:
/etc/yum.repo.d/xx.repo文件详解 [serverid] #serverid是用于区别各个不同的repository(仓库;贮藏室;博物馆;亲信),必须有一个独一无二的名称。 重复了 前面覆盖后面--还是反过来呢???用enabled 测试是后面覆盖前面 name=Some name for this server #name,是对repository的描述,支持像$releasever $basearch这样的变量; name=Fedora Core $releasever - $basearch - Released Updates baseurl=url://path/to/repository/ #baseurl是服务器设置中最重要的部分,只有设置正确,才能从上面获取软件。它的格式是: baseurl=url://server1/path/to/repository/ url://server2/path/to/repository/ url://server3/path/to/repository/ #其中url支持的协议有 http:// ftp:// file://三种。baseurl后可以跟多个url,你可以自己改为速度比较快的镜像站,但baseurl只能有一个,也就是说不能像如下格式: baseurl=url://server1/path/to/repository/ baseurl=url://server2/path/to/repository/ baseurl=url://server3/path/to/repository/ 其中url指向的目录必须是这个repository header目录的上一级,它也支持$releasever $basearch这样的变量。 #mirrorlist=http://mirrors.fedoraproject.org/mirrorlist?repo=fedora-$releasever&arch=$basearch #上面的这一行是指定一个镜像服务器的地址列表,通常是开启的,本例中加了注释符号禁用了,我们可以试试,将$releasever和$basearch替换成自己对应的版本和架构,例如10和i386,在浏览器中打开,我们就能看到一长串镜可用的镜像服务器地址列表。 url之后可以加上多个选项,如gpgcheck、exclude、failovermethod等,比如: gpgcheck=1 exclude=gaim #其中gpgcheck,exclude的含义和[main]部分相同,但只对此服务器起作用, failovermethod=priority #failovermethode 有两个选项roundrobin和priority,意思分别是有多个url可供选择时,yum选择的次序,roundrobin是随机选择,如果连接失 败则使用下一个,依次循环,priority则根据url的次序从第一个开始。如果不指明,默认是roundrobin。 enabled=[1 or 0] #当某个软件仓库被配置成 enabled=0 时,yum 在安装或升级软件包时不会将该仓库做为软件包提供源。使用这个选项,可以启用或禁用软件仓库。 #通过 yum 的 --enablerepo=[repo_name] 和 --disablerepo=[repo_name] 选项,或者通过 PackageKit 的"添加/删除软件"工具,也能够方便地启用和禁用指定的软件仓库
服务器/etc/yum.conf的标准配置:
[root@xxx ~]# cat /etc/yum.conf [main] exclude=ibutils-libs* cachedir=/var/cache/yum/$basearch/$releasever keepcache=0 debuglevel=2 logfile=/var/log/yum.log exactarch=1 obsoletes=1 gpgcheck=1 plugins=1 installonly_limit=5 bugtracker_url=http://bugs.centos.org/set_project.php?project_id=23&ref=http://bugs.centos.org/bug_report_page.php?category=yum distroverpkg=centos-release # This is the default, if you make this bigger yum won't see if the metadata # is newer on the remote and so you'll "gain" the bandwidth of not having to # download the new metadata and "pay" for it by yum not having correct # information. # It is esp. important, to have correct metadata, for distributions like # Fedora which don't keep old packages around. If you don't like this checking # interupting your command line usage, it's much better to have something # manually check the metadata once an hour (yum-updatesd will do this). # metadata_expire=90m # PUT YOUR REPOS HERE OR IN separate files named file.repo # in /etc/yum.repos.d
/etc/yum.repos.d/CentOS-Base.repo文件标准配置:
shell> cat /etc/yum.repos.d/CentOS-Base.repo
[base] name=CentOS-7.3.1611 - Base #mirrorlist=http://yum.sys.srv/centos/7.3.1611/os/$basearch/ baseurl=http://yum.sys.srv/centos/7.3.1611/os/$basearch/ gpgcheck=0 gpgkey=http://yum.sys.srv/RPM-GPG-KEY-CentOS-7 #released updates [updates] name=CentOS-7.3.1611 - Updates #mirrorlist=http://yum.sys.srv/centos/7.3.1611/updates/$basearch/ baseurl=http://yum.sys.srv/centos/7.3.1611/updates/$basearch/ gpgcheck=0 gpgkey=http://yum.sys.srv/RPM-GPG-KEY-CentOS-7 #additional packages that may be useful [extras] name=CentOS-7.3.1611 - Extras #mirrorlist=http://yum.sys.srv/centos/7.3.1611/extras/$basearch/ baseurl=http://yum.sys.srv/centos/7.3.1611/extras/$basearch/ gpgcheck=0 gpgkey=http://yum.sys.srv/RPM-GPG-KEY-CentOS-7 #additional packages that extend functionality of existing packages [centosplus] name=CentOS-7.3.1611 - Plus #mirrorlist=http://yum.sys.srv/centos/7.3.1611/centosplus/$basearch/ baseurl=http://yum.sys.srv/centos/7.3.1611/centosplus/$basearch/ gpgcheck=0 enabled=0 gpgkey=http://yum.sys.srv/RPM-GPG-KEY-CentOS-7
几个变量:
shell> rpm -q centos-release centos-release-7-3.1611.el7.centos.x86_64 # 这里$releasever就是7的意思 # 先将我们可以修改/etcyum.conf源文件,把$releasever全部替换为7,然后通过如下命令安装centos-release软件包
shell> yum install centos-release
大多数发行版都使用distroverpkg版本来获取releasever和basearch。 如果查看/etc/yum.conf,您将看到Distrover设置为redhat-release(对于RHEL),enterpriselinux-release(对于OEL)以及其他。 获取包名: distro=$(sed -n 's/^distroverpkg=//p' /etc/yum.conf) 要获得发布版本: releasever=$(rpm -q --qf "%{version}" -f /etc/$distro) 要获得基本架构: basearch=$(rpm -q --qf "%{arch}" -f /etc/$distro)
获取系统架构:
shell> arch x86_64
$releasever,发行版的版本,从[main]部分的distroverpkg获取,如果没有,则根据redhat-release包进行判断。
$arch,cpu体系,如i686、athlon、x86_64等,咱们的服务器和电脑通常就是x86_64
$basearch,cpu的基本体系组,如i686和athlon同属i386,alpha和alphaev6同属alpha。
#############