前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Linux yum 命令

Linux yum 命令

作者头像
用户1679793
发布2019-10-24 22:40:47
9.7K0
发布2019-10-24 22:40:47
举报

yum (全称Yellow dog Update)命令是 RedHat 和 Fedora 以及 SUSE 中基于 rpm 软件包管理器。全称 Yellowdog Updater,Modified。起初是由yellow dog 这一发行版的开发者Terra Soft 研发,用python 写成,那时还叫做yup(yellow dog updater),后经杜克大学的Linux@Duke 开发团队进行改进,遂有此名。yum 可以交互和自动化地更新与管理 rpm 软件包,能够从指定的 yum 存储仓库自动下载 rpm 包并安装,可以自动处理依赖性关系。提供查找、安装、删除、更新等操作命令。

1 检查和更新软件包

可以列出软件包、整体更新软件包、个体更新软件包

1.2 检查系统上已安装的软件包是否有可用的更新

代码语言:javascript
复制
yum check-update

例如:yum check-update 部分输出如下:

1.2.1 更新软件包

可以单个软件包、多个、全部更新,如果更新的包的任何依赖项本身有更新可用,那么依赖的软件包也会被更新。

更新单个软件包

代码语言:javascript
复制
yum update package_name

类似的更新包组

代码语言:javascript
复制
yum group update group_name

更新所有包及依赖项。

代码语言:javascript
复制
yum update

2 查找包及获取相关信息

Yum使您能够对软件包执行完整的操作集,包括搜索软件包、查看有关软件包的信息、安装和删除。

2.1 根据包名查找

代码语言:javascript
复制
yum search package_name1 package_name2 ...

2.2 列出所有已安装和可用的包的信息

代码语言:javascript
复制
yum list all

2.3 列出所有已安装的包

代码语言:javascript
复制
yum list installed
# 或列出指定名字的包
yum list installed *vim*

2.4 列出所有可安装的已启用存储库中的所有包

代码语言:javascript
复制
yum list available

3 列出yum仓库信息

列出系统上每个启用的存储库的存储库ID、名称和包的数量

代码语言:javascript
复制
yum repolist

列出更详细的存储库信息,存储库大小,存储库链接地址,存储库配置文件等

代码语言:javascript
复制
yum repolist -v
yum repoinfo

列出禁用和启用的存储库:yum repolist all,也可以针对启用状态和禁止状态进行过滤:yum repolist disabled、yum repolist enabled

4 显示软件包信息

包括显示软件包的大小、官网URL、描述、来源存储库、版本号。类似 rpm -q --info package_name 命令。

代码语言:javascript
复制
yum info package_name

显示软件包的其它信息

这个命令提供了额外的信息,包括包的校验和(算法用于生产,如sha - 256),在命令行上给出的命令被调用安装包(如果有的话),reason=user表明它是由用户安装,reason=dep意味着它被引入作为一个依赖项

代码语言:javascript
复制
yumdb info package_name

5 yum 包组

包组是服务于一个公共目的的包的集合,例如系统工具或声音和视频。安装包组将获取一组相关的包,从而大大节省了时间。yum组命令是一个顶级命令,它涵盖了在yum中作用于包组的所有操作。

smmary参数用于查看已安装组、可用组、可用环境组以及已安装和可用语言组的数量:

代码语言:javascript
复制
yum groups summary

列出存储库中所有包组

代码语言:javascript
复制
yum groups list

列出特定组中包含的包信息

等于yum groupinfo group_name

代码语言:javascript
复制
yum group info group_name

每个包组都有一个名称和一个组ID (groupid)。列出所有包组的名称及其组id(显示在括号中)

安装包组,可以通过将包组的完整组名(不包含groupid部分)传递给组安装命令来安装包组。

代码语言:javascript
复制
yum group install "group name"

也可以通过groupid进行安装

代码语言:javascript
复制
yum group install groupid

移除包组

代码语言:javascript
复制
yum group remove "group name"

6 yum history

yum history命令查看yum事务的时间轴、发生的日期和时间、受影响的包的数量、这些事务是成功还是中止,以及事务之间是否更改了RPM数据库。此外,此命令可用于撤消或重做某些事务。所有的历史数据都存储在/var/lib/yum/history/目录的历史数据库中。

查看yum的历史操作记录

代码语言:javascript
复制
yum history list all

也可以根据ID仅显示指定范围

代码语言:javascript
复制
yum history list start_id..end_id

查看某个id的详细信息,包括执行的命令、安装更新的软件包、执行时间等。

代码语言:javascript
复制
yum history info id

yum history重复或取消某个历史操作

重复执行指定的id,该命令将重复执行该id的命令

代码语言:javascript
复制
yum history redo id

取消某个历史id的,如果该id是执行安装软件包的命令,那么将remove掉该软件包

代码语言:javascript
复制
yum history undo id

将事务历史存储在单个SQLite数据库文件中。启动新的事务历史记录文件

代码语言:javascript
复制
yum history new

7 yum的配置文件

yum 的配置文件分为两部分:main 和 repository

  • main 部分定义了全局配置选项,整个yum 配置文件应该只有一个main。常位于/etc/yum.conf 中。
  • repository 部分定义了每个源/服务器的具体配置,可以有一到多个。常位于/etc/yum.repo.d 目录下的各文件中。

/etc/yum.conf配置参数说明

  • assumeyes=value

提示确认操作,默认是0。如果是1,则当yum install package_name等命令时则不会提示确认操作。这个过程不用输入“y”确认安装。

  • cachedir=directory

yum存储其缓存和数据库文件的目录。

  • debuglevel=value

yum生成的调试输出的详细信息。value是1到10之间的整数。设置更高的调试级别值将导致yum显示更详细的调试输出。debuglevel=2是默认值,而debuglevel=0禁用调试输出。

  • exactarch=value

默认1表示开启,在更新包时考虑准确的体系结构。通过此设置,yum不会安装用于32位体系结构的包来更新已经安装在系统上的具有64位体系结构的包。

  • gpgcheck=value

默认gpgcheck=1,在所有存储库中的所有包上启用GPG签名检查,包括本地包安装。启用gpgcheck后,将检查所有包的签名。在对应的.repo文件中为单个存储库设置gpgcheck=value将覆盖默认值(如果它位于/etc/yum. conf中)。

  • keepcache=value

默认0,安装成功后,不要保留标题和包的缓存。1:成功安装后保留缓存。

  • logfile=value

默认/var/log/yum.log,日志输出保存位置。记录软件包更新、安装、移除等。

  • plugins=value

plugins=1全局启用所有yum插件。仍然可以通过在插件的配置文件中设置enabled=0来禁用特定的yum插件。

repository配置说明

在[repository]部分中,repository是惟一的存储库ID,如my_personal_repo(不允许使用空格),允许您定义单独的yum存储库。位置/etc/yum.repos.d/*

repo配置参数实例

代码语言:javascript
复制
[root@web ~]# cat /etc/yum.repos.d/CentOS-Base.repo 
[base]
name=CentOS-$releasever
enabled=1
failovermethod=priority
baseurl=http://mirrors.cloud.aliyuncs.com/centos/$releasever/os/$basearch/
gpgcheck=1
gpgkey=http://mirrors.cloud.aliyuncs.com/centos/RPM-GPG-KEY-CentOS-7

[updates]
name=CentOS-$releasever
enabled=1
failovermethod=priority
baseurl=http://mirrors.cloud.aliyuncs.com/centos/$releasever/updates/$basearch/
gpgcheck=1
gpgkey=http://mirrors.cloud.aliyuncs.com/centos/RPM-GPG-KEY-CentOS-7

[extras]
name=CentOS-$releasever
enabled=1
failovermethod=priority
baseurl=http://mirrors.cloud.aliyuncs.com/centos/$releasever/extras/$basearch/
gpgcheck=1

serverid 是用于区别各个不同的repository,必须有一个独一无二的名称; name 是对repository 的描述,支持像$releasever $basearch这样的变量; baseurl 是服务器设置中最重要的部分,只有设置正确,才能从上面获取软件。它的格式是:

  • 如果存储库通过HTTP可用,请使用:http://path/to/repo
  • 如果存储库在FTP上可用,请使用:ftp://path/to/repo
  • 如果存储库是机器本地的,那么使用:file:///path/to/local/repo
  • 如果特定的在线存储库需要基本的HTTP身份验证,则可以通过将用户名和密码前缀为URL来指定用户名和密码:http://user:password@www.example.com/repo/
  • 通常这个URL是一个HTTP链接:baseurl=http://path/to/repo/releases/$releasever/server/$basearch/os/

8 yum-config-manager添加yum仓库

yum-config-manager命令需要安装yum-utils软件包。

添加第三方yum源仓库

代码语言:javascript
复制
[root@abvi17j5 ~]# yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
已加载插件:fastestmirror
adding repo from: http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
grabbing file http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo to /etc/yum.repos.d/docker-ce.repo
repo saved to /etc/yum.repos.d/docker-ce.repo

仅下载不安装:

yum install --downloadonly --downloaddir=/tmp lrzsz

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-10-24 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1 检查和更新软件包
    • 1.2 检查系统上已安装的软件包是否有可用的更新
      • 1.2.1 更新软件包
  • 2 查找包及获取相关信息
    • 2.1 根据包名查找
      • 2.2 列出所有已安装和可用的包的信息
        • 2.3 列出所有已安装的包
          • 2.4 列出所有可安装的已启用存储库中的所有包
          • 3 列出yum仓库信息
          • 4 显示软件包信息
          • 5 yum 包组
          • 6 yum history
          • 7 yum的配置文件
          相关产品与服务
          对象存储
          对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档