这里主要讲以CentOS为例,rpm程序包管理器的相关内容:
CentOS的程序包管理器:
1) 程序包的命名规则:
源代码包:
software_name-VERSION.tar.gz
VERSION:major.minor.release
major:主版本号,通常代表重大功能改进的版本分支;
minor:次版本号,通常代表在某个版本的分支中的某个功能发生变化;
release:发行版本号,修复了某些bug或者对某段代码进行了优化;
apache-tomcat-7.0.63.tar.gz
2) rpm程序包命名规则:
源码包:source code
software_name-VERSION.src.rpm
二进制包:
software_name-VERSION-[release].[os].arch.rpm
VERSION:major.minor.release
[release]:rpm封包的发行版本号
[os]:所支持的操作系统版本,el6, el7, suse11, fedora22, ...
arch:硬件平台类型,I386, x64(amd64), ppc, sparc, noarch, ...
puppet-3.8.7-1.el7.noarch.rpm
在制作rpm程序包的时候,通常其制作者会采用分包技术来构建rpm程序包;
根据程序的不同功能,构建多个程序包;
被分包的程序包一般分为两类:
主程序包:
software_name-VERSION-[release].[os].arch.rpm
附属功能包:
software_name-function-VERSION-[release].[os].arch.rpm
一般来讲,主程序包和附属功能包具有相同的版本号,发行版本号,操作系统及兼容平台的标识;
所以,主程序包往往被所有的附属功能包所依赖;不安装主程序包就不能安装附属功能包;
function:devel, utils, libs, tools, manual, client, common, ...
依赖关系:
A --> B --> C D --> A 依赖黑洞
3)rpm程序包管理器:
1.rpm命令行工具;
2.yum工具;
rpm命令行工具:
功能:
1.将编译好的应用程序的各个组成文件打包成一个或多个程序包文件;
2.软件包的安装、卸载、升级、查询、校验及数据库管理功能
rpm程序包中文件的组成清单:
1.程序的文件
2.文件清单
3.软件安装或卸载时所运行的脚本文件,共分为四类:
preinstall:在正式的安装操作开始之前所运行的脚本,%pre
postinstall:在安装完成后所执行的脚本,%post
preuninstall:在正式卸载操作开始之前所运行的脚本,%preun
postuninstall:在卸载完成后所执行的脚本,%postun
rpm数据库(公共):
已经安装好的程序包名称及版本
/var/lib/rpm
4)获取程序包的途径:
1.系统的发行版的光盘
2.官方的文件服务器或者镜像站点:
http://mirrors.aliyun.com
http://mirrors.sohu.com
http://mirrors.163.com
https://mirrors.tuna.tsinghua.edu.cn
http://mirrors.hust.edu.cn
...
3.某个项目的官方站点:
4.第三方组织制作的rpm程序包站点
Fedora EPEL:红帽官方的社区组织,在镜像站点中也包含EPEL镜像;
搜索引擎:
http://pkgs.org
http://rpmfind.net
http://rpm.pbone.net
5.自己制作
建议:获得程序包之后,实施完整性检查
来源合法性:
通过程序提供者的数字签名加密的数据,我们通过其公钥进行解密验证;
程序包完整性:
sha-1校验码
rpm和yum两个工具的使用
rpm命令行工具:
安装、卸载、升级(降级)、查询、文件校验、验证、数据库维护;
rpm命令的通用选项:
-v:显示安装例程的信息,仅仅显示安装软件名
-vv:显示非常详细的操作信息
安装:
rpm {-i|--install} [install-options] PACKAGE_FILE ...
install-options:
-h, --hash:用50个"#"来表示安装进度
--test:并不是真正的安装软件包,仅仅是测试是否在安装时能够正常完成,dry run模式;
--nodeps:忽略因为依赖关系导致的安装错误,不建议使用;
--replacefiles:在安装软件包时,软件包中的文件会直接将原来安装的文件替换;
--replacepkgs:无需卸载软件包而重新安装;
--noscripts:不运行任何脚本
--nopre
--nopost
--nosignature:不考虑软件包的来源是否合法;
--nodigest:不考虑软件包是否完整;
例:~]# rpm -ivh php-mysql-5.3.3-40.el6_6.x86_64.rpm php-pdo-5.3.3-40.el6_6.x86_64.rpm
升级:
rpm {-U|--upgrade} [install-options] PACKAGE_FILE ...
如果选择被安装的程序包事先并未安装,则全新安装;如果已经安装了旧版本,则可以升级安装;
rpm {-F|--freshen} [install-options] PACKAGE_FILE ...
仅仅只能对已经安装的低版本的程序包进行升级安装;
常用选项:与安装相同
--oldpackage:降级安装,用老版本的程序包替换新版本的程序包;
--force:强制升级
注意:
1.强烈建议,不要对内核进行升级操作;Linux可以支持多内核,可以直接安装新版本的内核,在启动界面可以手动更换;
2.升级安装可能会带来文件的变化,因此,系统默认不会直接更改之前安装过的软件的配置文件,新程序包中的配置文件会被重命名,通常会是:FINENAME.rpmnew
卸载:
rpm {-e|--erase} [--allmatches] [--nodeps] [--noscripts] [--notriggers] [--test] PACKAGE_NAME ...
--allmatches:卸载所有匹配指定名称的程序包的各个版本;
--nodeps:卸载时忽略依赖关系,不建议使用;
--test:测试卸载,dry run模式;
查询:
rpm {-q|--query} [select-options] [query-options]
[select-options]
PACKAGE_NAME:直接给出程序包名
-a,--all:查询所有已经安装的程序包名;
~]# rpm -qa | grep mysql
-f,--file FILE:查找指定的文件是由哪个程序包提供的;
-p,--package PACKAGE_FILE:对还没有安装的程序包文件中执行查询操作
--whatprovides CAPABILITY:查询指定的CAPABILITY是由哪个程序包提供的
--whatrequires CAPABILITY:查询指定的CAPABILITY被哪个程序包所依赖
[query-options]
--changelog:查询rpm程序包的changelog;
-c,--configfiles:查询指定程序包中有哪些是配置文件;
-d,--docfiles:查询指定程序包中有哪些文档文件;
-i,--info:查询程序包相关的信息,包括版本号,发行号,大小等;
-l,--list:列表显示程序包安装会生成哪些文件
--provides:列出指定程序包提供的所有的CAPABILITY;
-R,--requires:查询指定程序包的依赖关系;
--scripts:查看程序包所携带的脚本的内容;
具体使用方法:
-qf FILE
-qc|-ql|-qd|-qi PACKAGE_NAME
-qpl|-qpc|-qpd|-qpi 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
认证:
rpm --import /PATH/TO/KEY_FILE
rpm -K /PATH/TO/PACKAGE_FILE
数据库管理:
数据库的初始化和重建
/var/lib/rpm
rpm {--initdb|--rebuilddb}
[--dbpath DIRECTORY]
二:yum前端工具相关
yum:
Yellowdog Updater Modified
Yellowdog是一款发行版linux,使用rpm作为默认的程序包管理工具
URL: yum定位软件仓库及仓库中程序包文件的主要标识方式;
schema://[username@]hostname[:port][/PATH/TO/DOCUMENT][parameters][method]
web站点:
http/https
http://www.163.com
yum是C/S架构的模型,其中服务器也称为软件仓库(yum repository),客户端需要书写URL以指定服务器及程序包路径;
在服务器上,软件仓库其实就是一个目录,在目录中包含了程序包文件及元数据文件;
元数据文件统一的存放于repodata的目录中;也可以说,repodata目录所在的路径即为软件仓库的路径;
createrepo命令:
createrepo - Create repomd (xml-rpm-metadata) repository
createrepo [options]
客户机的使用:
yum程序包
yum的主配置文件:/etc/yum.conf
ini风格的配置信息模式:分段式配置内容
[repositoryid]
statements
一)yum命令的用法:
yum - Yellowdog Updater Modified
yum [options] [command] [package ...]
[options]:
-y, --assumeyes:对于yum执行过程中与用户交互的问题,全部以yes回答
-q, --quiet:安静模式,在某一次yum执行过程中,没有任何信息输出到stdout;
--enablerepo=repoidglob
--disablerepo=repoidglob
在某一次yum执行过程中明确的规定启用或禁用某个repository指向;在使用了这样的选项之后,仓库指向文件中的enabled语句的作用将失效;
--noplugins:
在某一次yum执行过程中,明确指出不使用任何插件;
--nogpgcheck:
在某一次yum执行过程中,明确指出不验证程序包完整性,在仓库指向文件中的gpgcheck=1语句会失效;
[command]
command is one of:
* install package1 [package2] [...]
安装程序包
注意:
1.如果只是给出程序包名称,yum搜索所有仓库,并找到最新版本缓存安装;
2.如果给出程序包的名称及版本,则查找安装指定版本的程序包;
3.如果给出的程序包是完整的程序包名,则只是查找某一个程序包;
4.程序包名称可以使用globbing,(* ? [] [^])
* update [package1] [package2] [...]
* update-to [package1] [package2] [...]
* check-update
* upgrade [package1] [package2] [...]
* upgrade-to [package1] [package2] [...]
* downgrade package1 [package2] [...]
程序包升级或降级:
程序包不同版本之间的更迭;
* remove | erase package1 [package2] [...]
卸载程序包:
* list [...]
yum list LIST OPTIONS
LIST OPTIONS:
all: 显示所有的程序包,包括已经安装的和尚未安装但可用的;
注意:
anaconda:CentOS系统的安装器,在安装操作系统的时候一并安装的程序包;
installed:显示所有已经安装的程序包;
available:显示所有尚未安装但可以安装的程序包;
updates:显示所有可以升级更新的程序包;
* info [...]
yum info LIST OPTIONS
LIST OPTIONS:
all: 显示所有的程序包,包括已经安装的和尚未安装但可用的;
注意:
anaconda:CentOS系统的安装器,在安装操作系统的时候一并安装的程序包;
installed:显示所有已经安装的程序包;
available:显示所有尚未安装但可以安装的程序包;
updates:显示所有可以升级更新的程序包;
name[globbing]
* provides | whatprovides feature1 [feature2] [...]
查看指定的特性是由哪个程序包提供的;
* clean [ packages | metadata | expire-cache | rpmdb | plugins | all ]
清理本地缓存信息
* makecache
构建缓存
* groupinstall group1 [group2] [...]
* groupupdate group1 [group2] [...]
* grouplist [hidden] [groupwildcard] [...]
* groupremove group1 [group2] [...]
* groupinfo group1 [...]
程序包组的管理命令:
* search string1 [string2] [...]
根据关键字进行匹配,默认情况下,搜索程序包名称及汇总信息;
模糊搜索
* shell [filename]
给yum提供一个交互式命令的操作界面
* localinstall rpmfile1 [rpmfile2] [...]
(maintained for legacy reasons only - use install)
* localupdate rpmfile1 [rpmfile2] [...]
(maintained for legacy reasons only - use update)
实现本地程序包安装,即:不依赖于软件仓库,直接对rpm格式包文件进行操作;
这两个命令已经被停用,使用install和update取代;
* reinstall package1 [package2] [...]
重新安装
* deplist package1 [package2] [...]
显示每个程序包所有的依赖关系;
* repolist [all|enabled|disabled]
列表显示yum仓库的元数据信息
在没有给出后面的参数的时候,默认为enabled;
* version [ all | installed | available | group-* | nogroups* | grouplist | groupinfo ]
* history [info|list|packages-list|packages-info|summary|addon-
info|redo|undo|rollback|new|sync|stats]
查看yum事务的历史;
安装、升级、卸载等操作的时候,yum会开启事务;
* load-transaction [txfile]
重新启动已经停止的事务;
* check
* help [command]
待续:... ...