YUM配置安装使用详解

一、YUM简介

    1. YUM: Yellowdog Update Modifier

完成RHEL系列前端自动解决依赖关系安装工具,依赖rpm存在

    2.工作模式:C/S 架构

      Server端(yum仓库):依赖关系库、原文件、校验码文件

      Client端:yum客户端程序、配置文件(连接Server路径信息)

    3.设计缺陷:

某一次安装过程中半途终止,再次重启后将无法解决程序间的依赖关系

yum升级版dnf就是为了解决此类问题

    2.yum repository: yum repo,yum仓库

存储rpm包,以及包的相关的元数据文件(放置于特定目录下:repodata);

 

二、YUM客户端配置

    1.yum配置文件路径

/etc/yum.conf:为所有yum仓库提供公共配置

/etc/yum.repos.d/*.repo:为仓库的指向提供配置

    2./etc/yum.conf主配置定义

        [root@localhost ~]# man 5 yum.conf           #可获得yum.conf的详解

       [root@localhost ~]# cat /etc/yum.conf

[main]            #通用主配置段

cachedir=/var/cache/yum/$basearch/$releasever          # 缓存文件路径

keepcache=0                     # 缓存到本地的文件是否保存

debuglevel=2                   # 调试级别

logfile=/var/log/yum.log                 # 安装的日志文件

exactarch=1                                              # 精确严格的平台release匹配

obsoletes=1

gpgcheck=1                      #检测来源合法性和完整性

plugins=1                         #支持插件机制

installonly_limit=5                    #同时安装多少程序包

bugtracker_url=http://bugs.centos.org/set_project.php?project_id=23&ref=http://bugs.centos.org/bu        # 追踪bug路径

distroverpkg=centos-release               # 当前发行版版本号从哪儿获取

#  This is the default, if you make this bigger yum won't see if the metadata

# is newer on the remote and so you'll "gain" the bandwidth of not having to

# download the new metadata and "pay" for it by yum not having correct

# information.

#  It is esp. important, to have correct metadata, for distributions like

# Fedora which don't keep old packages around. If you don't like this checking

# interupting your command line usage, it's much better to have something

# manually check the metadata once an hour (yum-updatesd will do this).

# metadata_expire=90m

# PUT YOUR REPOS HERE OR IN separate files named file.repo

# in /etc/yum.repos.d

    3.仓库(*.repo)配置文件定义:

[repositoryID]        #仓库ID,唯一标识别,不能重复

name=Some name for this repository       #  完整的仓库名称

baseurl=url://path/to/repository/          # yum仓库指明的访问路径

enabled={1|0}           #是否启用此yum仓库,默认启用

gpgcheck={1|0}              #是否检查完整性和来源合法性

gpgkey=URL                     #秘钥文件位置,可能是对方仓库提供

enablegroups={1|0}              #是否基于组来批量管理程序包

failovermethod={roundrobin|priority}    #故障转移方法:轮询、根据优先级选择; 默认roundrobin随机

cost=#                    #设置开销,默认为1000

… ...

     说明:

                1)*.repo可以将多个[repositoryID]的配置信息放在一个而文件内,也可以切成多个方便管理

     2)baseurl可以使用:ftp:// 、http:// 、nfs:// 、file:///  指明URL路径

     3)baseurl等号两边不能有空格,其后可以填写多个镜像访问路径,每行一个,不能顶行写

           多个访问路径间联系是镜像相同,目的是为了做备用访问

     4)更多选项使用man  5  yum.conf查看,基本配置只需前三行就可以        

     5)发行版光盘镜像安装可能会自动配置网络镜像URL地址

 

三、yum命令的用法

 yum   [options]   [command]   [package ...] 

    1.OPTIONS

    --nogpgcheck:禁止进行gpg check;

            -y:    自动回答为“yes”;

            -q: 静默模式,不输出显示信息;

            --disablerepo=repoidglob:临时禁用此处指定的repo;

            --enablerepo=repoidglob:临时启用此处指定的repo;

            --noplugins:禁用所有插件;

 

    2.常用COMMAND

        (1)显示仓库列表:repolist

   # yum repolist [all|enabled|disabled]    [所有|可用的|不可用]

wKioL1Z9WKeAo9-8AAEJ7wLMzS8141.jpg

        (2)显示程序包:list

                 # yum list [all | glob_exp1] [glob_exp2] [...]     [所有的|符合glob通配条件的]

                # yum list {available|installed|updates} [glob_exp1] [...]   可用尚未安装的,已经安装的,可升级的

        (3)安装程序包:install

             # yum  install package1 [package2] [...]

                 # yum reinstall package1 [package2] [...]  (重新安装)

wKiom1Z9WJKRYpY4AAEtes0ErR8288.jpg

wKioL1Z9WKjhaytDAAEkLkx3kWs681.jpg

        (4)卸载程序包:此时依赖于此安装包也会被卸载

            yum remove | erase package1 [package2] [...]         

        (5)升、降级安装程序包:update、downgrade

            # yum update [package1] [package2] [...]         升级操作

            # yum downgrade package1 [package2] [...]       降级操作

        (6)检查可用升级:check-uodate

            # yum check-update

        (7)查看程序包简要信息:info

            # yum info [package1]  [package2]  [...]

wKiom1Z9WJPDD8vUAAKYLxKL4wM239.jpg

        (8)查看指定的特性(可以是某文件)是由哪个程序包所提供:provides

            yum  provides | whatprovides feature1 [feature2] [...]

wKioL1Z9WKqx7_z6AADlLnR7s8Y583.jpg

        (9)清理本地缓存:clean

            # yum  clean  <packages | metadata | expire-cache | rpmdb | plugins | all >

包、源数据、过期缓存、rpmdb、插件、所有

包安装完了会自动清除、而元数据(依赖关系等)不会自动,但下次yum安装会自动重新校验wKiom1Z9WJSRWKNMAAE1KBr2CXY931.jpg

        (10)构建缓存:重新yum安装会自动创建缓存数据:makecache

            #  yum makecache

wKioL1Z9WKyQC3VTAAMVCzfzHAg325.jpg

        (11)以指定的关键字搜索程序包名及summary信息:search

              # yum  search  string1  [string2]  [...]   

wKioL1Z9WK_zRu0mAAUb2NlFxAw361.jpg

        (12)查看指定包所依赖的功能(capabilities):

               # yum deplist  package1  [package2] [...]

wKiom1Z9WJqiY1ofAAJt4AVCQUE381.jpg

        (13)查看yum事务历史:history

            history [info|list|packages-list|packages-info|summary|addon-info|redo|undo|rollback|new|sync|stats]

 

    3.COMMAND:安装及升级本地程序包

指定安装本地的*.rpm,但是会根据yum源现有依赖关系,解决此安装可能出现的依赖关系

             # yum  localinstall rpmfile1 [rpmfile2] [...]

             # yum  localupdate rpmfile1 [rpmfile2] [...]

 

    4.COMMAND:包组管理的相关命令:

包组:一堆程序的一个集合,用于一起安装,因为某些程序安装需要依赖包组内容

                  # yum  groupinstall group1 [group2] [...]     安装包组

                  # yum  groupupdate group1 [group2] [...]    升级包组

                  # yum  grouplist [hidden] [groupwildcard] [...]   显示包组列表

                 # yum  groupremove group1 [group2] [...]     移除包组

                 # yum  groupinfo group1 [...]   显示包组信息

 

四、创建yum仓库

    1.使用光盘当作本地yum仓库:

光盘的镜像本身就是一个yum源,自己安装系统时候选择安装工具时就是借助yum自动安装

       (1)挂载光盘至某目录,例如/media/cdrom   # mount -r [-t iso9660]  /dev/cdrom /media/cdrom

       (2)创建配置文件

            [ID]

            name=

            baseurl=file:///… …

            gpgcheck=

    2.yum的repo配置文件中可用的变量:

            $releasever: 当前OS的发行版的主版本号;

            $arch: 平台;

            $basearch:基础平台,同一系列最基本的架构,如32、64;

            $YUM0-$YUM9 可做自定义

wKiom1Z9WJvhLDbrAACrHBBzXtg387.jpg

    3.手动创建yum仓库:

        (1)安装工具:createrepo

wKioL1Z9WLHih-v4AAGpA0WzP1k244.jpg

        (2)下载所需要的所有文件到本地某个路径

wKiom1Z9WJvTly-fAAB1D47cksI937.jpg

        (3)创建关联关系: createrepo - Create repomd (xml-rpm-metadata) repository

命令:createrepo   [options]   <directory>

当完成狗会生成repodata即可

wKioL1Z9WLLww27xAAFasp_-BG0446.jpg

        (4)配置yum源文件,创建*.rope写入信息即可

wKiom1Z9WJ6yTz2-AAJ328oD7W8080.jpg

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
yum是一款软件包管理器,常用于CentOS、RedHat等Linux操作系统中。yum可以帮助用户轻松地安装、更新和删除软件包,同也可以管理系统中的依赖关系。 本教程将介绍如何配置yum源以便于安装软件包。 步骤1:备份现有yum配置文件 在修改yum配置文件前,我们首先要备份现有的yum配置文件,以便出现问题可以恢复到原来的状态。 使用以下命令备份yum配置文件: sudo cp /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup 步骤2:修改yum配置文件 在备份完现有的yum配置文件后,我们可以修改该文件以添加新的yum源。 使用以下命令打开CentOS-Base.repo文件: sudo vi /etc/yum.repos.d/CentOS-Base.repo 该文件中包含了CentOS官方的yum配置信息。我们可以在文件末尾添加新的yum源信息,如下所示: [example-repo] name=Example Repository baseurl=http://example.com/repo/ enabled=1 gpgcheck=0 其中,[example-repo]是该yum源的名称,name是该yum源的描述信息,baseurl是该yum源的地址,enabled表示是否启用该yum源,gpgcheck表示是否检查包的完整性。 注意:在修改yum配置文件,需要使用root用户权限。 步骤3:更新yum缓存 在修改yum配置文件后,我们需要更新yum缓存以便于系统能够正确地获取新的yum源信息。 使用以下命令更新yum缓存: sudo yum makecache 该命令会下载新的yum源信息并更新本地缓存。 步骤4:测试yum源 在更新了yum缓存后,我们可以测试新的yum源是否可用。使用以下命令测试yum源: sudo yum search example-package 其中,example-package是我们要测试的软件包名称。如果yum配置正确,该命令应该能够找到该软件包并列出相关信息。 总结 本教程介绍了如何配置yum源以便于安装软件包。在修改yum配置文件前,我们需要备份现有的yum配置文件;修改yum配置文件后,需要更新yum缓存以便于系统能够正确地获取新的yum源信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值