以rpm为后端及以yum为前端工具的程序包管理器在Linux发行版系统centos中的使用

程序包管理:

应用程序的安装,实际上是解压缩并复制程序包中的文件到指定目录的过程;

程序包管理器:

方便终端用户进行程序的安装、卸载、升级、安装信息查询及校验等工作;

不同的Linux的发行版本中,有不同的程序包管理器:

Debian:dpt;Redhat:rpm;S.u.S.E:rpm;Gentoo:借鉴了FREEBSD的portage程序包管理机制,ports方式,emerge工具;ArchLinux:pacman

以CentOS为例,rpm程序包管理器:

rpm程序包的命名规则:

源代码包:

name-Version.tar.gz(纯源代码包)

name-Version.src.rpm(rpm封包的源代码包)

VERSION: Major.Minor.Release

Major:主版本号,通常只有程序进行了重大的功能改进才会修改;

Minor:次版本号,通常在某个主版本中的对某个特定功能进行改进或添加新功能才会修改;

Release:发行版本号,一般修复bug或进行了代码优化都会更改;

如:apache-tomcat-7.0.63.tar.gz

二进制包:

name-Version-[release].[os].arch.rpm

VERSION: Major.Minor.Release

[release]: rpm封包的发行版本号;

[os]: 此程序包所能够支持的操作系统的版本;如:el7(RHEL7,CentOS7), suse11, fedora21, ...

arch: 此程序包所依赖的硬件平台类型:

i386, x86_64(amd64), ppc, sparc, noarch, ...

如:hping3-0.0.20051105-24.el7.x86_64.rpm

在制作rpm程序包时,通常其制作者会根据自己的理解将程序编译后的结果分别放置于不同的rpm包中,用以实现对于该程序的不同需求;将此种封包方式,称为分包技术;一旦程序被分包,则程序包就被分为两类:

主程序包:

name-Version-[release].[os].arch.rpm

子程序包(分支程序包):

name-function-Version-[release].[os].arch.rpm

function:

devel:开发包;

utils:工具包;

libs:共享库包;

manual:离线帮助文档包;

...

程序包的依赖关系:

程序包的安装顺序,被需要的应该先被安装;如果安装包的安装顺序混乱,会导致最后的程序无法使用,导致依赖地狱的出现;

程序包管理的前端工具:

就是为了解决各个程序包之间的依赖关系,阻止依赖地狱出现;

各个发行版中的前端工具:

RHEL/CentOS系统:

yum,Yellow dog Update Modifier

yum在实施程序包安装、升级、卸载等过程中,会开启事务;

事务一般具有四个特性:ACID

所谓事务,即将整个操作过程视为一个不可分割的整体,其中的操作要么全部都执行,要么全部都不执行;

dnf:Fedora22+

Debian/Ubuntu系统:

apt-get:实现安装、卸载、升级、降级等deb包的管理工作;

apt-cache:实现基于关键字进行搜索功能,管理本地缓存及缓存的元数据;

S.u.S.E系统:

zypper

在CentOS系统中,程序包管理器的核心是rpm;

其后端使用rpm命令行工具;

前端使用yum命令行工具或dnf命令行工具;

rpm命令行工具:

功能:

1.将编译好的应用程序的各个文件打包成一个或多个程序包;

2.支持rpm程序包的安装、卸载、升级、降级、查询、校验及程序包信息数据库管理功能;

rpm程序包文件的组成:

1.被封包的程序文件;

2.文件清单;

3.程序在安装或卸载时所需要运行的脚本,共有四种:

preinstall:在正式的安装操作开始之前所需要运行的脚本,标识为"%pre";

postinstall:在安装完成之后所需要运行的脚本,标识为"%post";

preuninstall:在正式的卸载操作开始之前所需要运行的脚本,标识为"%preun";

postuninstall:在卸载完成之后所需要运行的脚本,标识为"%postun";

注:在一个rpm程序包中,并不一定同时有这四类脚本,也可以没有这些脚本;

rpm数据信息的数据库(公共):

目录:/var/lib/rpm

rpm程序包的获取途径:

1.系统的发行版光盘;

2.官方的文件服务器或者镜像站点;

阿里云镜像

网易镜像

搜狐镜像

...

3.某个应用程序项目的官方站点;

4.第三方组织制作的rpm程序包站点:

Fedora EPEL:Extra Package for Enterprise Linux;红帽官方的社区组织,通常来说,在上述的镜像站点中也会包括EPEL镜像;

5.某些专用的搜索引擎:

http://pkgs.org

http://rpmfind.net

http://rpm.pbone.net

6.自己动手制作rpm程序包;

注:除了自己制作的rpm程序包之外,建议在获取程序包后,对其实施完整性校验;

rpm命令行工具:

安装:

-h,--hash:用"#"表示安装进度条;

--force:强制安装进行,无论是否有错误发生;不建议使用;

--test:并非真正安装程序包,仅仅是测试安装过程是否能够正常进行;dry run

--nodeps:忽略因为依赖关系导致的安装错误;不建议使用;

--replacefiles:在安装程序包时,程序包中的文件会直接替换已经存在的文件;若不使用该选项,在安装程序包中的文件之前,先将原有的同名文件改名为filename.rpmsave;

--replacepkgs:无需卸载已安装程序包而重新安装之;

--noscripts:在安装前及安装后均不允许安装相关脚本;

--nopre:

--nopost:

--nosignature:跳过校验程序包来源的合法性;

--nodigest:跳过校验程序包完整性;

--oldpackage:降级安装,指定的安装的程序包的版本低于当前已经安装的程序包的版本;

示例:

安装命令及执行结果为:

升级:

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

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

相比较而言,两个选项有下列特点:

-U:既可以对已经安装的程序包进行升级或降级安装,又可以在未安装该程序包时进行全新安装;可以包括部分-i安装模式的功能;

-F:仅能够对已经安装的程序包进行升级安装;

install-options

-h,--hash:用"#"表示安装进度条;

--force:强制安装进行,无论是否有错误发生;不建议使用;

--test:并非真正安装程序包,仅仅是测试安装过程是否能够正常进行;dry run

--nodeps:忽略因为依赖关系导致的安装错误;不建议使用;

--replacefiles:在安装程序包时,程序包中的文件会直接替换已经存在的文件;若不使用该选项,在安装程序包中的文件之前,先将原有的同名文件改名为filename.rpmsave;

--replacepkgs:无需卸载已安装程序包而重新安装之;

--noscripts:在安装前及安装后均不允许安装相关脚本;

--nopre:

--nopost:

--nosignature:跳过校验程序包来源的合法性;

--nodigest:跳过校验程序包完整性;

--oldpackage:降级安装,指定的安装的程序包的版本低于当前已经安装的程序包的版本;

注意:

1.强烈建议,不要使用此方法对内核进行升级操作;

2.升级安装程序包可能会带来文件的变化,或引入未知的BUG或漏洞,因此,在实施升级操作之前,必须要进行可行性分析;

卸载:

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

注意:卸载程序包时,rpm命令的参数时程序名称而非程序包的名称;

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

--nodeps:卸载时忽略依赖关系;

--test:并非真正的卸载而是测试卸载过程是否能够正常完成;dry run

查询:rpm {-q|--query} [select-options] [query-options]

select-options

PACKAGE_NAME:指定要查询的程序名称,不是程序包名称;

-a,--all:查询所有已经安装的程序包名称;

-f,--file FILE:查询指定的文件是由哪个程序包提供的;

-p,--package PACKAGE_FILE:查看尚未安装的程序包文件中的文件清单;

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

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

query-options

--changelog:查询程序包的历次的版本变更记录;

-c,--configfiles:查询指定的程序包中包含哪些配置文件;

-d,--docfiles:查询指定的程序包中有哪些文件文件;

-i,--info:查询指定程序包的相关属性信息;

-l,--list:列表显示;

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

-R,--requires:列出指定程序包的依赖关系;

--scripts:查询程序包所携带的脚本的内容;

常用的选项组合:

-qa

-qf | -qc | -qd | -ql PACKAGE_NAME

-qpl | -qpc | -qpd | -qpl PACKAGE_FILE

校验:rpm {-V|--verify} [select-options] [verify-options]

校验的状态

S file Size differs

M Mode differs (includes permissions and file type)

5 digest (formerly MD5 sum) differs

D Device major/minor number mismatch

L readLink(2) path mismatch

U User ownership differs

G Group ownership differs

T mTime differs

P caPabilities differ

认证:

rpmkeys --import PUBKEY ...

导入指定的认证密钥的路径;

rpmkeys {-K|--checksig} PACKAGE_FILE ...

检查指定的程序包的数字签名信息;

数据库管理:

rpmdb命令:

/var/lib/rpm

--initdb:初始化数据库

--rebuilddb:从已安装软件包包头重建数据库反向列表

程序包管理的前端工具:

RHEL/CentOS系列发行版Linux中,yum和dnf;

yum命令行工具:

Yellow dog Updater Modifier

软件仓库:Package Repository

在软件仓库中,存放有大量的rpm程序包,将所有的rpm程序包的属性信息提取出来,保存于xml格式的文档之中;

利用URL标记并定位软件仓库的位置,并且可以直接读取和缓存软件仓库中事先创建的xml文档的内容到本地;

URL:统一资源定位符;

schema://[[email protected]]hostname[:port][/PATH/TO/RESOURCE][parameters][flag]

schema:

http

ftp

file

...

yum是C/S架构的模型,服务器端其实就是软件仓库,客户端需要在指定的配置文件中填写正确的URL,以能够通过正确的协议访问到软件仓库中的各程序包;

在服务器上,软件仓库其实就是一个目录,在目录中包含了程序包文件及与这些程序包对应的元数据文件;所有的元数据文件统一放置于名为"repodata"目录中;程序包的元数据通过createrepo命令来构建:

createrepo命令:

createrepo - Create repomd (xml-rpm-metadata) repository

createrepo [options] <directory>

在客户端上,使用配置文件到服务器的URL的指向;

yum的主配置文件:/etc/yum.conf

yum的片段配置文件:/etc/yum.repos.d/*.repo

片段配置文件拥有ini风格的配置模式:即分段式配置内容;

1.使用"[Repositoryid]"唯一标识出软件仓库;

2.其他的配置信息都类似于变量的复制,即key=value;

3.在软件仓库的标记下面的所有的配置信息都针对其上面的仓库生效,直到遇到下一对"[]"为止;

每个片段配置文件中,都可以配置一个或多个仓库的指向;而且,yum程序在查找各个仓库的时候,每一次都可能会查找多个yum仓库,并且从所有的可以使用的仓库中选择所需程序包的最新版本并缓存到本地进行安装、升级等操作;

同一个repoid下的多个仓库被称为镜像,只有一个仓库会被使用;

多个不同repoid的仓库,可以同时被使用;

.repo文件的内容格式:

[repositoryid]

name=Full name of Repository

baseurl=schema1://hostname/PATH

schema2://hostname/PATH

schema3://hostname/PATH

schema4://hostname/PATH

...

enabled={0|1}

gpgcheck={0|1}

gpgkey=schema://hostname/PATH/TO/PUBLIC_KEY

如:gpgkey=file:///mnt/cdrom/RPM-GPG-KEY-CentOS-7

failovermethod={roundrobin|priority}

cost=NUMBER

.repo文件的格式示例:

[myrepo]

name=repository on localhost cdrom

baseurl=

#mirrorlist=

enabled=1

gpgcheck=0

#gpgkey=

yum命令行工具:

常用选项:

-y, --assumeyes:对于yum执行过程中与用户交互的问题,全部以"yes"回答;

-q, --quiet:安静模式,在一次安装事务中,不输出任何信息;

--enablerepo=repoidglob:

即使被指定的repoid是被禁用的,也可以通过该选项将其启用;

--disablerepo=repoidglob:

即使卑职的repoid是被正常启用的,也可以通过该选项将其禁用;

--noplugins:在yum执行过程中,明确指出不使用任何插件;

--nogpgcheck:在yum的执行过程中,明确指出不进行程序包完整性认证;

command:

安装程序包:

* install package1 [package2] [...]

注意:

1.如果启用安装时仅给出程序名称,并没有给出程序版本,平台类型及操作系统类型等信息的话,yum将会搜索所有的处于启用状态的仓库,并找到版本最新的程序包进行安装;

2.如果启用安装时给出的是带有程序版本,平台类型及操作系统类型等信息的程序名称,则在所有的仓库中查找与之完全匹配的程序包进行安装;

3.如果启用安装时给出的是完整的程序包名称,则只查找特定的程序包进行安装;

4.程序包名或程序名可以使用通配符(Globbing), * ? [] [^]

升级和降级安装程序包,让程序包在不同的版本之间更迭:

* update [package1] [package2] [...]

* downgrade package1 [package2] [...]

卸载程序包:

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

查看程序包:

* list [available|installed|all]

查看程序包的相关信息:

* info [...]

清除本地相关缓存信息:

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

手动构建本地缓存:

* makecache [fast]

显示所有可用的仓库的相关信息,如果缓存消失,则先缓存再显示:

* repolist [all|enabled|disabled]

模糊搜索:

* search string1 [string2] [...]

程序包组管理命令:

* groups [...]

group install

group update

group list

group remove

group info

显示指定程序包的所有的依赖关系:

* deplist package1 [package2] [...]

恢复yum的安装事务:

* load-transaction [txfile]

Fedora提供的第三EPEL仓库,到任何一个镜像站点下载epel-release-latest-7.noarch.rpm程序包,在linux本地使用rpm或yum直接安装,即可在/etc/yum.repos.d目录中生成一个epel.repo的配置文件;

yum的repo配置文件中的常用变量:

$basearch:当前计算机所使用的基础平台架构类型:

i686

x86_64(amd64)

ppc

ppc64

$releasever:当前操作系统发行版本的主版本号:

如:CentOS 7.2-1511,其发行版本的主版本号是7;

CentOS 6.9,其发行版本的主版本号是6;

$arch:平台架构类型

$YUM0~$YUM9:yum内置的可以由用户自定义的10个变量;

http://mirrors.sohu.com/fedora-epel/6/x86_64/

http://mirrors.sohu.com/fedora-epel/7/x86_64/

[epel]

name

baseurl=http://mirrors.sohu.com/fedora-epel/$releasever/$basearch/

原文地址:http://blog.51cto.com/chenliangdeeper/2084298

时间: 2024-10-18 06:54:40

以rpm为后端及以yum为前端工具的程序包管理器在Linux发行版系统centos中的使用的相关文章

linux程序包管理之rpm程序包管理器与yum前端工具

这里主要讲以CentOS为例,rpm程序包管理器的相关内容: CentOS的程序包管理器:   1) 程序包的命名规则:        源代码包:            software_name-VERSION.tar.gz            VERSION:major.minor.release                major:主版本号,通常代表重大功能改进的版本分支:                minor:次版本号,通常代表在某个版本的分支中的某个功能发生变化:     

CentOS程序包管理器rpm、yum以及程序包编译安装详解

一.程序包管理器RPM和Yum简介 程序包管理器:将编译好的应用程序的各组成文件打包成一个或几个程序包文件,可以更方便地实现程序包的安装.升级.卸载和查询等管理操作. rpm软件包管理器(RPM Package Manager):rpm包存在依赖关系,依赖关系复杂,安装时间很长,虽然可以忽略依赖关系,但是可能会导致程序包安装后无法正常使用. yum程序包管理器( Yellow dog Updater, Modified):yum是基于RPM包管理,自动解决程序包间的依赖关系.根据配置文件的资源地

RHEL系统程序包管理器【rpm、yum】

程序包管理器 将编译好的文件打包成一个或有限的几个文件,可用于实现便捷的安装.卸载.升级.查询,校验等程序管理. centos常用的程序管理器有rpm和yum rpm: redhat package manager, RPM is Package Manager rpm是由红帽公司开发的软件包管理方式,使用rpm我们可以方便的进行软件的安装.查询.卸载.升级等工作.但是rpm软件包之间的依赖性问题往往会很繁琐,尤其是软件由多个rpm包组成时. RPM包的命名 例如,bash-4.3.2-1.ce

rpm,yum程序包管理器

在早期我们在Linux上安装程序时,都采用的源代码来安装应用程序,这就意味着我们每次都要经过预处理,编译,汇编,链接最后生成可执行的二进制文件:这样的操作太过繁琐,为简化安装步骤,便于广大用户的安装部署程序,程序提供商就在特定的系统上面编译好相关程序的安装文件并进行打包,提供给大家下载,而对这些程序包进行管理的就是程序包管理器: 不同Linux发行版本,就有不同的程序包管理器:在这里列举一些常用的程序包管理器: 在Debian中dpkg工具来管理所有.deb后缀名的包文件:Redhat中就使用最

程序包管理的前端工具yum、程序包管理器编译安装、sed命令

下面介绍的是程序包管理的前端工具yum.程序包管理器编译安装.sed命令. 一.Linux程序包管理:程序包管理的[前端工具] 1.yum软件包仓库简介 CentOS系的管理工具有yum和dnf.yum是一款发行版的Linux,其使用的默认程序包管理工具为rpm. URL是yum定位软件包仓库和仓库中程序文件的主要标识方式,表示如下: 例如:schema://[[email protected]]hostname/PATH/TO/DOCUMENT[paramers][methord] (例子中的

Linux的程序包管理器(上)——rpm详解

在使用Linux操作系统的过程中,我们需要的一些服务(例如Nginx)并没有提供,需要用户自行安装相应的程序包,才能使用相应的服务.本文以CentOS6.6为例,分三小节为读者朋友们尽可能详细的讲解rpm.yum以及程序包的编译安装三种程序包的管理方法. rpm rpm包管理工具是Red Hat公司贡献的一款rpm程序包管理器,在RHEL.CentOS.Fedora.SUSE等主流发行版本中,被广泛使用. rpm包管理工具可用于安装,升级,卸载,重新安装程序:也可以用于查询当前系统上安装了哪些程

yum程序包管理器浅谈

基于rpm安装程序包时,程序包之间的依赖性太过于复杂和麻烦,开发了yum程序包管理器,可以自行的解决程序包之间的依赖关系,并且一次性安装所有的有依赖关系的程序包,无须繁琐的下载依赖性的程序包,相对于rpm来说,rpm为基础包管理,yum是前端工具.而yum需要一个文件服务的服务器,总共有四种文件服务器:ftp服务,http服务,本地文件目录,NFS服务.yum命令工具可以通过配置文件,指向仓库的位置以及相关的各种配置信息:每个yum命令行可以同时指向多个仓库,仓库间可以优先级等相关的配置. 当y

CentOS系统之程序包管理器-RPM

在早期我们使用源代码的方式来安装软件时,都需要先把源程序代码编译成可执行的二进制安装程序,然后进行安装.这就意味着每次安装软件都需要经过预处理-->编译-->汇编-->链接-->生成安装文件--> 安装,这个复杂而艰辛的过程.为简化安装步骤,便于广大用户的安装部署程序,程序提供商就在特定的系统上面编译好相关程序的安装文件并进行打包,提供给大家下载,我们只需要根据自己的系统去下载相应的安装包进行安装即可,其类似 Windows 的安装方式,由程序开发者直接在已知的系统上面编译好

rpm程序包管理器详解

1. 程序包管理器的功能 我们知道,由程序员编写并提供的程序源代码要转换成目标二进制格式才能在计算机上运行起来,但用户要在平台上使用时需要手动编译安装后才能使用,对于普通用户来说有一定难度.因此为了降低普通用户对应用程序的使用难度,程序员可在提供源代码的同时提供已在特定环境下编译好的程序文件,只要用户的平台环境和程序员的平台环境相同,就可以通过解压程序员提供的二进制格式文件即可使用,而无需自己手动编译安装. 一个已编译好的程序由二进制程序.库文件.配置文件和帮助手册等组成,而程序包管理器的功能就