LINUX学生会

yum仓库创建与使用

2017-06-11  本文已影响31人  fengkaipeng

yum是基于C/S架构的,有服务端和客户端,可以自动解决依赖关系的RPM包的前端工具。
工作流程:yum客户端先会将各个包之间的元数据文件下载并放在自己的数据库中(etc/var/yum/),然后根据所要下载的包的依赖关系他能够实现自动查找相互依赖的rpm包,并从服务端中下载互相依赖的rpm包到本地并安装,安装完成后自动删除安装包。

配置文件

首先,我们到yum配置文件/etc/yum.conf下看看:

cachedir=/var/cache/yum/$basearch/$releasever #安装包缓存
keepcache=0 #包是否要保存,0是不保存,写成1就是保存,如果保存就存在上面的目录下
debuglevel=2 #日志的调试级别,级别越高越详细
logfile=/var/log/yum.log #日志文件路径
exactarch=1 #是否允许更新不同版本的包
obsoletes=1 #是否允许更新旧版本的包
gpgcheck=1 #是否检查密钥
plugins=1 #是否允许使用插件,默认为0不允许
installonly_limit=5 #允许保留多少个内核包
bugtracker_url=http://bugs.centos.org/set_project.php?project_id=19&ref=http://bugs.centos.org/bug_report_page.php?category=yum #bug提交地址
distroverpkg=centos-release 将 $releasever 设置为 centos-release 这个RPM包的版本号
...
# metadata_expire=90m #元数据有效期

# PUT YOUR REPOS HERE OR IN separate files named file.repo
# in /etc/yum.repos.d  #库放置路径

服务端

然后,我们需要去配置服务端:
将所需的rpm包放到一个目录下,然后用createrepo这个命令读取各个包的元数据和依赖关系,生成一个名为repodata的目录。这样,父目录就可以当作服务端来使用了。我们做个小实验来看看:

[root@feng ~]# mount /dev/sr0 /mnt/ #挂载光盘
mount: block device /dev/sr0 is write-protected, mounting read-only
[root@feng ~]# cd /mnt/Packages/ #进入光盘目录
[root@feng Packages]# mkdir /test #创建test目录
[root@feng Packages]# find -name "*ftp*" -ok cp {} /test \;
< cp ... ./ftp-0.17-54.el6.x86_64.rpm > ? y
< cp ... ./gvfs-obexftp-1.4.3-26.el6.x86_64.rpm > ? y
...
[root@feng Packages]# ls /test/ #验证有没有复制成功
ftp-0.17-54.el6.x86_64.rpm            lftp-4.0.9-6.el6.x86_64.rpm  tftp-server-0.49-8.el6.x86_64.rpm
gvfs-obexftp-1.4.3-26.el6.x86_64.rpm  tftp-0.49-8.el6.x86_64.rpm   vsftpd-2.2.2-21.el6.x86_64.rpm
[root@feng test]# createrepo /test
...
[root@feng test]# ls   #查看到repodata目录创建成功
ftp-0.17-54.el6.x86_64.rpm            lftp-4.0.9-6.el6.x86_64.rpm  tftp-0.49-8.el6.x86_64.rpm         vsftpd-2.2.2-21.el6.x86_64.rpm
gvfs-obexftp-1.4.3-26.el6.x86_64.rpm  repodata                     tftp-server-0.49-8.el6.x86_64.rpm

客户端

为了实验方便,我们先将/etc/yum.repo.d/目录下的默认文件都先移动到别处,然后根据配置文件最后两行,我们在/etc/repos.d/下边创建名为base.repo结尾的文件,我们来看下文件内容:

[base] #库名
name=base # 库名(这一行不写用yum repolist会报个错,但是不影响使用)
baseurl=file:///test/ #服务端路径
gpgcheck=1 #是否要检验公钥
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6 #公钥路径

基本上有这几行yum仓库就可以使用了,由于实验是将仓库做在本地的/test目录下,所以路径写的为file:///test/这种写法,要是服务端在网络上的别的主机,写法有:

视服务端开启的什么共享服务而定

使用

配置好之后,就可以使用了,下面为常用的yum命令语法和参数:
yum [options] [command] [package ...]

还有一些不常用的选项,这里就不一一列出了,系统中可以用man yum来查看。

上一篇下一篇

猜你喜欢

热点阅读