CentOS系统上rpm命令管理程序包:
        安装、升级、卸载、查询和校验、数据库维护
         
        rpm命令:rpm  [OPTIONS]  [PACKAGE_FILE]
            安装:-i, --install
            升级:-U, --update, -F, --freshen
            卸载:-e, --erase
            查询:-q, --query
            校验:-V, --verify
            数据库维护:--builddb, --initdb
             
        安装:
            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:重新安装
                     
                    注意:rpm可以自带脚本;
                        四类:--noscripts
                            preinstall:安装过程开始之前运行的脚本,%pre , --nopre
                            postinstall:安装过程完成之后运行的脚本,%post , --nopost
                            preuninstall:卸载过程真正开始执行之前运行的脚本,%preun, --nopreun
                            postuninstall:卸载过程完成之后运行的脚本,%postun , --nopostun
                             
                    --nosignature:不检查包签名信息,不检查来源合法性;
                    --nodigest:不检查包完整性信息;
                     
        升级:
            rpm {-U|--upgrade} [install-options] PACKAGE_FILE ...
            rpm {-F|--freshen} [install-options] PACKAGE_FILE ...
             
                -U:升级或安装;
                -F:升级
                 
                rpm  -Uvh PACKAGE_FILE ...
                rpm  -Fvh PACKAGE_FILE ...
                 
                    --oldpackage:降级;
                    --force:强制升级;
                     
                注意:(1) 不要对内核做升级操作;Linux支持多内核版本并存,因此,直接安装新版本内核;
                        (2) 如果某原程序包的配置文件安装后曾被修改过,升级时,新版本的程序提供的同一个配置文件不会覆盖原有版本的配置文件,而是把新版本的配置文件重命名(FILENAME.rpmnew)后提供;
                         
        卸载:
            rpm {-e|--erase} [--allmatches] [--nodeps] [--noscripts] [--test] PACKAGE_NAME ...
                 
                --allmatches:卸载所有匹配指定名称的程序包的各版本;
                --nodeps:忽略依赖关系
                --test:测试卸载,dry run模式
                 
        查询:
            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包的changlog;
                -l, --list:程序安装生成的所有文件列表;
                -i, --info:程序包相关的信息,版本号、大小、所属的包组,等;
                -c, --configfiles:查询指定的程序包提供的配置文件;
                -d, --docfiles:查询指定的程序包提供的文档;
                --provides:列出指定的程序包提供的所有的CAPABILITY;
                -R, --requires:查询指定的程序包的依赖关系;
                --scripts:查看程序包自带的脚本片断;
                 
            用法:
                -qi  PACKAGE, -qf FILE, -qc PACKAGE, -ql PACKAGE, -qd PACKAGE
                -qpi  PACKAGE_FILE, -qpl PACKAGE_FILE, -qpc 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
             
    包来源合法性验正和完整性验正:
        来源合法性验正:
        完整性验正:
         
        获取并导入信任的包制作者的密钥:
            对于CentOS发行版来说:rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
             
        验正:
            (1) 安装此组织签名的程序时,会自动执行验正;
            (2) 手动验正:rpm -K PACKAGE_FILE
             
    数据库重建:
        rpm管理器数据库路径:/var/lib/rpm/
            查询操作:通过此处的数据库进行;
             
        获取帮助:
            CentOS 6:man rpm
            CentOS 7:man rpmdb
             
            rpm {--initdb|--rebuilddb} [--dbpath DIRECTORY] [--root DIRECTORY]
                --initdb:初始化数据库,当前无任何数据库可实始化创建一个新的;当前有时不执行任何操作;
                --rebuilddb:重新构建,通过读取当前系统上所有已经安装过的程序包进行重新创建;

【Linux】【Services】【Package】rpm的更多相关文章

  1. 【Linux&Unix--open/close/write/read系统调用】

    个人学习整理.如有不足之处,请不吝不吝赐教. 转载请注明:@CSU-Max 系列博文:      Linux&Unix学习第一弹 -- 文件描写叙述符与权限  Linux&Unix学习 ...

  2. 【linux之设备,分区,文件系统】

    一.设备 IDE磁盘的设备文件采用/dev/hdx来命名,分区则采用/dev/hdxy来命名,其中x表示磁盘(a是第一块磁盘,b是第二块磁盘,以此类推), y代表分区的号码(由1开始,..3以此类推) ...

  3. 【linux之挂载,Raid,LVM】

    一.挂载,卸载 挂载:将新的文件系统关联至当前根文件系统卸载:将某文件系统与当前根文件系统的关联关系移除 cat /etc/mtab 存储着已经挂载的文件系统 (跟 mount 一样) mount:显 ...

  4. 【linux之进程管理,系统监控】

    一.进程管理 前台进程:一般是指占据着标准输入和/或标准输出的进程后台进程:不占据默认开启的进程都是前台进程ctrl+C 中断ctrl+z 从前台转入后台bg 后台进程编号 让其在后台运行ls -R ...

  5. 【Linux磁盘优化管理--RAID和LVM】

    在现阶段的企业环境中,为了数据的安全性及完整性必须要有一个合理的存储方案.面对着每秒可能产生超过几TB的数据,考虑到磁盘能不能实现 热冗余,及扩容,缩容.Linux给出了RAID(磁盘阵列)以及LVM ...

  6. 【Linux 内核网络协议栈源码剖析】网络栈主要结构介绍(socket、sock、sk_buff,etc)

    原文:http://blog.csdn.net/wenqian1991/article/details/46700177 通过前面的分析,可以发现,网络协议栈中的数据处理,都是基于各类结构体,所有有关 ...

  7. 【linux之链接,函数,随机数】

    一.链接 硬链接(hard link):同一个文件使用了多个别名.新建文件是已经存在的一个别名,,当原文件删除时,新建的文件仍然可以使用.硬链接和原来的文件没有什么区别,而且共享一个inode号.通过 ...

  8. 【Linux运维-集群技术进阶】Nginx+Keepalived+Tomcat搭建高可用/负载均衡/动静分离的Webserver集群

    额.博客名字有点长.. . 前言 最终到这篇文章了,心情是有点激动的. 由于这篇文章会集中曾经博客讲到的全部Nginx功能点.包含主要的负载均衡,还有动静分离技术再加上这篇文章的重点.通过Keepal ...

  9. 5.2【Linux 内核网络协议栈源码剖析】socket 函数剖析 ☆☆☆

    深度剖析网络协议栈中的 socket 函数,可以说是把前面介绍的串联起来,将网络协议栈各层关联起来. 应用层 FTP SMTP HTTP ... 传输层 TCP UDP 网络层 IP ICMP ARP ...

  10. 【Linux下安装使用virtualenv与virtualenvwrapper】

    virtualenv virtualenv是一个可以帮助我们管理不同Python环境的绝好工具. virtualenv是一个可以在系统中建立多个不同且相互不干扰的虚拟环境. 下面的步骤将创建两个独立的 ...

随机推荐

  1. mysql流程控制结构case when

    一.case 使用场景 简单函数 CASE case_value WHEN when_value THEN statement_list [WHEN when_value THEN statement ...

  2. uni-app 提示 v-for 暂不支持循环数据

    这个问题由于目前博主只在APP端遇到过,解决办法是把v-for key值全部取循环的索引,如果解决了你的问题请给博主点个赞 <block v-for="(item,index) in ...

  3. vs Code配置C++运行和调试环境以及相关问题

    vs Code配置C++运行和调试环境以及相关问题 第一步:下载c++插件 第二步:安装编译.调试环境 如果没有Dev-C++下载MinGW 下载地址:https://sourceforge.net/ ...

  4. map2bean & bean2map

    1,自己实现: /** * @author xx * @since 2020/7/8 */ @Slf4j public class JavaBeanUtils { /** * 实体类转map * 效率 ...

  5. 【CVE-2020-1948】Apache Dubbo Provider反序列化漏洞复现

    一.实验简介 实验所属系列: 系统安全 实验对象:本科/专科信息安全专业 相关课程及专业: 计算机网络 实验时数(学分):2 学时 实验类别: 实践实验类 二.实验目的 Apache Dubbo是一款 ...

  6. Java线程状态及同步锁

    线程的生命历程 线程的五大状态 创建状态:简而言之,当创建线程对象的代码出现的时候,此时线程就进入了创建状态.这时候的线程只是行代码而已.只有调用线程的start()方法时,线程的状态才会改变,进入就 ...

  7. 关于使用idea工具debug时,断点颜色由红色变成灰色

    在使用断点调试的时候,发现断点由原来的红色变成灰色的,后来发现是由于错误操作将Debug断点t调试禁用了 ,只需要点击禁用按钮取消就可以了 

  8. sql关联修改

    UPDATE  p  set p.ClientID = c.id  from PaymentTable p left JOIN ClientTable c on p.ClientID = c.Clie ...

  9. 菜鸡的Java笔记 - java 访问控制权限

    java中四种访问控制权限的使用                内容            在java里面一共定义有四个权限,按照由小到大的顺序:private<defaule<prote ...

  10. 不可忽视的Dubbo线程池

    问题描述 线上突然出现Dubbo超时调用,时间刚好为Consumer端设置的超时时间. 有好几个不同的接口都报超时了 第1次调用超时,第2次(或第3次)重试调用非常快(正常水平) Dubbo调用超时的 ...