yum仓库创建与使用

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/这种写法,要是服务端在网络上的别的主机,写法有:

  • baseurl=ftp://URL
  • baseurl=http://URL
  • baseurl=https://URL

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

使用

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

  • install:安装(将依赖的包一起安装,可以安装本地下载好的rpm包,但是要写全路径和文件名)
  • remove:卸载 (卸载指定包和一起安装但是没有别的依赖关系的包)
  • repolist :列出仓库 默认列出enabled,可以加disabled列出禁用的,用all 列出所有(可以在配置文件中用enabled=0来关闭不使用的仓库)
  • list:文件列表 用available来列出未安装的 updates列出更新的
  • reinstall:重装
  • info:查看详细信息
  • serch:关键字查找相关内容
  • --nogpgcheck:临时忽略包检查
  • clean all:清空缓存,有时候挂光盘不一样会导致缓存错误,yum不合适可以看下这里
  • make cache:构建缓存,装包会自动构建,网络慢的时候可以先提前构建一下
  • history:历史信息,有几个选项配合使用,功能强大(由于这个命令是基于日志的,所以删除日志这个功能就不好使了):
  •      info #:查看第几条历史的详细信息
    
  •     undo #:将之前的操作反过来操作一次,比如刚装了个软件,用remove卸载由于依赖关系可能删不全,但是用这个装什么就全删
    
  •      redo #:重复之前的操作  
    

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

你可能感兴趣的:(yum仓库创建与使用)