Linux程序包管理.md

rpm

简介

RPM包管理员(简称RPM,全称为The RPM Package Manager)是在Linux下广泛使用的软件包管理器。RPM此名词可能是指.rpm的文件格式的软件包,也可能是指其本身的软件包管理器(RPM Package Manager)。最早由Red Hat研制,现在也由开源社区开发。RPM通常随附于Linux发行版,但也有单独将RPM作为应用软件发行的发行版(例如Gentoo)。RPM仅适用于安装用RPM来打包的软件,目前是GNU/Linux下软件包资源最丰富的软件包类型之一。
RPM包里面都包含什么?里面包含可执行的二进制程序,这个程序和Windows的软件包中的.exe文件类似是可执行的;RPM包中还包括程序运行时所需要的文件,这也和Windows的软件包类似,Windows的程序的运行,除了.exe文件以外,也有其它的文件;
一个RPM 包中的应用程序,有时除了自身所带的附加文件保证其正常以外,还需要其它特定版本文件,这就是软件包的依赖关系;依赖关系并不是Linux特有的, Windows操作系统中也是同样存在的;比如我们在Windows系统中运行3D游戏,在安装的时候,他可能会提示,要安装Direct 9 ;Linux和Windows原理是差不多的;
RPM软件包分为二进制包(Binary)、源代码包(Source)和Delta包三种。二进制包可以直接安装在计算机中,而源代码包将会由RPM自动编译、安装。源代码包经常以src.rpm作为后缀名。

软件安装流程图

Linux程序包管理.md

Linux程序包管理.md
 

安装

语法

rpm {-i|--install} [install-options] PACKAGE_FILE ...

选项

  • -i<套件档>或--install<套件档>:安装指定的套件档;

  • -v:显示指令执行过程;

  • -vv:详细显示指令执行过程,便于排错。

  • -h:hash marks输出进度条;每个#表示2%的进度;

  • --test:测试安装,检查并报告依赖关系及冲突消息等;

  • --nodeps 忽略软件包的依赖关系强行安装

  • --replacepkge 无论软件包是否已被安装,都重新安装软件包

  • --nosignature:不检查包签名信息,不检查来源合法性;

  • --nodigest:不检查包完整性信息;

升级

语法

rpm {-U|--upgrade} [install-options] PACKAGE_FILE ...
rpm {-F|--freshen} [install-options] PACKAGE_FILE ...

选项

  • -U<套件档>或--upgrade<套件档>:升级或安装指定的套件档;

  • -F:升级指定的套件档;

  • --oldpackage:降级;

  • --force:强制升级;

卸载

语法

rpm {-e|--erase} [--allmatches] [--nodeps] [--noscripts] [--test] PACKAGE_NAME ...

选项

  • -e<套件档>或--erase<套件档>:删除指定的套件;

  • --allmatches:卸载所有匹配指定名称的程序包的各版本;

  • --nodeps:忽略依赖关系

  • --test:测试卸载,dry run模式

查询

语法

rpm {-q|--query} [select-options] [query-options]

选项

select-options

  • PACKAGE_NAME:查询指定的程序包是否已经安装,及其版本;

  • -a, --all:查询所有已经安装过的包;

  • -f FILE:查询指定的文件由哪个程序包安装生成;

  • -p, --package PACKAGE_FILE:用于实现对未安装的程序包执行查询操作;

  • --whatprovides CAPABILITY:查询指定的CAPABILITY由哪个程序包提供;

  • --whatrequires CAPABILITY:查询指定的CAPABILITY被哪个包所依赖;

query-options

  • --changelog:查询rpm包的changlog;

  • -l, --list:程序安装生成的所有文件列表;

  • -i, --info:程序包相关的信息,版本号、大小、所属的包组,等;

  • -c, --configfiles:查询指定的程序包提供的配置文件;

  • -d, --docfiles:查询指定的程序包提供的文档;

  • --provides:列出指定的程序包提供的所有的CAPABILITY;

  • -R, --requires:查询指定的程序包的依赖关系;

  • --scripts:查看程序包自带的脚本片断;

其他

校验

rpm {-V|--verify} [select-options] [verify-options]

在CentOS 的iso镜像中,有个RPM-GPG-KEY-CentOS-7的文件,这个文件就是光盘的镜像中rpm的校验信息。如果在安装是没有在系统中导入此文件则会报出警告,所以需要通过rpm --import RPM-GPG-KEY-CentOS-7导入,而导入后则会在系统的/etc/pki/rpm-gpg/路径下存放该文件。我们在使用第三方的yum仓库时一般都是需要导入由yum仓库提供的此类文件。

数据库重建

rpm {--initdb|--rebuilddb} [--dbpath DIRECTORY] [--root DIRECTORY]

选项说明:

  • --initdb:初始化数据库,当前无任何数据库可实始化创建一个新的;当前有时不执行任何操作;

  • --rebuilddb:重新构建,通过读取当前系统上所有已经安装过的程序包进行重新创建;

如果我们的rpm包的查询出现了问题就需要注意是否是rpm的数据库出现文件,而实际中除非是特殊情况一般是不会动此数据的。数据库的路径/var/lib/rpm/

yum

简介

yum,是Yellow dog Updater, Modified 的简称,是杜克大学为了提高RPM 软件包安装性而开发的一种软件包管理器。起初是由yellow dog 这一发行版的开发者Terra Soft 研发,用python 写成,那时还叫做yup(yellow dog updater),后经杜克大学的Linux@Duke 开发团队进行改进,遂有此名。yum 的宗旨是自动化地升级,安装/移除rpm 包,收集rpm 包的相关信息,检查依赖性并自动提示用户解决。yum 的关键之处是要有可靠的repository,顾名思义,这是软件的仓库,它可以是http 或ftp 站点,也可以是本地软件池,但必须包含rpm 的header,header 包括了rpm 包的各种信息,包括描述,功能,提供的文件,依赖性等。正是收集了这些header 并加以分析,才能自动化地完成余下的任务。
yum 的理念是使用一个中心仓库(repository)管理一部分甚至一个distribution 的应用程序相互关系,根据计算出来的软件依赖关系进行相关的升级、安装、删除等等操作,减少了Linux 用户一直头痛的dependencies 的问题。这一点上,yum 和apt 相同。apt 原为debian 的deb 类型软件管理所使用,但是现在也能用到RedHat 门下的rpm 了。
yum 主要功能是更方便的添加/删除/更新RPM 包,自动解决包的倚赖性问题,便于管理大量系统的更新问题。
yum 可以同时配置多个资源库(Repository),简洁的配置文件(/etc/yum.conf),自动解决增加或删除rpm 包时遇到的依赖性问题,保持与RPM 数据库的一致性。

构成一个完整的 yum 服务,需要以下部分:

  • yum 服务器上的服务仓库(存储 rpm 文件和索引文件)

  • 提供 rpm 和索引下载的网络服务(http 或者 ftp)

  • 客户端的 yum 命令行工具

  • 客户端仓库配置信息和插件扩展模块

语法

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

选项

  • -h:显示帮助信息;

  • -y:对所有的提问都回答“yes”;

  • -c:指定配置文件;

  • -q:安静模式;

  • -v:详细模式;

  • -d:设置调试等级(0-10);

  • -e:设置错误等级(0-10);

  • -R:设置yum处理一个命令的最大等待时间;

  • -C:完全从缓存中运行,而不去下载或者更新任何头文件。

  • --nogpgcheck:禁止进行gpg check;

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

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

  • --noplugins:禁用所有插件;

使用说明

显示仓库列表

repolist [all|enabled|disabled]

显示程序包

 list [all | glob_exp1] [glob_exp2] [...]
list {available|installed|updates} [glob_exp1] [...]

安装程序包

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

升级程序包

update [package1] [package2] [...]
downgrade package1 [package2] [...] (降级)

检查可用升级

check-update

卸载程序包

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

查看程序包information

info [...]

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

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

清理本地缓存

clean [ packages | metadata | expire-cache | rpmdb | plugins | all ]

构建缓存

makecache

搜索

search string1 [string2] [...]

查看指定包所依赖的capabilities

deplist package1 [package2] [...]

查看yum事务历史

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

配置文件

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

  • main 部分定义了全局配置选项,整个yum 配置文件应该只有一个main。常位于/etc/yum.conf 中。

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

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

  • $releasever:当前 OS 发行版的主版本号,如对 CentOS 6.6 系统,这个值为 6。

  • $arch:当前系统的平台,如 i386, x86_64 等。

  • $basearch:基础平台,如 x86_64 和 amd64 平台的基础平台同为 x86_64。

说明

# cat /etc/yum.conf
[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。

repo文件说明

repo文件是redhat系中yum源(软件仓库)的配置文件,通常一个repo文件定义了一个或者多个软件仓库的细节内容,例如我们将从哪里下载需要安装或者升级的软件包,repo文件中的设置内容将被yum读取和应用!
下面详细解释此配置的各项参数:

  • [fedora] #方括号里面的是软件源的名称,将被yum取得并识别

  • name=Fedora $releasever - $basearch #这里也定义了软件 仓库的名称,通常是为了方便阅读配置文件,一般没什么作用,$releasever变量定义了发行版本,通常是8,9,10等数字,$basearch变 量定义了系统的架构,可以是i386、x86_64、ppc等值,这两个变量根据当前系统的版本架构不同而有不同的取值,这可以方便yum升级的时候选择 适合当前系统的软件包,以下同……

  • failovermethod=priority #failovermethod 有两个值可以选择,priority是默认值,表示从列出的baseurl中顺序选择镜像服务器地址,roundrobin表示在列出的服务器中随机选择

  • exclude=compiz* compiz fusion-icon* #exclude这个选项是后来我自己加上去的,用来禁止这个软件仓库中的某些软件包的安装和更新,可以使用通配符,并以空格分隔,可以视情况需要自行添加

  • #baseurl=http://download.fedoraproject.org/pub/fedora/linux/releases/$releasever/Everything/$basearch/os/ #上面的一行baseurl第一个字符是'#'表示该行已经被注释,将不会被读取,这一行的意思是指定一个baseurl(源的镜像服务器地址)

  • #mirrorlist=http://mirrors.fedoraproject.org/mirrorlist?repo=fedora-$releasever&arch=$basearch #上面的这一行是指定一个镜像服务器的地址列表,通常是开启的,本例中加了注释符号禁用了,我们可以试试,将$releasever和$basearch替换成自己对应的版本和架构,例如10和i386,在浏览器中打开,我们就能看到一长串镜可用的镜像服务器地址列表。

  • enabled=1 #这个选项表示这个repo中定义的源是启用的,0为禁用

  • gpgcheck=1 #这个选项表示这个repo中下载的rpm将进行gpg的校验,已确定rpm包的来源是有效和安全的

  • gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-fedora-$basearch #定义用于校验的gpg密钥

yum源构建

阿里云yum 源构建

  1. 备份

mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup
  1. 下载新的CentOS-Base.repo 到/etc/yum.repos.d/

  • CentOS 5

wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-5.repo
  • CentOS 6

wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-6.repo
  • CentOS 7

wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo

3.之后运行yum makecache生成缓存

本地yum 源配置

  1. 挂载光盘

mount /dev/cdrom /media/
echo "/dev/cdrom /media iso9660 defaults 0 0" >> /etc/fstab 实现开机挂载

2.建立yum仓库

vim /etc/yum.repos.d/iso.repo (iso是随便取得名字,但是一定要以repo结尾)
[Centos]
name=CentOS
baseurl=file:///media/
gpgcheck=1
enabled=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6
然后保存退出
(如果是redhat5.x的系统这里写成file:///media/Server/,是redhat6.x的系统file:///media/Packages/)

3.运行yum clean all清楚原先系统的缓存,之后运行yum makecache生成缓存

插件

yum 还能够支持插件的安装,能够扩展 yum 的功能,这里列举 yum-downloadonly 插件,这个插件的功能是使用 yum 下载一个 rpm 包到某个目录中而不安装它。
下载插件:
yum install yum-downloadonly
使用 --downloadonly 选项来下载 rpm 包而不安装:

yum install --downloadonly --downloaddir=<directory> <package>

举例

# yum install --downloadonly --downloaddir=/opt gcc
# ls /opt/
cpp-4.8.5-11.el7.x86_64.rpm glibc-common-2.17-157.el7_3.1.x86_64.rpm kernel-headers-3.10.0-514.2.2.el7.x86_64.rpm libmpc-1.0.1-3.el7.x86_64.rpm
gcc-4.8.5-11.el7.x86_64.rpm glibc-devel-2.17-157.el7_3.1.x86_64.rpm libgcc-4.8.5-11.el7.x86_64.rpm rh
glibc-2.17-157.el7_3.1.x86_64.rpm glibc-headers-2.17-157.el7_3.1.x86_64.rpm libgomp-4.8.5-11.el7.x86_64.rpm
上一篇:Create AI Guard Class


下一篇:解决在圆角手机(如小米8)上自定义Dialog无法全屏的问题