YUM配置安装使用

一、YUM简介

    1. YUM: Yellowdog Update Modifier

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

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

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

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

    3.设计缺陷:

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

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

    2.yum repository: yum repoyum仓库

存储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)、降安装程序包:updatedowngrade

            # 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:基础平台,同一系列最基本的架构,如3264

            $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

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/96863

(0)
隔壁小翔隔壁小翔
上一篇 2018-04-22
下一篇 2018-04-22

相关推荐

  • 简述rpm与yum命令的常见选项,并举例

    rpm命令:     rpm [option] [package_file]             安装:-i  –install [install-option] page_file                     rpm -ivh package_file                             -v:verbose…

    Linux笔记 2018-06-07
  • 课后实操

    1.怎么查看设备UUID? [root@centos6 ~]#blkid /dev/sda1: UUID=”625dc9a7-69cd-478f-892c-0d4a664b72fe” TYPE=”ext4″ /dev/sda2: UUID=”070d3bc7-773e-4d27-bf0e-81221…

    Linux笔记 2018-04-23
  • FTP服务介绍及相关实验

    FTP是File Transfer Protocol(文件传输协议)的英文简称,而中文简称为“文传协议”。用于Internet上的控制文件的双向传输。FTP协议是早期的三个应用级协议之一。

    2018-06-26
  • 正则表达式

    基本正则表达式元字符

    Linux笔记 2018-06-22
  • LAMP架构实现

    LAMP是一组Web应用软件的组合,Linux+Apache+Mysql/MariaDB+Perl/PHP/Python一组常用来搭建动态网站或者服务器的开源软件,所有组成产品均是开源软件,本身都是各自独立的程序,但是因为常被放在一起使用,拥有了越来越高的兼容度,共同组成了一个强大的Web应用程序平台。

    2018-06-23
  • 第一周博客(4)

    基础命令

    Linux笔记 2018-05-12