Linux系统软件包管理介绍

Linux发行版中附带有成千上万的可用包,其中包括了Internet工具、开发工具、办公工具、游戏等,如果你没有选择完整安装,则只会安装这些包的“子集”,如何删除不想要的包,如何安装遗漏的包,学习LInux系统的软件包管理将解决你的这些问题
在这里插入图片描述

一、软件包基础

软件运行环境:

程序员代码–>预处理–>编译–>汇编–>链接

静态编译:.a

动态编译:.so

包管理器:

二进制应用程序的组成部分

二进制文件、库文件、配置文件、帮助文件

包命名:

源代码:name-VERSION.tar.gz|bz2|xz

包之间:可能存在依赖性关系,甚至循环依赖

解决依赖包管理工具:

yum:rpm包管理器的前端工具

apt-get:deb包管理器前端工具

zypper:suse上的rpm前端管理工具

dnf:Fedora 18+ rpm包管理器前端管理工具

程序包管理器:

debian:deb文件,dpkg包管理器

redhat:rpm文件,rpm包管理器

rpm:Redhat Package Manager

RPM Package Manager

二、RPM包管理

RPM代表Redhat Packge Manager(Redhat包管理器)

RPM现在已成为管理Redhat和UnitedLinux以及其他许多发行版本上的软件的标准。

RPM本质上就是一个包,包含可以立即在特定机器体系结构上安装和运行的Linux软件。

最初加载到发行版本中的所有软件都是通过一个RPM来安装的。

RPM剖析:

RPM是文件包,它包括关于包及其功能和依赖关系(即在该包能够运行之前必须安装

其他哪些包)的信息。还包含包中的文件清单,指定这些文件必须加载到系统中的何处,

以及它们的初始权限如何。RPM还包含安装前脚本,这是由包开发人员编写的。

RPM其次还包含已编译的二进制文件。最后,RPM包含了安装后的脚本。

RPM数据库:

/var/lib/rpm

包含了关于系统上已安装的每个RPM信息。这个数据库知道包之间的依赖关系,还知道每个包的

文档和配置文件的位置。在加载和卸载包时,RPM使用这个数据库来检查依赖关系。用户还可以

在这个数据库查询关于包的信息。

rpm

常用选项:

-i 安装包

-h 输出哈希(#)符号提供安装进度更新

-v 显示详细过程

-ihv是常用配合选项;

-e 删除已安装的包

-V 验证开关

-U 升级

-q 查询

-qc 显示包的配置文件

-qd 显示包的文档文件

-qi 显示包描述

-ql 显示包的文件列表

-qR 显示包的依赖关系

安装:

rpm{-i|–install}[install-option]PACKAGE_FILE

-h 输出哈希(#)符号提供安装进度更新

-v 显示详细过程

-ihv是常用配合选项

[install-option]

–test 测试安装,但不真正执行安装

–nodeps 忽略依赖关系

–replacepkgs|replacefiles 覆盖包安装(可用来修复已安装的安装包)|覆盖文件安装

–nosignature 不检查来源的合法性(不安全)

RPM-GPG-KEY-CentOS-6

–nodigest 不检查包完整性 (不安全)

–noscripts 只装包不执行程序包脚本

–nopre 不执行安装前脚本

–nopost 不执行安装后脚本

–nopreun 不执行卸载前脚本

–nopostun 不执行卸载后脚本

升级:

rpm{-U|–upgrade}[install-option]PACKAGE_FILE

rpm{-F|–freshen}[install-option]PACKAGE_FILE

upfrade 如果安装有旧版程序包,则升级, 如果不存在旧版程序包,则安装

freshen 如果安装有旧版程序包,则升级, 如果不存在旧版程序包,则不执行升级操作

rpm -Uvh PACKAGE_FILE…

rpm -Fvh PACKAGE_FILE…

注:内核升级不建议使用以上两种升级命令,建议使用-ivh重新安装另一个内核,Linux

支持多内核版本共存。

–oldpackage 降级

–force 强制安装(可用来修复已安装的安装包)

查询:

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

注:包的名称必须精确匹配,不允许使用通配符。然而,如果记不住包的完整名称,您可以

使用 grep 工具来帮助找到它。可以使用 -qa 开关来查询所有已安装的包,并用 grep 来管道

输出您能记住的信息。例如:rpm -qa | grep name

[select-option]

-a 查看所有已安装的包

-f 查看指定的文件由哪个程序包安装产生

-p rpmfile 针对尚未安装的程序包文件做查询操作(配合文件名而不是包名)

–whatprovides CAPABILITY 查询指定的关键字由哪个包所提供

–whatrequires CAPABILITY 查询指定的关键字被哪个包所依赖

[query-options]

–changelog 查询rpm包的changelog

-c 查询程序的配置文件

-d 查询程序的文档

-i 查看包描述information

-l 查看指定的程序包安装后生成的文件

–scripts 查看程序包自带的脚本

–provides 列出指定程序包所提供的关键字

-R 查询指定程序包所依赖的关键字CAPABILITY

rpm2cpio 包文件|cpio -itv 预览包内文件

rpm2cpio 包文件|cpio -id “*.conf” 释放包内文件

包校验:

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

校验
注:只能查看已安装的包

导入所需要公钥

rpm -K|checksig rpmfile 检查包的完整性和签名

rpm –import /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7

CentOS 7发行版光盘提供:RPM-GPG-KEY-CentOS-7

rpm -qa “gpg-pubkey*”

三、YUM使用介绍

Yellowdog Update Modifier,rpm的前端程序,可解决软件包相关依赖性,可在多个库之间定位软件包,up2date的替代工具。

使用yum安装文件包出错一般都是下面2种情况:

  1. 配置文件的格式错误

  2. 缓存问题
    注:yum不支持多个终端同时执行

yum repository: yum repo,存储了众多rpm包,以及包的相关的元数据文件(放置于特定目录repodata下)

文件服务器:

http://

https://

ftp://

file://

仓库位置:

/etc/yum.repos.d/*.repo

仓库默认设置:

/etc/yum.conf

repo关键行

[base]                                                 仓库名,不可以加空格

name=centos cdrom                        描述信息

baseurl= file:///mnt/cdrom

注:仓库路径为repodata目录的父目录

gpgcheck=0                                       默认为1,0表示不进行数字签名完整性检查

gpgkey=file:///mnt/cdrom/RPM-GPG-KEY-CentOS-7             自动导入秘钥

enabled=0                                          默认为1,0表示仓库禁用

yum日志:

/var/log/yum.log 包含了使用yum安装与卸载的日志

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

$releasever: 当前OS的发行版的主版本号

$basearch:基础平台;i386, x86_64

例如:

http://server/centos/$releasever/$basearch/

http://server/centos/7/x86_64

http://server/centos/6/i384

yum

格式:yum[option][command][package…]PACKAGE_FILE

显示仓库列表:

yum repolist[all|enabled|disabled]

显示程序包:

yum list

yum list[all|glob_exp1][glob_exp2][…]

yum list{available|installed|updates}[glob_exp1][…]

安装程序包:

yum install package1 [package2] […]

yum reinstall package1 [package2] […] (重新安装)

升级程序包:

yum update [package1] [package2] […](升级)

yum downgrade package1 [package2] […] (降级)

检查可用升级:

yum check-update

卸载程序包:

yum remove | erase package1 [package2] […]

查看程序包information:

yum info […] 

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

yum provides | whatprovides feature1 [feature2] […] 

清理本地缓存:

清除/var/cache/yum/$basearch/$releasever缓存

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

构建缓存:

yum makecache

搜索:

以指定的关键字搜索程序包名及summary信息

yum search string1 [string2] […]

查看指定包所依赖的capabilities:

yum deplist package1 [package2] […]

查看yum执行历史:

yum history

yum history info 6yum history undo 6 

日志:/var/log/yum.log

安装及升级本地程序包:

yum install rpmfile1 [rpmfile2] […]

yum update rpmfile1 [rpmfile2] […]

包组管理的相关命令:

yum groupinstall group1 [group2] […]

yum groupupdate group1 [group2] […]

yum grouplist [hidden] [groupwildcard] […]

yum groupremove group1 [group2] […]

yum groupinfo group1 […]

四、源代码安装

C、C++:make项目管理器

configure脚本–>Makefile.in–>Makefile

C语言源代码编译安装三步骤:

1、./configure

--prefix=                              指定目录安装

--sysconfidir=                      指定/etc目录独立安装

(1)通过选项传递参数,指定启用特性,安装路径;执行会参考用户的指定已经Makefile.in
文件生成Makefile

(2)检查依赖到的外部环境,如依赖的软件包

2、make

编译过程,根据Makefile文件,构建应用程序

3、make install

复制文件到相应路径

Logo

更多推荐