0x00 软件包管理器

所有的软件都是由文件格式的程序代码(即源代码),经过编译成为一个可执行二进制文件;对于一个软件来说,其包含二进制程序、库文件、配置文件以及帮助文件。在应用中,每次要安装程序时通过找源代码然后去编译成二进制文件,这个过程要花费大量的时间,所以就有了程序包管理器。程序包管理器的功能是:将编译好的应用程序的各组文件打包成一个或几个程序包文件,从而更方便地实现程序包的安装、升级、卸载和查询等管理操作。

我们可以将这种软件包管理器称为手动安装程序的软件包管理器,为什么成为手动安装程序的软件包管理器呢?
因为这种软件包管理器,在软件安装的过程中不能解决包之间的依赖管理,比如,A程序的运行要基于B程序的某些库文件才能运行,所以在安装A程序之前必须安装A程序;当然也有可能出现这种情况:B程序的运行也要基于A程序的某些库文件才能运行,这样就形成了先有鸡还是先有蛋的问题。

利用这种程序包管理器我们只能手动解决包之间的依赖关系。所谓自动解决依赖关系,无非就是在某个程序安装之前对该程序包文件进行分析看其都依赖哪些程序,然后将这些程序一并安装,从而解决软件包的依赖文件,我们将自动解决依赖关系的工具称为解决依赖关系的前端工具。

Linux发行版本主要分为两类:类RedHat和类Debain,不同的发行版本上所使用的程序包管理器各不相同,下图是各发行版本所使用的程序包管理器:

0x01 程序包管理器的组成

1、程序包的组成清单(每个程序包都单独实现)

其中包含文件清单和安全或卸载时运行的脚本

2、数据库(公共)

程序包管理器数据库存放的位置在/var/lib/rpm/目录下,其中包含程序包的名称和版本,依赖关系,功能说明以及安装生成的各文件的文件路径及校验码信息等等。

0x02  获取可靠安全程序包的途径

1、系统发行版的光盘或官方的文件服务器(或镜像站点)

http://mirrors.aliyun.com
http://mirrors.sohu.com
http://mirrors.163.com

2、项目的官方站点

详细直接参考官方网站

3、第三方组织:

(1) EPEL
(2) 专门搜索rpm的搜索引擎
http://pkgs.org
http://rpmfind.net
http://rpm.pbone.net

4、自己做rpm包

0x03 rpm包命名格式

在看rpm包命名格式之前先来看下源代码的命名格式:

源代码:name-VERSION.tar.gz
其中VERSION包含: major.minor.release

rpm包命名格式

name-VERSION-release.arch.rpm
VERSION: major.minor.release --> 其为源代码的发行号
release.arch: rpm包的发行号
architecture: i386, x64(amd64), ppc, noarch
redis-3.0.2-1.centos7.x64.rpm

拆包:主包和子包;Linux中的软件包一般有一个主程序的安装包,再就是子程序包,所谓的子程序包就是该软件上的某一功能的安装包,或者说是该程序的一个插件。

主包: name-VERSION-release.arch.rpm
子包: name-function-VERSION-release.arch.rpm

0x04 CentOS系统上rpm命令管理程序包

rpm程序包管理器主要实现的功能有:安装、升级、查询、校检以及数据库维护

  • rpm命令格式

  rpm [OPTIONS] [PACKAGE_FILE]

  • 命令选项 [OPTIONS]

  -i, --install: 安装
  -U, -update, -F, --freshen: 升级
  -e, --erase: 卸载
  -q, --query: 查询
  -V, --verify: 校验
  --builddb, --initdb: 数据库的创建

1、安装

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

# rpm -ivh PACKAGE_FILE
GENERAL OPTIONS
-v: verbose,详细信息
-vv: 更详细的输出

[install-options]

-h: hash marks 输出进度条;每个#表示2%的进度;
--test: 测试安装,检查并报告依赖关系及冲突消息等;
--nodeps: 忽略依赖关系;
注意:当忽略依赖关系安装程序时,程序安装完成后,有可能不能正常运行,所以该安装选项不建议使用;
--replacepkgs: 重新安装;
比如说,将某程序的配置文件中信息修改后,想还原该配置文件,但是忘记了之前的配置,此时可以将该配置文件删除后,利用该安装选项对该程序重新安装来恢复其某个配置文件;
--nosignature: 不检查包签名信息,不检查包来源的合法性;
--nodigest: 不检查包完整性信息;
--noscripts: 安装时不执行脚本文件

注意:rpm可以自带脚本

rpm包中的脚本分四类:
preinstall: 安装过程开始之前运行的脚本,%pre,--nopre
postinstall: 安装过程完成之后运行的脚本,%post,--nopost
preuninstall: 卸载过程真正开始执行之前运行的脚本,%preun,--nopreun
postuninstall: 卸载过程完成之后运行的脚本,%postun,--nopostun

安装命令演示

(1) 安装一个rpm软件包

(2) 忽略依赖关系安装

安装php的rpm包时出现依赖关系错误,此时可以忽略依赖关系对软件包进行安装

(3) 测试安装

(4) 重新安装

2、升级

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

-U: 升级或安装
-F: 升级
rpm -Uvh PACKAGE_FILE...
rpm -Fvh PACKAGE_FILE...

[install-options]

--oldpackage: 降级
--foece: 强制升级

注意:

(1) 不要对内核做升级操作;Linux支持多内核版本并存,因此,直接安装新版内核;
(2)如果某原程序包的配置文件安装后曾被修改过,升级时,新版本的程序提供一个配置文件不会覆盖原有版本的配置文件,而是把新版本的配置文件重命名(FILENAME.rpmnew)后提供;

3、卸载

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

--allmarches: 卸载所有匹配指定名称的程序包的各版本;
--nodeps: 忽略依赖关系;
--test: 测试卸载,dry run模式

4、查询

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包的changelog;
-l, --list: 程序包安装生成的所有文件列表;
-i, --info: 程序包相关的信息,版本号、大小、所属组等;
-c, --configfiles: 查询指定的程序提供的配置文件;
-d, --docfiles: 查询指定的程序包提供的文档;
--provides: 列出指定程序包提供的所有CAPABILITY;
-R, --require: 查询指定程序包的依赖关系;
--scripts: 查询程序包自带的脚本片段;

查询命令演示

(1) 查询指定的安装后的程序

(2) 查询指定的文件由哪个程序安装包生成

(3) 查询程序包安装后生成的文件列表或者某程序的文件列表

(4) 列出指定程序包提供的所有CAPABILITY

(5) 查询指定的CAPABILITY由哪个包提供

(7) 查询指定程序包的依赖关系

(8) 查询程序包自带的脚本片段

5、校验

软件包的校验一般是验证其来源的合法性以及软件包完整性的验证;来源合法性验证利用数字签名奇数,完整性验证利用单项函数加密技术。

软件包校验命令

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

校验过程:

(1) 首先获取并导入信任的包制作者的密钥

对于CentOS发行版来说,利用下面的命令进行密钥的导入:
# rpm -import /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7

(2) 验证

a. 安装此组织签名的程序时,会自动执行验证;
b. 手动验证:rmp -K PACKAGE_FILE

6、数据库重建

rpm管理器数据库的路径/var/lib/rpm/

获取rpm数据库工具的帮助

CentOS 6: man rpm
CentOS 7: man rpmdb

数据库重建的命令

rpm {--initdb|--rebuilddb}

--initdb: 初始化数据库,当前无任何数据库可实现初始化创建一个新的;当前有时不执行任何操作;
--rebuilddb: 重新构建,通过读取当前系统上所有已经安装过的程序 包进行重新创建;

参考

Linux学习笔记之rpm包管理功能全解的更多相关文章

  1. [转帖]Linux学习笔记之rpm包管理功能全解

    Linux学习笔记之rpm包管理功能全解 https://www.cnblogs.com/JetpropelledSnake/p/11177277.html rpm 的管理命令 之前学习过 yum 的 ...

  2. Linux学习笔记15—RPM包的安装OR源码包的安装

    RPM安装命令1. 安装一个rpm包rpm –ivh 包名“-i” : 安装的意思“-v” : 可视化“-h” : 显示安装进度另外在安装一个rpm包时常用的附带参数有:--force : 强制安装, ...

  3. 【Linux相识相知】rpm包管理

    我们日常在使用Windows的时候,如果要安装某个软件,最简单的方法就是在程序包的官网直接下载软件包到本地,一般是以.exe或者.msi格式的文件,然后一直下一步下一步就能安装成功了,但是在使用lin ...

  4. linux 学习笔记之文件与管理

    前言: 对于windows来说,文件的系统管理都是非常简单的(这个应该有一个捂脸),通常就是重命名,复制,移动,删除,查看文件属性,查看文件内容,寻找文件.其实在图形化行中的linux也是有这样子功能 ...

  5. linux学习笔记----文件与目录管理

    一.目录处理命令 cd:切换目录 pwd:显示当前目录 mkdir:新建一个新的目录 rmdir:删除一个空的目录 1)pwd:显示当前目录 pwd [-P] P:显示出当前的路径,而非使用连接(li ...

  6. linux学习笔记--程序与进程管理

    .工作管理 1.前台程序放后台程序  命令后 加  & 2.任务执行时将前台任务任务放到后台中并[暂停]  ctr + z 3.jobs 观察后台工作状态 及多少任务在执行,可以通过 help ...

  7. node学习笔记2 —— npm包管理

    全局模式安装包 将包安装为全局可用的可执行命令, 并非可以从任意地方require 将 package.json中bin定义的文件软链到统一的目录下, 该目录可以通过如下方式推算出来: path.re ...

  8. linux学习笔记二-----文件权限管理

    一.分析文件权限(ln -s 文件名 快捷方式名 用来创建文件的快捷方式,下方ll查看信息时会在第一个字符处显示l) [hjp@bogon ~]$ ll total 4 drwxrwxr-x. 2 h ...

  9. [ kvm ] 学习笔记 4:KVM 高级功能详解

    1. 半虚拟化驱动 1.1 virtio 概述 KVM 是必须使用硬件虚拟化辅助技术(如 Intel VT-x .AMD-V)的 Hypervisor,在CPU 运行效率方面有硬件支持,其效率是比较高 ...

随机推荐

  1. Django rest framework ---- 权限

    Django rest framework ---- 权限 添加权限 api/utils文件夹下新建premission.py文件,代码如下: message是当没有权限时,提示的信息 # FileN ...

  2. 定时调度之Quartz

    工作中我们经常碰到定时或者固定时间点去做一些事情,然后每天到时间点就会去做这样的事情,如果理解这样的场景,我们就要引入今天我们的主角Quartz,其实这个跟数据库的作业类似,但是不仅仅局限于数据库. ...

  3. k8s集群搭建(一)

    k8s简介 kubernetes,简称K8s,是用8代替8个字符“ubernete”而成的缩写.是一个开源的,用于管理云平台中多个主机上的容器化的应用,Kubernetes的目标是让部署容器化的应用简 ...

  4. rollup入门

    作为js程序员,掌握rollup是必要的. 有了webpack后,为什么还要用rollup, 因为webpack不专业,webpack是打包一切. rollup只为打包js而生. rollup通过的五 ...

  5. LOJ 3119: 洛谷 P5400: 「CTS2019 | CTSC2019」随机立方体

    题目传送门:LOJ #3119. 题意简述: 题目说的很清楚了. 题解: 记恰好有 \(i\) 个极大的数的方案数为 \(\mathrm{cnt}[i]\),则答案为 \(\displaystyle\ ...

  6. Win7下安装openssl

    安装环境: 操作系统:window7(64位) C++编译器:VS2012 -------------------------------------------------------------- ...

  7. Spring Boot 注入外部配置到应用内部

    Spring Boot允许你外部化你的配置,这样你就可以在不同的环境中使用相同的应用程序代码,你可以使用properties文件.YAML文件.环境变量和命令行参数来外部化配置,属性值可以通过使用@V ...

  8. 如何用<dl>标签做表格而不用table标签

    我们都知道很多的内容编辑器(TinyMCE编辑器.fck)都有插入表格功能,快速方便,但是这些表格用到的<table>标签,可以查看html源代码就能发现,table标签对搜索引擎不是很友 ...

  9. 一个小问题 关于 com.mysql.jdbc.PacketTooBigException: Packet for query is too large

    这个错本身就是应为传输的数据大于mysql的max_allowed_packet参数默认值造成的: 之前遇到这个问题,一直是改max_allowed_packet的值 ,做项目遇到这个错误改了好几次, ...

  10. vue之父子组件通信

    一. 父-子组件间通信 let children={    template:`<div><h1>{{send}}</h1></div>`,  # 将传 ...