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
下一篇 2015-05-13

相关推荐

  • linux防火墙介绍

    一、前言firewall(防火墙):工作在网络进入或者流包,进出的网络数据包进行一定的规则进行检查过滤系统。包括iptables和netfilter组件。iptables 是与 Linux 内核集成的 IP 信息包过滤系统。如果 Linux 系统连接到因特网或 LAN、服务器或连接 LAN 和因特网的代理服务器, 则该系统系统中更好地控制 IP 信息包过滤和…

    2017-04-30
  • N22-第十四周作业

    系统的INPUT和OUTPUT默认策略为DROP; ~]# iptables -P INPUT DROP ~]# iptables -P OUTPUT DROP 1、限制本地主机的web服务器在周一不允许访问;新请求的速率不能超过100个每秒;web服务器包含了admin字符串的…

    Linux干货 2017-03-15
  • N22-℡浮生.若夢 ╮-第二周作业

    1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。 cp文件复制:       常用选项:     -i:交互式复制,即覆盖之前提醒用户确认;     -f:强制覆盖目标文件;  &n…

    Linux干货 2016-09-06
  • ansible学习笔记之2 ad-hoc篇

    ansible学习笔记之2 ad-hoc篇 ansible学习笔记之2 ad-hoc篇 ansible 学习笔记 ad-hoc ansible学习笔记之2 ad-hoc篇 使用ansible ad-hoc搭建lnmp/lamp 编辑host文件,通过秘钥认证ssh连接主机 前期环境准备 在lnmp上安装lnmp 其中 ad-hoc搭建mysql主从 配置文件…

    2016-11-21
  • linux用户和组

    *** Linux用户和组: 1.用户:Username/UID     管理员:root, 0     系统用户:1-499(CENTOS6), 1-999(CENTOS7)     对守护进程获取资源进行权限分配  &nbsp…

    Linux干货 2016-08-04
  • ldirectord 结合ipvsadm 配置nat,dr模型

    ldirectord 结合ipvsadm 配置nat,dr模型  一、nat模型 1、 drector # wget ftp://172.16.0.1/pub/Sources/7.x86_64/crmsh/ldirectord-3.9.6-0rc1.1.1.x86_64.rpm # yum -y install nginx (同时用于做为sorry…

    Linux干货 2014-01-03