linux yum 软件包管理

简介: linux yum 软件包管理

文章目录

1 yum介绍

2 Yum 特点:

3 yum命令

3.1. 安装

3.2. 更新和升级

3.3. 查找和显示

3.4. 删除程序

3.5. 清除缓存

4 yum源类型

5 yum源使用方式

6 生成repo文件方式

7 制作yum源

7.1 自定义yum源

7.2 用iso搭建yum源

7.3 添加rpm包新添加到yum源

8 利用开源yum源

9 yum配置文件

10.执行报错

1 yum介绍

1832b220aa754cd18c504acc7686a560.png

yum 是Yellow dog Updater, Modified 的简称,是杜克大学为了提高RPM 软件包安装性而开发的一种软件包管理器。

yum 的理念是使用一个中心仓库(repository)管理一部分甚至一个distribution 的应用程序相互关系,

根据计算出来的软件依赖关系进行相关的升级、安装、删除等等操作,减少了Linux 用户一直头痛的dependencies 的问题。

这一点上,yum 和apt 相同。apt 原为debian 的deb 类型软件管理所使用,但是现在也能用到RedHat 门下的rpm 了。

2 Yum 特点:

  • 可以同时配置多个资源库(Repository)
  • 简洁的配置文件(/etc/yum.conf)
  • 自动解决增加或删除rpm包时遇到的倚赖性问题
  • 使用方便
  • 保持与RPM数据库的一致性

3 yum命令

概括了部分常用的命令包括:

#自动搜索最快镜像插件:

yum install yum-fastestmirror

#安装yum图形窗口插件:

yum install yumex

#查看可能批量安装的列表:

yum grouplist

3.1. 安装

yum install  //全部安装
yum install package1 //安装指定的安装包package1
yum groupinsall group1 //安装程序组group1

3.2. 更新和升级

yum update //全部更新
yum update package1 //更新指定程序包package1
yum check-update //检查可更新的程序
yum upgrade package1 //升级指定程序包package1
yum groupupdate group1 //升级程序组group1

3.3. 查找和显示

yum info package1 //显示安装包信息package1
yum list //显示所有已经安装和可以安装的程序包
yum list package1 //显示指定程序包安装情况package1
yum  list python --showduplicates| sort -r
yum groupinfo group1 //显示程序组group1信息
yum search string //根据关键字string查找安装包

3.4. 删除程序

yum remove | erase package1 //删除程序包package1
yum groupremove group1 //删除程序组group1
yum deplist package1 //查看程序package1依赖情况

3.5. 清除缓存

yum clean packages //清除缓存目录下的软件包

yum clean headers //清除缓存目录下的 headers
yum clean oldheaders //清除缓存目录下旧的 headers
yum clean, yum clean all (= yum clean packages; yum clean oldheaders) //清除缓存目录下的软件包及旧的headers

4 yum源类型

本地搭建

开源社区

5 yum源使用方式

ftp
http
file

6 生成repo文件方式

第一种:直接编辑配置文件

$ vim /etc/yum.repos.d/rh7dvd.repo
[rh7dvd]
Name=rh7dvd
Baseurl=http://192.168.4.254/rh7dvd  
Baseurl=ftp://192.168.4.254/rh7dvd  
Baseurl=file///mnt
Enabled=1
Gpgcheck=0

第二种:创建快捷配置文件

$ yum-config-manager --add http://192.168.4.254/rh7dvd ftp://192.168.4.254/rh7dvd  file///mnt
$ echo "gpgcheck=0" > > <yum文件>

第三种:写脚本方式

#!/binbash
rm -rf /etc/yum.repos.d/*
echo"[rhel]
Name=rhel linux
Baseurl=http://xxxxx
Gpgcheck=0
Enabled=1 " > /etc/yum.repos.d/rh7.dvd
$ yum clean all && yum repolist 

7 制作yum源

7.1 自定义yum源

 createrepo /data/(里面包含根据自己需求囊括的软件包)
 #!/binbash
rm -rf /etc/yum.repos.d/*
echo"[rh7dvd]
Name=zzzz
Baseurl=file:///opt/yum
Gpgcheck=0
Enabled=1 " > /etc/yum.repos.d/data.repo
yum clean all && yum repolist 

多台机器公用一个yum源,要在本地搭建httpd

$ yum -y install httpd
$ vim /etc/httpd/conf/httpd.conf
listen 81
# vim  /etc/httpd/conf.d/define.conf
<VirtualHost *:81>
        ServerName  www.XXX-ym.com
        DocumentRoot /opt/yum
</VirtualHost>
# vim  /etc/httpd/conf.d/permission.conf
<Directory /opt/yum>
  Require all granted      
</Directory>
$ systemctl  restart  httpd
$ chcon -R --reference=/var/www  /opt/yum  //调整SELinux属性

7.2 用iso搭建yum源

$ mount -t iso9660 -o,loop /usr/rhel-server-6.5-x86_64-dvd.iso /mnt/cdrom
$ vim /etc/yum.repos.d/iso.repol
name=Red Hat Enterprise Linux - Source
baseurl=file:///mnt/cdrom/
enabled=1
gpgcheck=1
gpgkey=file:///mnt/cdrom/RPM-GPG-KEY-redhat-release
$ yum clean all && yum repolist

7.3 添加rpm包新添加到yum源

1,将所有的rpm包拷贝到一个文件夹中
 2,通过rpm命令手工安装createrepo软件
 3,运行命令createrepo -v /rpm-directory
   如果有分组信息,则在运行命令的时候使用-g参数指定分组文件
   createrepo -g /tmp/*comps.xml /rpm-directory
 4,CentOS/RHEL的分组信息保存在光盘repodata/目录下,文件名以comps.xml结尾的xml文件

8 利用开源yum源

$ wget -O /etc/yum.repos.d/epel.repo http://mirrors.cloud.tencent.com/repo/epel-7.repo
$ cat <<EOF > /etc/yum.repos.d/kubernetes.repo
[kubernetes]
name=Kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64/
enabled=1
gpgcheck=1
repo_gpgcheck=1
gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg  
EOF
$ yum clean all && yum makecache

9 yum配置文件

yum的配置文件的详解:

yum 的配置文件分为两部分:mainrepository

  • main 部分定义了全局配置选项,整个yum 配置文件应该只有一个main。常位于/etc/yum.conf 中。
  • repository 部分定义了每个源/服务器的具体配置,可以有一到多个。常位于/etc/yum.repo.d 目录下的各文件中
[main]
cachedir=/var/cache/yum   //yum 缓存的目录,yum 在此存储下载的rpm 包和数据库,默认设置为/var/cache/yum
keepcache=0             //安装完成后是否保留软件包,0为不保留(默认为0),1为保留
debuglevel=2             //Debug 信息输出等级,范围为0-10,缺省为2
logfile=/var/log/yum.log     //yum 日志文件位置。用户可以到/var/log/yum.log 文件去查询过去所做的更新。
pkgpolicy=newest    //包的策略。一共有两个选项,newest 和last,这个作用是如果你设置了多个repository,而同一软件在不同的repository 中同时存在,yum 应该安装哪一个,如果是newest,则yum 会安装最新的那个版本。如果是last,则yum 会将服务器id 以字母表排序,并选择最后的那个服务器上的软件安装。一般都是选newest。
distroverpkg=redhat-release    //指定一个软件包,yum 会根据这个包判断你的发行版本,默认是redhat-release,也可以是安装的任何针对自己发行版的rpm 包。
tolerant=1          //有1和0两个选项,表示yum 是否容忍命令行发生与软件包有关的错误,比如你要安装1,2,3三个包,而其中3此前已经安装了,如果你设为1,则yum 不会出现错误信息。默认是0。
exactarch=1        //有1和0两个选项,设置为1,则yum 只会安装和系统架构匹配的软件包,例如,yum 不会将i686的软件包安装在适合i386的系统中。默认为1。
retries=6         //网络连接发生错误后的重试次数,如果设为0,则会无限重试。默认值为6.
obsoletes=1          //这是一个update 的参数,具体请参阅yum(8),简单的说就是相当于upgrade,允许更新陈旧的RPM包。
plugins=1          //是否启用插件,默认1为允许,0表示不允许。我们一般会用yum-fastestmirror这个插件。
bugtracker_url=http://bugs.centos.org/set_project.php?project_id=16&ref=http://bugs.centos.org/bug_report_page.php?category=yum
# Note: yum-RHN-plugin doesn't honor this.
metadata_expire=1h
installonly_limit = 5
# PUT YOUR REPOS HERE OR IN separate files named file.repo
# in /etc/yum.repos.d
# 除了上述之外,还有一些可以添加的选项,如:
exclude=selinux*  // 排除某些软件在升级名单之外,可以用通配符,列表中各个项目要用空格隔开,这个对于安装了诸如美化包,中文补丁的朋友特别有用。
gpgcheck=1  // 有1和0两个选择,分别代表是否是否进行gpg(GNU Private Guard) 校验,以确定rpm 包的来源是有效和安全的。这个选项如果设置在[main]部分,则对每个repository 都有效。默认值为0。

10.执行报错

yum 命令死锁

Another app is currently holding the yum lock; waiting for it to exit… 
The other application is: PackageKit 
Memory : 40 M RSS (698 MB VSZ) 
Started: Wed Jul 15 13:59:01 2015 - 06:29 ago 
State : Sleeping, pid: 2305

可以通过执行rm -rf /var/run/yum.pid 来强行解除锁定,然后你的yum就可以运行了。

$ rm -f /var/lib/rpm/__db.00*  //删除rpm数据文件
或者删除
$ rm -f /var/lib/rpm/__db.*
$ rpm --rebuileddb //从新rpm数据文件
$ yum clean all  && yum update

✈推荐阅读:

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
2月前
|
算法 安全 Ubuntu
Linux下的软件包管理器有哪些
Linux下的软件包管理器有哪些
139 5
|
1月前
|
缓存 应用服务中间件 Linux
yum 命令下载软件包到本地
在 Linux 系统中,使用 `yum` 命令可以下载软件包但不安装。通过 `yum` 的下载缓存功能,可以快速获取所需软件包。常用命令包括:`yum list available` 列出可安装的软件包,`yum download nginx` 下载特定软件包,`yum download nginx-1.18.0` 下载特定版本,`yum download -resolve nginx` 下载软件包及其依赖,`yum download nginx -d /path/to/download/directory` 指定下载目录
208 11
|
2月前
|
Linux 开发工具 数据安全/隐私保护
linux异常一:feng 不在 sudoers 文件中,此事将被报告。yum提示Another app is currently holding the yum lock; waiting for
这篇文章介绍了在CentOS 7系统中安装Docker时遇到的两个常见问题及其解决方法:用户不在sudoers文件中导致权限不足,以及yum被锁定的问题。
46 2
linux异常一:feng 不在 sudoers 文件中,此事将被报告。yum提示Another app is currently holding the yum lock; waiting for
|
1月前
|
缓存 应用服务中间件 Linux
yum 命令下载软件包到本地
在 Linux 系统中,使用 yum 命令可以下载软件包但不安装。通过 yum 的下载缓存功能,可以快速获取软件包。常用命令包括:`yum list available` 列出可安装的软件包,`yum download nginx` 下载特定软件包,`yum download nginx-1.18.0` 下载特定版本,`yum download -resolve nginx` 下载软件包及其依赖,`yum download nginx -d /path/to/download/directory` 指定下载目录
136 1
|
1月前
|
存储 缓存 Linux
【Linux】另一种基于rpm安装yum的方式
通过本文的方法,您可以在离线环境中使用RPM包安装YUM并进行必要的配置。这种方法适用于无法直接访问互联网的服务器或需要严格控制软件源的环境。通过配置本地YUM仓库,确保了软件包的安装和更新可以顺利进行。希望本文能够为您在特定环境中部署YUM提供实用的指导。
164 0
|
2月前
|
缓存 前端开发 Linux
Linux yum 命令
10月更文挑战第1天
58 2
|
3月前
|
关系型数据库 MySQL Linux
Linux 安装 mysql【使用yum源进行安装】
这篇文章介绍了在Linux系统中使用yum源安装MySQL数据库的步骤,包括配置yum源、安装MySQL服务、启动服务以及修改root用户的默认密码。
Linux 安装 mysql【使用yum源进行安装】
|
2月前
|
Unix Linux Go
Linux 使用Yum安装Go和配置环境
Linux 使用Yum安装Go和配置环境
|
3月前
|
Linux 开发工具 存储
Linux软件包管理
Linux软件包管理
52 0
|
4月前
|
Ubuntu Linux 数据库
在Linux中,如何进行软件包升级?
在Linux中,如何进行软件包升级?
下一篇
DataWorks