程序包管理

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

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

        常用rpm命令   

        rpm -qa | grep coreutils    <-- 查看系统上是否已经安装了coreutils

        rpm -qi coreutils               <-- 查看已经安装的好的coreutils的描述信息

        rpm -qf /bin/bash            <-- 查看bash文件属于哪个包

        rpm -ql bash                    <-- 列出包bash中的所有文件

        rpm -qc bash                   <-- 列出包bash中的配置文件

        rpm -qd bash                   <-- 列出包bash中的文档


        rpm -qip package.rpm        <-- 查看未安装rpm文件的描述信息

        rpm -qlp package.rpm        <-- 查看未安装rpm文件里的文件列表

        rpm -qcp package.rpm        <-- 查看未安装rpm文件里的配置文件列表

        rpm -qdp package.rpm        <-- 查看未安装rpm文件的文档文件列表


        rpm -ivh package.rpm          <-- 安装一个rpm包

        rpm -e package_name         <-- 删除一个rpm包

        rpm -Uvh package_name       <-- 升级一个rpm包,旧包不存在则安装

        rpm -Fvh package_name       <-- 升级一个rpm包,旧包不存在则不升级也不安装,得有旧包才升级


        rpm --import key_file            <-- 导入公钥用于检查rpm文件的签名

        rpm -qa | grep pubkey          <-- 列出rpm导入的所有公钥

        rpm --checksig package.rpm  <-- 检查rpm文件的签名   

    

    

rpm:

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

        -v: verbose

        -vv: 

        -h: 以#显示程序包管理执行进度;每个#表示2%的进度

        

安装:


    rpm -ivh PACKAGE_FILE ...


        [install-options]

            --test: 测试安装,但不真正执行安装过程;dry run模式;

            --nodeps:忽略依赖关系;

            --replacepkgs: 重新安装;


            --nosignature: 不检查来源合法性;

            --nodigest:不检查包完整性;


            --noscipts:不执行程序包脚本片断;

                %pre: 安装前脚本; --nopre

                %post: 安装后脚本; --nopost

                %preun: 卸载前脚本; --nopreun

                %postun: 卸载后脚本;  --nopostun


升级:

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

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


        upgrage:安装有旧版程序包,则“升级”;如果不存在旧版程序包,则“安装”;

        freeshen:安装有旧版程序包,则“升级”;如果不存在旧版程序包,则不执行升级操作;


        rpm -Uvh PACKAGE_FILE ...

        rpm -Fvh PACKAGE_FILE ...


        --oldpackage:降级;

        --force: 强行升级;


    注意:(1) 不要对内核做升级操作;Linux支持多内核版本并存,因此,对直接安装新版本内核;

          (2) 如果原程序包的配置文件安装后曾被修改,长级时,新版本的提供的同一个配置文件并不会直接覆盖老版本的配置文件,而把新版本的文件重命名(FILENAME.rpmnew)后保留;


查询:

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


    [select-options]

        -a: 所有包

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


        -p /PATH/TO/PACKAGE_FILE:针对尚未安装的程序包文件做查询操作;


        --whatprovides CAPABILITY:查询指定的CAPABILITY由哪个包所提供;

        --whatrequires CAPABILITY:查询指定的CAPABILITY被哪个包所依赖;


    [query-options]

        --changelog:查询rpm包的changlog

        -c: 查询程序的配置文件

        -d: 查询程序的文档

        -i: information

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

        --scripts:程序包自带的脚本片断

        -R: 查询指定的程序包所依赖的CAPABILITY;

        --provides: 列出指定程序包所提供的CAPABILITY;


    用法:

        -qi PACKAGE, -qf FILE, -qc PACKAGE, -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


导入所需要公钥:

    rpm --import /PATH/FROM/GPG-PUBKEY-FILE


    CentOS 7发行版光盘提供的密钥文件:RPM-GPG-KEY-CentOS-7

    

检查包的数字签名:

    rpm -checksig PACKAGE_NAME.rpm

    

数据库重建:

    rpm {--initdb|--rebuilddb}

        initdb: 初始化

            如果事先不存在数据库,则新建之;否则,不执行任何操作;


        rebuilddb:重建

            无论当前存在与否,直接重新创建数据库;

            

**************************************************************************************************************************


CentOS系统上yum命令管理程序包:yum, dnf

yum客户端:

    配置文件:

        /etc/yum.conf:为所有仓库提供公共配置

        /etc/yum.repos.d/*.repo:为仓库的指向提供配置


    仓库指向的定义:

    [repositoryID]

    name=Some name for this repository

    baseurl=url://path/to/repository/

    enabled={1|0}

    gpgcheck={1|0}

    gpgkey=URL

    enablegroups={1|0}

    failovermethod={roundrobin|priority}

        默认为:roundrobin,意为随机挑选;

    cost=

        默认为1000



    教室里的yum源:http://172.16.0.1/cobbler/ks_mirror/CentOS-6.6-x86_64/

    CentOS 6.6 X84_64 epel: http://172.16.0.1/fedora-epel/6/x86_64/


yum命令的用法:

    yum [options] [command] [package ...]

    

        options:

            --nogpgcheck:禁止进行gpg check

            -y: 自动回答为“yes”

            -q:静默模式

            --disablerepo=repoidglob:临时禁用此处指定的repo

            --enablerepo=repoidglob:临时启用此处指定的repo

            --noplugins:禁用所有插件

            

        command:   

            repolist      显示仓库列表

            list          显示程序包

            install       安装程序包

            reinstall     重新安装

            update        升级程序包

            downgrade     降级程序包

            check-update  检查可用升级

            remove|erase  卸载程序包

            info          查看程序包information

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

            clean         清理本地缓存

            makecache     构建缓存

            search        搜索

            deplist       查看指定包所依赖的capabilities

            localinstall  安装本地程序包(不使用了,用install)

            localupdate   升级本地程序包(不使用了,用update)

            history [info|list|packages-list|packages-info|summary|addon-info|redo|undo|rollback|new|sync|stats]   查看yum事务历史:


            groupinstall group1 [group2] [...]      包组管理的相关命令:

            groupupdate group1 [group2] [...]

            grouplist [hidden] [groupwildcard] [...]

            groupremove group1 [group2] [...]

            groupinfo group1 [...]

            


如何使用光盘当作本地yum仓库:

    (1) 挂载光盘至某目录,例如/media/cdrom

        # mount -r -t iso9660 /dev/cdrom /media/cdrom

    (2) 创建配置文件

        [CentOS7]

        name=

        baseurl=

        gpgcheck=

        enabled=


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

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

    $arch: 平台;

    $basearch:基础平台;

    $YUM0-$YUM9


    http://mirrors.magedu.com/centos/$releasever/$basearch/os


创建yum仓库:

    createrepo [options] <directory>


        

**************************************************************************************        

        

程序包编译安装:

testapp-VERSION-release.src.rpm --> 安装后,使用rpmbuild命令制作成二进制格式的rpm包,而后再安装;


源代码 --> 预处理 --> 编译(gcc) --> 汇编 --> 链接 --> 执行


源代码组织格式:

    多文件:文件中的代码之间,很可能存在跨文件依赖关系;


    C、C++: make (configure --> Makefile.in --> makefile)

    java: maven



编译C源代码:

    前提:提供开发工具及开发环境

        开发工具:make, gcc等

        开发环境:开发库,头文件

            glibc:标准库


        通过“包组”提供开发组件

            CentOS 6: "Development Tools", "Server Platform Development",


    第一步:configure脚本

        选项:指定安装位置、指定启用的特性


        --help: 获取其支持使用的选项

            选项分类:

                安装路径设定:

                    --prefix=/PATH/TO/SOMEWHERE: 指定默认安装位置;默认为/usr/local/

                    --sysconfdir=/PATH/TO/SOMEWHERE:配置文件安装位置;


                System types:


                Optional Features: 可选特性

                    --disable-FEATURE

                    --enable-FEATURE[=ARG]


                Optional Packages: 可选包

                    --with-PACKAGE[=ARG]

                    --without-PACKAGE


    第二步:make


    第三步:make install


安装后的配置:

    (1) 导出二进制程序目录至PATH环境变量中;

        编辑文件/etc/profile.d/NAME.sh

            export PATH=/PATH/TO/BIN:$PATH


    (2) 导出库文件路径

        编辑/etc/ld.so.conf.d/NAME.conf

            添加新的库文件所在目录至此文件中;


        让系统重新生成缓存:

            ldconfig [-v]


    (3) 导出头文件

        基于链接的方式实现:

            ln -sv 


    (4) 导出帮助手册

        编辑/etc/man.config文件

            添加一个MANPATH


    练习:

     1、yum的配置和使用;包括yum repository的创建;

     2、编译安装apache 2.2; 启动此服务;

        

        

DNF新一代的RPM软件包管理器。他首先出现在 Fedora 18 这个发行版中。而最近,他取代了YUM,正式成为 Fedora 22 的包管理器。


DNF包管理器克服了YUM包管理器的一些瓶颈,提升了包括用户体验,内存占用,依赖分析,运行速度等多方面的内容。


DNF使用 RPM, libsolv 和 hawkey 库进行包管理操作。尽管它没有预装在 CentOS 和 RHEL 7 中,但你可以在使用 YUM 的同时使用 DNF 。


DNF 的最新稳定发行版版本号是 1.0,发行日期是2015年5月11日。 这一版本的额 DNF 包管理器(包括在他之前的所有版本) 都大部分采用 Python 编写,发行许可为GPL v2.



Dependency resolution of YUM is a nightmare and was resolved in DNF with SUSE library ‘libsolv’ and Python wrapper along with C Hawkey.

YUM don’t have a documented API.

Building new features are difficult.

No support for extensions other than Python.

Lower memory reduction and less automatic synchronization of metadata �C a time taking process.


你可能感兴趣的:(数据库,管理程序)