共计 4061 个字符,预计需要花费 11 分钟才能阅读完成。
本篇内容主要讲解“linux repo 指的是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让丸趣 TV 小编来带大家学习“linux repo 指的是什么”吧!
linux repo 就是指“repository”,表示安装文件的位置,同时,repo 也是在 linux 环境中开发 android 主机环境需要的工具包名称,用于进行版本控制;repo 文件是指 Fedora 中 yum 源的配置文件,通常一个 repo 文件定义了一个或者多个软件仓库的细节内容。
linux repo 是什么?
在 linux 操作系统中,repo=repository,表示安装文件的位置,同时,repo 也是在 linux 环境中开发 android 主机环境需要的工具包名称,用于进行版本控制。REPO 是 Google 用 python 脚本写的调用 Git 的脚本,主要用来下载、管理 android 项目的软件仓库。
linux yum 的配置文件 repo 文件详解
repo 文件:
repo 文件是 Fedora 中 yum 源(软件仓库)的配置文件,通常一个 repo 文件定义了一个或者多个软件仓库的细节内容,例如我们将从哪里下载需要安装或者升级的软件包,repo 文件中的设置内容将被 yum 读取和应用!
YUM 的工作原理并不复杂,每一个 RPM 软件的头(header)里面都会纪录该软件的依赖关系,那么如果可以将该头的内容纪录下来并且进行分析,可以知道每个软件在安装之前需要额外安装哪些基础软件。也就是说,在服务器上面先以分析工具将所有的 RPM 档案进行分析,然后将该分析纪录下来,只要在进行安装或升级时先查询该纪录的文件,就可以知道所有相关联的软件。所以 YUM 的基本工作流程如下:
服务器端:在服务器上面存放了所有的 RPM 软件包,然后以相关的功能去分析每个 RPM 文件的依赖性关系,将这些数据记录成文件存放在服务器的某特定目录内。
客户端:如果需要安装某个软件时,先下载服务器上面记录的依赖性关系文件(可通过 WWW 或 FTP 方式),通过对服务器端下载的纪录数据进行分析,然后取得所有相关的软件,一次全部下载下来进行安装。
vi /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/yy.rm # 默认是 /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] 片段相同)。
第二部分:
vi /etc/yum.repo.d/xx.repo
这个字段其实也可以在 yum.conf 里面直接配置
[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 的 添加 / 删除软件 工具,也能够方便地启用和禁用指定的软件仓库
几个变量
$releasever,发行版的版本,从 [main] 部分的 distroverpkg 获取,如果没有,则根据 redhat-release 包进行判断。
$arch,cpu 体系,如 i686,athlon 等
$basearch,cpu 的基本体系组,如 i686 和 athlon 同属 i386,alpha 和 alphaev6 同属 alpha。
对 yum.conf 设定完成,我们就可以好好体验 yum 带来的方便了。
还有一件事没有做。那就是导入每个 reposity 的 GPG key,前面说过,yum 可以使用 gpg 对包进行校验,确保下载包的完整性,所以我们先要到各个 repository 站点找到 gpg key,一般都会放在首页的醒目位置,一些名字诸如 RPM-GPG-KEY.txt 之类的纯文本文件,把它们下载,然后用 rpm –import xxx.txt 命令将它们导入,最好把发行版自带 GPG-KEY 也导入,rpm –import /usr/share/doc/redhat-release-*/RPM-GPG-KEY 官方软件升级用的上。
到此,相信大家对“linux repo 指的是什么”有了更深的了解,不妨来实际操作一番吧!这里是丸趣 TV 网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!