CentOS系统程序包管理之---rpm、yum和编译
目前创新互联公司已为1000+的企业提供了网站建设、域名、虚拟空间、网站托管、服务器托管、企业网站设计、桦甸网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。
一、程序包管理器
1、软件的运行
2、程序包管理
将编译好的文件打包成一个或有限的几个文件,可用于实现便捷的安装、卸载、升级、查询,校验等程序管理。 centos常用的程序管理器有rpm和yum
二、程序包管理器之RPM
1、rpm是什么
RPM 是RPM Package Manager(RPM软件包管理器)的缩写,这一文件格式名称虽然打上了RedHat的标志,但是其原始设计理念是开放式的。RPM包管理器(RPM)是一个强大的命令行驱动的包管理系统能够安装、卸载、验证、查询和更新计算机软件包。每个软件包包括存档的文件连同包和它的版本信息,描述等。还有一个库API,允许高级开发人员来管理
2、程序的组成部分
程序的组成部分:
编译之前:源代码
编译文件:
二进制程序
库文件
配置文件
帮助文件(手册、文档)
二进制程序:/bin, /sbin, /usr/bin, /usr/sbin, /usr/local/bin, /usr/local/sbin, /opt/bin, /opt/sbin
库文件:/lib, /lib64, /usr/lib, /usr/lib64, /usr/local/lib, /usr/local/lib64
配置文件:/etc, /etc/DIR, /usr/local/{etc,conf}
帮助文件:/usr/share/man, /usr/share/doc, /usr/local/share/man
注意:有些特殊的应用程序可能会将可执行文件放置在libexec目录;
3、rpm包命名格式:
4、分包机制
想象一种场景:testapp有30种功能,其中有10种常用,有6次常用,余下的14种极少用;所以rpm包制作者会把一个程序的每个功能制作成一个rpm包,他们都依赖主包。
例如:
核心包,主包:命名与原项目名称一致;
bash-4.3.2-2.centos6.x86_64.rpm
子包(支包):命令为源项目名称后附加分支包中的文件提供的功能组成;
bash-devel-4.3.2-2.centos6.x86_64.rpm
程序包的获取路径:
1、系统的发行光盘镜像或官方站点(或站点镜像服务器)
挂载光盘:
mount -r /dev/cdrom /media/cdrom
官方站点,镜像:
mirrors.sohu.com
mirrors.163.com
mirrors.aliyun.com
2、程序包的官方站点
3、第三方组织:epel
4、搜索引擎
http://rpmfind.net
http://rpm.pbone.net
http://pkgs.org
建议:安装之前要验正的其合法性
来源合法
包的完整性
三、rpm的应用
3.1 安装
rpm {-i|--install} [install-options] PACKAGE_FILE ...
-i 安装
-v 显示详细信息,可叠加使用查看更加详细信息,如-vv,-vvv
-h 显示进度,用50个#来作为进度条
我们一般组合使用-ivh来安装rpm包
--nodeps 取消依赖关系
--replacepkgs 重新安装
--test 测试安装,而不是真正安装
举例:[root@localhost ~]# rpm -ivh package.rpm
3.2升级
rpm {-U|--upgrade} [install-options] PACKAGE_FILE ...
如果有较旧的版本程序包,则升级安装;若没有,则直接安装
rpm {-F|--freshen} [install-options] PACKAGE_FILE ...
如果有较旧的版本程序包,则升级安装;若没有,则终止
我们一般组合使用-Uvh、-Fvh来安装rpm包
[install-options]
--oldpackage 降级安装
--force 忽略冲突,强制执行
注意:
不要对内核包执行升级操作;linux支持多版本内核并存,因此,对新版本内核可直接安装;
如果原程序包的配置文件安装后曾被改动,升级时,新版本的文件并不会直接覆盖老版本的文件,而是把新版本的文件重命(加后缀.rpmnew)名后保留;
举例: [root@localhost ~]# rpm -Uvh package.rpm
3.3、卸载
rpm {-e|--erase} [--allmatches] [--nodeps] [--noscripts] [--notriggers] [--test] PACKAGE_NAME ...
--nodeps 忽略依赖关系
--test 卸载测试
举例 : [root@localhost ~]# rpm -ev package123
3.4、卸载查询
rpm {-q|--query} [select-options] [query-options]
[select-options]
1、查询该包是否安装
rpm -q PACKAGE_NAME...
2、查询已安装的所有包
rpm -qa
3、查询某文件是由哪个包安装生成
rpm -qf /path/to/somefile
4、查询尚未安装包的相关信息
rpm -qp PACKAGE_FILE
[query-options]
1、查询某包的简要说明信息
rpm -qi PACKAGE_NAME
2、查询某包安装后生成的所有文件列表
rpm -ql PACKAGE_NAME
3、查询某包安装后生成的所有配置文件列表
rpm -qc PACKAGE_NAME
4、查询某包安装后生成的所有帮助文件列表
rpm -qd PACKAGE_NAME
5、查询某rpm包制作时随版本变化的changelog列表信息
rpm -q --changelog PACKAGE_NAME
6、查询某包提供的capabilities
rpm -q --provides PACKAGE_NAME
7、查询某包所依赖的capabilities
rpm -q --requires PACKAGE_NAME
8、查询某包安装卸载时的脚本
rpm -q --scripts
附加: 安装卸载时的脚本有四种:
preinstall: 安装前执行的脚本
postinstall: 安装后执行的脚本
preuninstall: 卸载前执行的脚本
postuninstall: 卸载后执行的脚本
3.5校验
rpm {-V|--verify} [select-options] [verify-options]
常用用法:rpm -V PACKAGE_NAME
文件改动后校验会有下列相关信息提示:
5:文件的MD5校验值
S:文件大小
L:链接文件
T:文件创建的时间
D:设备文件
U:文件的用户
G:文件的用户组
M:文件的权限
3.6包来源合法性及完整性验正
rpm --import PUBKEY ...
导入密钥
rpm {-K|--checksig} [--nosignature] [--nodigest] PACKAGE_FILE ...
验证密钥
--nosignature: 不检查来源合法性
--nodigest: 不检查完整性
3.7、公共数据库:/var/lib/rpm
重建数据库
rpm {--initdb|--rebuilddb}
初始化:--initdb
如果事先不存在数据,则会新之;否则,不执行任何操作
重新构造:--rebuilddb
无论当前是否已经存在数据库,都会直接重建并覆盖现有数据库
四、程序包管理器之yum
1、yum介绍
yum: Yellow dog Updater,Modified,主要功能是更方便的添加/删除/更新RPM包,它能自动解决包的倚赖性问题,便于管理大量系统的更新问题
2、配置yum仓库
yum仓库配置文件:
指向仓库的位置以及各种配置信息;每个yum客户可以有多个可用的yum仓库
主配置文件有:
/etc/yum.conf
/etc/yum.repos.d/*.repo
yum客户端配置的高级用法:
(1)、如果有多个yum仓库,想优先选择使用,可以在配置文件添加一行cost定义仓库的使用开销值,默认值是1000,数值越低越优先
例如:cost=400
(2)、baseurl中指定路径时可使用变量,
例如:http://mirrors.sohu.com/centos/$releasever/os/$basearch
(3)、可以使用mirrorlist指令替换baseurl
指向一个URL,此URL是一个文本文件,其中保存了大量镜像服务器列表;用户使用yum仓库时,会获取此列表文件,而后通过fastestmirror插件判断哪一个镜像为访问速度最快的服务器,并以之做为本次访问的baseurl
3、yum的应用
3.1安装
yum install PACKAGE_NAME ...
-y: 自动回答为yes
如果需要安装指定的版本的程序:
yum install PACKAGE-VERSION ...
重新安装指定的程序包:
yum reinstall PACKAGE_NAME ...
3.2升级
yum update PACKAGE_NAME
如果有多个版本的升级包可用,且仅期望升级到指定版本:
yum update PACKAGE-VERSION
降级:
yum downgrade PACKAGE_NAME
检查可用升级:
yum check-update
3.3卸载
yum erase|remove PACKAGE_NAME
注意:依赖于该指定程序包的其它包,会被一并卸载
3.4查询
yum list
列出所有可安裝的软件清单
yum info PACKAGE_NAME
列出软件包信息
yum search KEYWORD
根据关键字模糊查询包名或包的sumary信息包含此KEYWORD的相关列表
yum provides|whatprovides /path/to/somefile
列出软件包提供哪些文件
3.5包租管理
显示所有包组:
yum grouplist
显示某包组的相关信息:
yum groupinfo "GROUP_NAME"
安装包组:
yum groupinstall "GROUP_NAME"
或
yum install @GROUP_NAME 引号加不加都可以
卸载包组:
yum groupremove "GROUP_NAME"
yum remove @"GROUP_NAME"
升级包组:
yum groupupdate "GROUP_NAME"
3.6从yum仓库下载rpm包
yumdownloader --resolve PACKAGE_FILE …
--destdir DIR
指定下载目标目录。默认为当前目录。
--urls
而不是下载RPM包,列出将要下载的网址
--resolve
当下载RPM包,解决依赖关系,并下载所需的软件包
--source
而不是下载的二进制RPM包,下载源RPM包
3.7yum命令还可用安装本地rpm包文件
yum localinstall /path/to/rpm_package_file ...
安装本地rpm包
选项:
--enablerepo=启用某yum仓库
--disablerepo=禁用某yum仓库
注意:优先级高于/etc/yum.repos.d/*.repo配置文件中定义的属性;
-y: 自动回答为yes
--nogpgcheck:不验证包的来源和完整性
四、程序包管理器之 编译
一、编译安装是什么?
在 linux上,有时候有的程序需要定制,可能程序内置功能很多,但是我们需要的只是我们需要的一部分,用yum安装不能提供我们需要的服务的时候,我们就会编译安装。编译安装就是将源代码编译成我们可以使用的可执行文件。
二、编译流程 Testapp-VERSION-release.src.rp.---->安装后,使用rpmbuild命令制作成二进制格式的rpm包----->安装
第一步:由于SRPM需要重新编译,而编译的过程当中,我们至少需要有make与其相关的程序,及gcc、c、c++等其 他的编译用的程序语言来进行编译。同时还要安装“Development Tools”,”Server Platfrom Development”开发组 件。
第二步:configure脚本
选项:指定安装位置、指定启用的特性
--help:获取其支持使用的选项
选项分类:
安装路径设定:
--prefix=/PATH/TO/SOMEWHERE:指定默认安装位置,默认为/usr/local
--sysconfdir=/PATH/TO/SOMEWHERE:配置文件安装位置
第三步: make
第四步:make install
第五步:安装后的配置
(1)、导出二进制程序目录至PATH环境变量中:
编辑文件/etc/profile.d/NAME.sh
Export PATH=/PATH/TO/BIN:$PATH
(2)、导出库文件路径
编辑/etc/ld.so.conf.d/NAME.conf
添加新的库文件所在目录至此文件中
让系统重新生成缓存 ldconfig [-v]
(3)导出头文件
基于链接的方式实现:
ln -sv
(4)导出帮助手册
编辑/etc/man.config文件
添加一个MANPATH
提示:如果configure安装为默认路径,就无须安装后配置文件。
文章标题:CentOS系统程序包管理之---rpm、yum和编译
文章URL:http://myzitong.com/article/jcephj.html