这里主要讲以CentOS为例,rpm程序包管理器的相关内容:

CentOS的程序包管理器:
   1) 程序包的命名规则:
        源代码包:
            software_name-VERSION.tar.gz
            VERSION:major.minor.release
                major:主版本号,通常代表重大功能改进的版本分支;
                minor:次版本号,通常代表在某个版本的分支中的某个功能发生变化;
                release:发行版本号,修复了某些bug或者对某段代码进行了优化;

                apache-tomcat-7.0.63.tar.gz

       2) rpm程序包命名规则:
            源码包:source code
                software_name-VERSION.src.rpm
            二进制包:
                software_name-VERSION-[release].[os].arch.rpm
                    VERSION:major.minor.release
                    [release]:rpm封包的发行版本号
                    [os]:所支持的操作系统版本,el6, el7, suse11, fedora22, ...
                    arch:硬件平台类型,I386, x64(amd64), ppc, sparc, noarch, ...

                puppet-3.8.7-1.el7.noarch.rpm

    在制作rpm程序包的时候,通常其制作者会采用分包技术来构建rpm程序包;

    根据程序的不同功能,构建多个程序包;

    被分包的程序包一般分为两类:
        主程序包:
            software_name-VERSION-[release].[os].arch.rpm
        附属功能包:
            software_name-function-VERSION-[release].[os].arch.rpm

            一般来讲,主程序包和附属功能包具有相同的版本号,发行版本号,操作系统及兼容平台的标识;

            所以,主程序包往往被所有的附属功能包所依赖;不安装主程序包就不能安装附属功能包;

            function:devel, utils, libs, tools, manual, client, common, ...

    依赖关系:
        A --> B --> C D --> A 依赖黑洞

  3)rpm程序包管理器:
    1.rpm命令行工具;
    2.yum工具;

    rpm命令行工具:
    功能:
        1.将编译好的应用程序的各个组成文件打包成一个或多个程序包文件;
        2.软件包的安装、卸载、升级、查询、校验及数据库管理功能

    rpm程序包中文件的组成清单:
        1.程序的文件
        2.文件清单
        3.软件安装或卸载时所运行的脚本文件,共分为四类:
            preinstall:在正式的安装操作开始之前所运行的脚本,%pre
            postinstall:在安装完成后所执行的脚本,%post
            preuninstall:在正式卸载操作开始之前所运行的脚本,%preun
            postuninstall:在卸载完成后所执行的脚本,%postun

    rpm数据库(公共):
        已经安装好的程序包名称及版本
        /var/lib/rpm


  4)获取程序包的途径:
    1.系统的发行版的光盘
    2.官方的文件服务器或者镜像站点:
        http://mirrors.aliyun.com
        http://mirrors.sohu.com
        http://mirrors.163.com
        https://mirrors.tuna.tsinghua.edu.cn
        http://mirrors.hust.edu.cn
        ...
    3.某个项目的官方站点:
    4.第三方组织制作的rpm程序包站点
        Fedora EPEL:红帽官方的社区组织,在镜像站点中也包含EPEL镜像;
        搜索引擎:
            http://pkgs.org
            http://rpmfind.net
            http://rpm.pbone.net
    5.自己制作

    建议:获得程序包之后,实施完整性检查
        来源合法性:
            通过程序提供者的数字签名加密的数据,我们通过其公钥进行解密验证;
        程序包完整性:
            sha-1校验码

rpm和yum两个工具的使用

rpm命令行工具:
    安装、卸载、升级(降级)、查询、文件校验、验证、数据库维护;

    rpm命令的通用选项:
        -v:显示安装例程的信息,仅仅显示安装软件名
        -vv:显示非常详细的操作信息

安装:
    rpm {-i|--install} [install-options] PACKAGE_FILE ...
        install-options:
            -h, --hash:用50个"#"来表示安装进度
            --test:并不是真正的安装软件包,仅仅是测试是否在安装时能够正常完成,dry run模式;
            --nodeps:忽略因为依赖关系导致的安装错误,不建议使用;
            --replacefiles:在安装软件包时,软件包中的文件会直接将原来安装的文件替换;
            --replacepkgs:无需卸载软件包而重新安装;
            --noscripts:不运行任何脚本
            --nopre
            --nopost
            --nosignature:不考虑软件包的来源是否合法;
            --nodigest:不考虑软件包是否完整;

        例:~]# rpm -ivh php-mysql-5.3.3-40.el6_6.x86_64.rpm php-pdo-5.3.3-40.el6_6.x86_64.rpm

升级:
    rpm {-U|--upgrade} [install-options] PACKAGE_FILE ...
        如果选择被安装的程序包事先并未安装,则全新安装;如果已经安装了旧版本,则可以升级安装;
    rpm {-F|--freshen} [install-options] PACKAGE_FILE ...
        仅仅只能对已经安装的低版本的程序包进行升级安装;
        常用选项:与安装相同
        --oldpackage:降级安装,用老版本的程序包替换新版本的程序包;
        --force:强制升级

    注意:
        1.强烈建议,不要对内核进行升级操作;Linux可以支持多内核,可以直接安装新版本的内核,在启动界面可以手动更换;
        2.升级安装可能会带来文件的变化,因此,系统默认不会直接更改之前安装过的软件的配置文件,新程序包中的配置文件会被重命名,通常会是:FINENAME.rpmnew

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

    --allmatches:卸载所有匹配指定名称的程序包的各个版本;
    --nodeps:卸载时忽略依赖关系,不建议使用;
    --test:测试卸载,dry run模式;

查询:
    rpm {-q|--query} [select-options] [query-options]
        [select-options]
            PACKAGE_NAME:直接给出程序包名
            -a,--all:查询所有已经安装的程序包名;
                ~]# rpm -qa | grep mysql
            -f,--file FILE:查找指定的文件是由哪个程序包提供的;
            -p,--package PACKAGE_FILE:对还没有安装的程序包文件中执行查询操作
            --whatprovides CAPABILITY:查询指定的CAPABILITY是由哪个程序包提供的
            --whatrequires CAPABILITY:查询指定的CAPABILITY被哪个程序包所依赖

        [query-options]
            --changelog:查询rpm程序包的changelog;
            -c,--configfiles:查询指定程序包中有哪些是配置文件;
            -d,--docfiles:查询指定程序包中有哪些文档文件;
            -i,--info:查询程序包相关的信息,包括版本号,发行号,大小等;
            -l,--list:列表显示程序包安装会生成哪些文件
            --provides:列出指定程序包提供的所有的CAPABILITY;
            -R,--requires:查询指定程序包的依赖关系;
            --scripts:查看程序包所携带的脚本的内容;

    具体使用方法:
        -qf FILE
        -qc|-ql|-qd|-qi PACKAGE_NAME
        -qpl|-qpc|-qpd|-qpi 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

认证:
    rpm --import /PATH/TO/KEY_FILE
    rpm -K /PATH/TO/PACKAGE_FILE

数据库管理:
    数据库的初始化和重建
        /var/lib/rpm

        rpm {--initdb|--rebuilddb}
            [--dbpath DIRECTORY]



二:yum前端工具相关

yum:
        Yellowdog Updater Modified
        Yellowdog是一款发行版linux,使用rpm作为默认的程序包管理工具

        URL: yum定位软件仓库及仓库中程序包文件的主要标识方式;
        schema://[username@]hostname[:port][/PATH/TO/DOCUMENT][parameters][method]
        web站点:
            http/https
            http://www.163.com

        yum是C/S架构的模型,其中服务器也称为软件仓库(yum repository),客户端需要书写URL以指定服务器及程序包路径;

        在服务器上,软件仓库其实就是一个目录,在目录中包含了程序包文件及元数据文件;
        元数据文件统一的存放于repodata的目录中;也可以说,repodata目录所在的路径即为软件仓库的路径;

        createrepo命令:
            createrepo - Create repomd (xml-rpm-metadata) repository
            createrepo [options]
                :存放程序包的目录

        客户机的使用:
            yum程序包
            yum的主配置文件:/etc/yum.conf
                ini风格的配置信息模式:分段式配置内容
                    [repositoryid]
                    statements


一)yum命令的用法:
    yum - Yellowdog Updater Modified
    yum [options] [command] [package ...]
        [options]:
            -y, --assumeyes:对于yum执行过程中与用户交互的问题,全部以yes回答
            -q, --quiet:安静模式,在某一次yum执行过程中,没有任何信息输出到stdout;
            --enablerepo=repoidglob
            --disablerepo=repoidglob
                在某一次yum执行过程中明确的规定启用或禁用某个repository指向;在使用了这样的选项之后,仓库指向文件中的enabled语句的作用将失效;
            --noplugins:
                在某一次yum执行过程中,明确指出不使用任何插件;
            --nogpgcheck:
                在某一次yum执行过程中,明确指出不验证程序包完整性,在仓库指向文件中的gpgcheck=1语句会失效;

        [command]
            command is one of:
        * install package1 [package2] [...]
            安装程序包
            注意:
                1.如果只是给出程序包名称,yum搜索所有仓库,并找到最新版本缓存安装;
                2.如果给出程序包的名称及版本,则查找安装指定版本的程序包;
                3.如果给出的程序包是完整的程序包名,则只是查找某一个程序包;
                4.程序包名称可以使用globbing,(* ? [] [^])

        * update [package1] [package2] [...]
        * update-to [package1] [package2] [...]
        * check-update
        * upgrade [package1] [package2] [...]
        * upgrade-to [package1] [package2] [...]
        * downgrade package1 [package2] [...]
            程序包升级或降级:
                程序包不同版本之间的更迭;

        * remove | erase package1 [package2] [...]
            卸载程序包:    

        * list [...]
                yum list LIST OPTIONS
                LIST OPTIONS:
                    all: 显示所有的程序包,包括已经安装的和尚未安装但可用的;
                        注意:
                            anaconda:CentOS系统的安装器,在安装操作系统的时候一并安装的程序包;
                    installed:显示所有已经安装的程序包;
                    available:显示所有尚未安装但可以安装的程序包;
                    updates:显示所有可以升级更新的程序包;

        * info [...]
            yum info LIST OPTIONS
            LIST OPTIONS:
                    all: 显示所有的程序包,包括已经安装的和尚未安装但可用的;
                        注意:
                            anaconda:CentOS系统的安装器,在安装操作系统的时候一并安装的程序包;
                    installed:显示所有已经安装的程序包;
                    available:显示所有尚未安装但可以安装的程序包;
                    updates:显示所有可以升级更新的程序包;

                    name[globbing]

        * provides | whatprovides feature1 [feature2] [...]
            查看指定的特性是由哪个程序包提供的;

        * clean [ packages | metadata | expire-cache | rpmdb | plugins | all ]
            清理本地缓存信息

        * makecache
            构建缓存

        * groupinstall group1 [group2] [...]
        * groupupdate group1 [group2] [...]
        * grouplist [hidden] [groupwildcard] [...]
        * groupremove group1 [group2] [...]
        * groupinfo group1 [...]
            程序包组的管理命令:


        * search string1 [string2] [...]
            根据关键字进行匹配,默认情况下,搜索程序包名称及汇总信息;
            模糊搜索

        * shell [filename]
            给yum提供一个交互式命令的操作界面

        * localinstall rpmfile1 [rpmfile2] [...]
           (maintained for legacy reasons only - use install)
        * localupdate rpmfile1 [rpmfile2] [...]
           (maintained for legacy reasons only - use update)
          实现本地程序包安装,即:不依赖于软件仓库,直接对rpm格式包文件进行操作;
          这两个命令已经被停用,使用install和update取代;

        * reinstall package1 [package2] [...]
            重新安装

        * deplist package1 [package2] [...]
            显示每个程序包所有的依赖关系;

        * repolist [all|enabled|disabled]
            列表显示yum仓库的元数据信息
            在没有给出后面的参数的时候,默认为enabled;

        * version [ all | installed | available | group-* | nogroups* | grouplist | groupinfo ]

        * history [info|list|packages-list|packages-info|summary|addon-
       info|redo|undo|rollback|new|sync|stats]
               查看yum事务的历史;
                   安装、升级、卸载等操作的时候,yum会开启事务;

        * load-transaction [txfile]
            重新启动已经停止的事务;

        * check

        * help [command]

待续:... ...