yum前端软件包管理器

yum是什么

    Yum (Yellow dog Updater, Modified) 由Duke University团队,修改Yellow Dog Linux的Yellow Dog Updater开发而成,是一个基于 RPM 包管理的字符前端软件包管理器。能够从指定的服务器自动下载 RPM 包并且安装,可以处理依赖性关系,并且一次安装所有依赖的软件包,无须繁琐地一次次下载、安装。被Yellow Dog Linux本身,以及Fedora、Red Hat Enterprise Linux采用。

yum工作机制

    C/S架构:client –> server

    yum仓库(server端):

        保存rpm包以及元数据,如:包名、版本信息、各包所包含的文件列表、依赖关系、包分组信息等。

    yum客户端(client端):以安装过程为例

        第一步:获取仓库元数据,缓存于本地,缓存目录/var/cache/yum

        第二步:yum客户端读取并分析本地缓存的元数据文件,结合本地系统环境做出要安装的程序包的决策,如依赖关系

        第三步:根据决策联系yum仓库,下载各程序包缓存到本地,一并进行安装

yum仓库:

    可以理解为rpm包的文件服务器,repodata目录所在的父目录就是一个可用仓库。

    自建一个yum仓库:

        1、把rpm包放到一个目录

        2、通过createrepo命令分析该目录的rpm包,然后生成元数据目录repodata

        3、配置yum客户端使用此仓库即可,就是这么简单。

yum客户端:

    要想通过yum管理rpm包,需要读取yum仓库的配置文件,指明仓库访问路径及各种属性信息

    主配置文件:/etc/yum.conf

    一个或几个相关仓库的配置信息可保存为一个文件,文件名以.repo结尾:/etc/yum.repos.d

    文件格式:

[REPOID]
name=Some name for this repository    #设置该yum仓库的名称
baseurl=url://server1/path/to/repository/           #方式1:指定yum仓库访问路径,支持多种url,如:ftp、nfs、http等,可指定多个url
        http://mirror.centos.org/centos/$releasever/os/$basearch/     #URL中也支持$releasever 、$basearch这样的变量,指定系统版本号
        mirrorlist=/path/to/urlfile        #方式2:可以将多个url写入一个文件,然后读取这个文件    
enabled={0|1}        #是否启用该yum仓库,0为不启用,1为启用,默认为1
gpgcheck={0|1}       #是否校验rpm包,0为不启用,1为启用
gpgkey=URL           #如果校验,指定公钥文件路径

   yum配置文件中可用的四个变量:

          $releasever: 程序的版本,对Yum而言指的是redhat-release版本;只替换为主版本号,如RedHat 6.5,则替换为6;
          $arch: 系统架构
          $basearch: 系统基本架构,如i686,i586等的基本架构为i386;
          $uuid:
          $YUM0-9: 在系统中定义的环境变量,可以在yum中使用;

    一个配置文件支持多个yum仓库

    1、列出所有repo

[root@qin ~]# yum repolist  {enabled|disabled|all}      #enabled列出可用的,disabled列出禁用的,all列出所有(默认)

    2、列出rpm包及包组

[root@qin ~]# yum list {all|installed|available}    #all列出所有包(默认),installed列出已安装的包,available列出可安装的包
[root@qin ~]# yum list KEYWORD*    #列出指定前缀的所有包,支持文件名通配

    3、包的描述信息

[root@qin ~]# yum info package_name

    4、列出所有包组信息

[root@qin ~]# yum grouplist

    5、显示包组的信息:例如组中包含的程序包列表

[root@qin ~]# yum groupinfo "GROUP NAME"

    6、清理缓存

[root@qin ~]# yum clean {all|packages|metadata|expire-cache|rpmdb|plugins}

    7、安装程序包

[root@qin ~]# yum install package_name
[root@qin ~]# yum reinstall package_name    #重新安装

    8、包的升级和降级

[root@qin ~]# yum check-update    #检查可用的升级包
[root@qin ~]# yum update package_name    #可以指定升级包的版本号升级;如果不指定包名,就升级所有可用的升级包
[root@qin ~]# yum downgrade package_name    #包降级

    9、包的卸载

[root@qin ~]# yum {remove|erase} package_name

    10、查询某文件是由哪个包安装生成的

[root@qin ~]# yum {whatprovides|provides} /path/to/somefile

    11、安装包组

[root@qin ~]# yum groupinstall "GROUP NAME"

    12、卸载包组

[root@qin ~]# yum groupremove "GROUP NAME"

    13、只下载包,不安装

[root@qin ~]# yumdownloader package_name    #此命令由yum-utils包提供

    14、另外一些常用选项介绍

--nogpgcheck    #不对包做校验
--disablerepo=[repo]    #安装时禁用某些yum仓库
-y:    #对所有交互式操作返回yes
[root@qin ~]# yum history    #显示yum的历史记录
[root@qin ~]# yum history list X    #X是历史事务ID,显示指定事务明细操作
[root@qin ~]# yum history redo X    #重新执行指定事务
[root@qin ~]# yum history undo X    #回滚指定事务
[root@qin ~]# yum makecache         #生成元数据
[root@qin ~]# yum search  STRING    #查找包含指定关键字的包

原创文章,作者:秦,如若转载,请注明出处:http://www.178linux.com/4241

(0)
上一篇 2015-05-13 18:37
下一篇 2015-05-13 18:39

相关推荐

  • sed

    复制/etc/rc.d/rc.sysinit文件到/tmp目录中,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首家#; 2.复制/boot/grub/grub.conf至/tmp中,删除/tmp/grub.conf文件中的行首的空白字符 3.删除/tmp/rc.sysinit文件中的以#开头,且后面跟了一个至少一个空白字符的行行的#…

    Linux干货 2016-12-04
  • corosync的高可用——高可用mariadb数据库

    corosync, pacemaker,nfs高可用mariadb 实验环境: 4台CentOS 7 的主机,并关闭的iptalbes和selinux功能 主机1:10.1.43.101 node1 corosync+pacemaker+amp 主机2:10.1.43.102 node2 corosync+pacemaker+amp 主机3:10.1.43….

    Linux干货 2016-11-24
  • OpenSSL 的使用

    OpenSSL 是一个开源项目,其组成主要包括一下三个组件:     openssl:多用途的命令行工具     libcrypto:加密算法库     libssl:加密模块应用库,实现了ssl及tls openssl可以实现:秘钥证书管…

    Linux干货 2017-06-07
  • 内核参数修改 内核编译 第14天

    Linux内核:单内核,模块化 内核的某些模块 编译进内核本体 [*] 编译成内核模块 [M] 不选择使用     [ ] 内核的组成部分 /boot/vmlinuz-VERSION /lib/modules/VERSION/ *.ko 模块间有可能有依赖关系 内核模块管理 lsmod:显…

    Linux干货 2016-01-18
  • 网络班N22期第三周博客作业

    一、列出当前系统所有已经登录的用户名,且同一个用户登录多次只显示一次 [root@bogon ~]# w  15:17:44 up 15:28,  2 users,  load average: 0.00, 0.00, …

    Linux干货 2016-08-29
  • Linux的终端类型

    Linux的终端类型 Linux的终端类型: TTY(虚拟终端,图形终端) 早期的电子计算机的输入设备是穿孔卡片【又称霍列瑞斯式卡(Herman Hollerith)或IBM卡】,用有洞和无洞表示计算机二进制里面的0和1,以此来记录相关信息,但是这种方式很慢。 1986年股票代码被发明,人们通过电报和电传打印机发送实时股票价格,此时teletypewrite…

    Linux干货 2016-10-14