博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
rpm命令管理程序包
阅读量:6811 次
发布时间:2019-06-26

本文共 2183 字,大约阅读时间需要 7 分钟。

安装、卸载、升级、查询、校验、数据库维护

安装:

rpm {-i|--install} [install-options] PACKAGE_FILE ...
-v 打印详细信息-通常例行公事,将显示进度消息。
-vv 更详细
-h 以#显示程序包管理执行进度,每个#代表2%进度
rpm -ivh PACKAGE_FILE...
[install -options]
--test 测试安装,但不真正执行安装过程:dry run
--nodeps 忽略依赖关系
--replacepkgs 重新安装
--nodigest 不检查包完整性
--nosignature 不检查来源合法性
--noscripts 不执行程序包的脚本片段
%pre 安装前脚本 --nopre
%post 安装后脚本 --nopost
%preun 卸载前脚本 --nopreun
%postun 卸载后脚本 --nopostun

升级:

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

--oldpackage 降级

--force 强行升级

注意:

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

查询:

rpm {-q|--query} [select-options] [query-options]
[select-options]
-a 所有包
-f 查看指定的文件有哪个文件安装生成(rpm -qf /bin/ls)
-p /PATH/TO/PACKAGE_FILE 针对尚未安装的程序包文件做查询操作
--whatprovides 查询指定的CAPABILITY由哪个包提供
--whatrequires 查询指定的CAPABILITY被哪个包依赖
[query-options]
--changelog 查询rpm包的changelog
-c,--configfiles 查询程序的配置文件
-d 查询程序的文档
-i information
-l 查看指定程序包安装生成的所有文件
--scripts 程序包自带的脚本片段
-R 查询指定的程序包所依赖的CAPABILITY
--provides 列出指定程序包所提供的CAPABILITY
用法:
-qi PACKAGE, -qf FILE, -ql PACKAGE , -qd PACKAGE
-qpi PACKAGE_FILE, -qpl PACKAGE_FILE
-qa

卸载:

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

校验:

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
包来源合法性及完整性验证:
完整性验证:SHA256

公钥加密技术:

对称加密:加密解密使用同一密钥
非对称加密:密钥是成对的
public key: 公钥
secrete key: 私钥

导入所需要公钥:

rpm --import /PATH/FROM/GPG-PUBKEY-FILE
Centos7发行版光盘提供的秘钥文件:RPM-GPG-KEY-CentOS-7
数据库重建:
rpm {--initdb|--rebuilddb}
initdb:初始化
如果事先不存在数据库,则重建之,否则,不执行任何操作
rebuilddb:重建
无论当前存在与否,直接重新创建数据库。

公钥秘钥加密详述

比如有两个用户Alice和Bob,Alice想把一段明文通过双钥加密的技术发送给Bob,Bob有一对公钥和私钥,那么加密解密的过程如下:

Bob将他的公开密钥传送给Alice。

Alice用Bob的公开密钥加密她的消息,然后传送给Bob。
Bob用他的私人密钥解密Alice的消息。
  上面的过程可以用下图表示,Alice使用Bob的公钥进行加密,Bob用自己的私钥进行解密。
rpm命令管理程序包

例子和图出自《网络安全基础 应用与标准第二版》

转载于:https://blog.51cto.com/14144328/2334053

你可能感兴趣的文章
WPF界面设计技巧(9)—使用UI自动化布局
查看>>
FastJson--阿里开源的速度最快的Json和对象转换工具
查看>>
在SpringMVC中获取request对象的几种方式
查看>>
RGB颜色对照表
查看>>
那些有坏味道的代码
查看>>
第 32 章 Sphinx
查看>>
Linq下的distinct()比SQLServer下的distinct更强大,更自由,呵呵
查看>>
linux虚拟机与winodows共享文件夹----linux安装VMware tools
查看>>
用re-sign.jar重签名apk后安装失败的解决办法
查看>>
跨平台iPhone中调用WCF服务
查看>>
如何设置centos6 不启动桌面环境gnome
查看>>
JavaScript blog式日历控件
查看>>
制作鼠标移动到div上面显示弹出框
查看>>
Maven版本号中隐藏的惊天大秘密
查看>>
HDU 2289 Cup【高精度,二分】
查看>>
QQ浏览器X5内核问题汇总
查看>>
ABP Zero示例项目问题总结
查看>>
180.8. Initialization store
查看>>
Calico 的默认连通性 - 每天5分钟玩转 Docker 容器技术(69)
查看>>
Oracle分页查询格式(十二)
查看>>