软件包管理(rpm篇)

软件包管理(rpm篇)
静态和动态链接
    链接主要作用是把各个模块之间相互引用的部分处理好,使得各个模块之间能够正确地衔接,分为静态链接和动态链接
    静态链接
        把程序对应的依赖库复制一份到包
        libxxx.a
        嵌入程序包
        升级难,需重新编译
        占用较多空间,迁移容易
    动态链接
        只把依赖加做一个动态链接
        libxxx.so
        “连接指向”
        占用较少空间,升级方便
包命名
源代码:name-VERSION.tar.gz|bz2|xz
         VERSION: major.minor.release
    rpm包命名方式:
          name-VERSION-release.arch.rpm
   例:bash-4.2.46-19.el7.x86_64.rpm
       VERSION: major.minor.release
       release:release.OS
       常见的arch:
        x86: i386, i486, i586, i686
        x86_64: x64, x86_64, amd64powerpc: ppc
        跟平台无关:noarch
包:分类和拆包
    Application-VERSION-ARCH.rpm: 主包
    Application-devel-VERSION-ARCH.rpm开发子包
    Application-utils-VERSION-ARHC.rpm其它子包
    Application-libs-VERSION-ARHC.rpm其它子包
包之间:可能存在依赖关系,甚至循环依赖
解决依赖包管理工具:
    yum:rpm包管理器的前端工具
    apt-get:deb包管理器前端工具
    zypper: suse上的rpm前端管理工具
    dnf: Fedora 18+ rpm包管理器前端管理工具        
库文件
    查看二进制程序所依赖的库文件
ldd/PATH/TO/BINARY_FILE
    管理及查看本机装载的库文件
ldconfig
/sbin/ldconfig-p: 显示本机已经缓存的所有可用库文件名及文件路径映射关系
配置文件:/etc/ld.so.conf, /etc/ld.so.conf.d/.conf
缓存文件:/etc/ld.so.cache
包管理器
    程序包管理器:
    功能:将编译好的应用程序的各组成文件打包一个或几个程序包文件,从而方便快捷地实现程序包的安装、卸载、查询、升级和校验等管理操作
    1、包文件组成(每个包独有)
    RPM包内的文件
    RPM的元数据,如名称,版本,依赖性,描述等
    安装或卸载时运行的脚本
    2、数据库(公共):/var/lib/rpm
    程序包名称及版本
    依赖关系
    功能说明
包安装后生成的各文件路径及校验码信息
    管理程序包的方式:
    使用包管理器:rpm
    使用前端工具:yum, dnf
rpm包管理
  CentOS系统上使用rpm命令管理程序包:
  安装、卸载、升级、查询、校验、数据库维护
安装:
    rpm {-i|–install} [install-options] PACKAGE_FILE…
    -v: verbose
    -vv:
    -h: 以#显示程序包管理执行进度
    rpm -ivhPACKAGE_FILE …
    rpm包安装
   [install-options]
    –test: 测试安装,但不真正执行安装,即dry run模式
    –nodeps:忽略依赖关系
    –replacepkgs| replacefiles
    –nosignature: 不检查来源合法性
    –nodigest:不检查包完整性
    –noscripts:不执行程序包脚本
    %pre: 安装前脚本;–nopre
    %post: 安装后脚本;–nopost
    %preun: 卸载前脚本;–nopreun
    %postun: 卸载后脚本;–nopostun
rpm包升级
升级:
    rpm {-U|–upgrade} [install-options] PACKAGE_FILE…
    rpm {-F|–freshen} [install-options] PACKAGE_FILE…
    upgrade:安装有旧版程序包,则“升级”
                  如果不存在旧版程序包,则“安装”
    freshen:安装有旧版程序包,则“升级”
                 如果不存在旧版程序包,则不执行升级操作
    rpm -UvhPACKAGE_FILE …
    rpm -FvhPACKAGE_FILE …
    –oldpackage:降级
    –force: 强制安装
包查询
    rpm {-q|–query} [select-options] [query-options]
    [select-options]
     -a: 所有包
     -f: 查看指定的文件由哪个程序包安装生成
     -p rpmfile:针对尚未安装的程序包文件做查询操作
     –whatprovidesCAPABILITY:查询指定的CAPABILITY由哪个包所提供
     –whatrequiresCAPABILITY:查询指定的CAPABILITY被哪个包所依赖
    rpm2cpio 包文件|cpio–itv预览包内文件
    rpm2cpio 包文件|cpio–id “
.conf”释放包内文件
    [query-options]
     –changelog:查询rpm包的changelog
  c卸载后脚本;–nopostun: 查询程序的配置文件
     -d: 查询程序的文档
     -i: information
     -l: 查看指定的程序包安装后生成的所有文件
     –scripts:程序包自带的脚本
     –provides: 列出指定程序包所提供的CAPABILITY
     -R: 查询指定的程序包所依赖的CAPABILITY
  常用查询用法:
     -qi PACKAGE, -qfFILE, -qc PACKAGE, -qlPACKAGE, -qdPACKAGE
     -qpiPACKAGE_FILE, -qplPACKAGE_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 mTimediffers
    P capabilities differ     
包来源合法性验正及完整性验正
    完整性验正:SHA256
    来源合法性验正:RSA
公钥加密
    对称加密:加密、解密使用同一密钥
    非对称加密:密钥是成对儿的
    public key: 公钥,公开所有人
    secret key: 私钥, 不能公开
导入所需要公钥
    rpm -K|checksigrpmfile检查包的完整性和签名
    rpm –import /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
    CentOS 7发行版光盘提供:RPM-GPG-KEY-CentOS-7
    rpm -qa“gpg-pubkey*”
    rpm数据库
数据库重建:
    /var/lib/rpm
    rpm {–initdb|–rebuilddb}
    initdb: 初始化
    (如果事先不存在数据库,则新建之否则,不执行任何操作)
    rebuilddb:重建已安装的包头的数据库索引目录

原创文章,作者:木,如若转载,请注明出处:http://www.178linux.com/74084

(0)
上一篇 2017-04-24 19:15
下一篇 2017-04-24 19:37

相关推荐

  • 如何成为一名软件架构师

    Daniel Mohl是一名专业的软件工程师/架构师,他的兴趣包括理解各种复杂的编程语言、企业应用架构以及如何搭建业务与技术,他通晓F#、C#、CoffeeScript、JavaScript、Erlang、ASP.NET、MVC、WPF、WCF、Sliverlight、SQL Server等技术。有着多年的软件开发经验。 他经常会被一些有潜力和有前途的程序员…

    Linux干货 2016-03-22
  • 马哥教育N22期第八周作业

    1、请描述网桥、集线器、二层交换机、三层交换机、路由器的功能、使用场景与区别。 设备 功能 使用场景 区别 网桥 根据MAC地址来转发帧,本地通信只限本网段内, 相当于中继器,线路比较长保证信号不变形的传输 工作在物理层,相当于一个物理接口 集线器 接收到的数据包进行广播转发,所有端口都能收到此数据,通过MAC确认是不是发给自己的包进行回应 广播形式转发数据…

    Linux干货 2016-11-14
  • 脚本初学者

    期待已久的脚本终于在这一周学到了,对于脚本,我感觉就是有两点,第一:考验一个人的思维能力,如果能把你想要的结果用脚本正确的表示出来。第二:以前学的基础命令,怎么组合起来使用。达到以上两点,再难写的脚本都可以写出来的。 一、编写,执行一个脚本        脚本的格式  &nbsp…

    2017-08-05
  • 图解 lvs 工作原理

    一.lvs 基本工作流程介绍  如图1,ipvsadm定义lvs服务监听的ip和port,并发送给ipvs,而ipvs是工作在netfilter的input钩子上的程序,当input链中有目标ip属于lvs服务的请求报文时,ipvs就会修改该报文的链路,使其不进入用户空间而直接转到postrouting链上,并转发给其中一台real server,…

    Linux干货 2016-10-30
  • iptables 从入门到进阶

    Linux的防火墙体系主要工作在网络层,针对TCP/IP数据包实施过滤和限制,属于典型的包过滤防火墙(或网络层防火墙)。在Linux中netfilter和iptables都是指Linux防火墙。区别在于: netfilter:指的是Linux内核中实现包过滤防火墙的内部结构,不以程序或文件的形式存在,属于“内核态”的防火墙功能体系。 iptables:指的是…

    Linux干货 2017-01-10
  • test

    欢迎使用马克飞象 作业帮 示例笔记本 马克飞象 帮助 Markdown 马克飞象是一款专为印象笔记(Evernote)打造的Markdown编辑器,通过精心的设计与技术实现,配合印象笔记强大的存储和同步功能,带来前所未有的书写体验。特点概述: 功能丰富 :支持高亮代码块、LaTeX 公式、流程图,本地图片以及…

    Linux干货 2017-03-20

评论列表(1条)

  • renjin
    renjin 2017-04-28 12:05

    详细的介绍了rpm包的安装使用,内容总结的很详细,也可以适当的加入一些实验流程进来,注意一下排版