API:Application Programming Interface

  POSIX:Portable OS

  程序源代码 --> 预处理 --> 编译 --> 汇编 --> 链接

  静态编译:

  共享编译:.so

ABI:Application Binary Interface

  Windows与Linux不兼容

  库级别的虚拟化:

    Linux:WINE

    Windows:Cywin

系统级开发

  C

  C++

应用级开发

  jave

  Python

  php   

二进制应用程序的组成部分:

  二进制文件、库文件、 配置文件、帮助文件

  程序包管理器:

   debian:deb,dpt

      redhat:rpm,rpm

    rpm:Redhat Package Manager

      RPM is Package Manager

    Gentoo

    Archlinux

源代码:name-VERSION.tar.gz

  VERSION:major.minor.release

rpm包命令方式:

  name-VERSION-ARCH.rpm

    VERSION:major.minor.release

    ARCH:release.os.arch

    zlib-1.2.7-13.e17.i686.rpm

    常见的arch:

      x86:i386,i486,i586,i686

      x86_64:x64,x86_64,amd64

      powerpc:ppc

      跟平台无关:noarch

  testapp:拆包

    testapp-VERSION-ARCH.rpm:主包

    testapp-devel-VERSION-ARCH.rpm:支包

    testapp-testing-VERSION-ARCH.rpm

  包之间:存在依赖关系

    X,Y,Z

    yum:rpm包管理器的前端工具;

    apt-get:deb包管理器前端工具;

    zypper:suse上的rpm前端管理工具;

    dnf:Fedora 22+ 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、程序的组成清单(每个包独有)

    文件清单

    安装或卸载时运行的脚本

  2、数据库(公共)

    程序包名称及版本

    依赖关系;

    功能说明;

    安装生成的各文件的文件路径及校验码信息;

管理程序包的方式:

  使用包管理器:rpm

  使用前端工具:yum,dnf

获取程序包的途径:

  (1)系统发行版的光盘或官方的服务器;

    CentOS镜像:

      http://mirrors.aliyun.com

      http://mirrors.sohu.com

      http://mirrors.163.com

  (2)项目官方站点

  (3)第三方组织:

    Fedora-EPEL

    搜索引擎:

      http://pkgs.org

      http://rpmfind.net

      http://rpm.pbone.net

  (4)自己制作

建议:检查其合法性

  来源合法性;

  程序包的完整性;

CentOS系统上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:不检查包完整性;

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

            %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:查看指定的文件由哪个程序包安装生成

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

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

    [qurey-options]

      --changelog:查询rpm包的changelog

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

      -d:查询程序的文档

      -i:information 查询一个程序包的简要信息;

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

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

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

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

    用法:

      -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

  包来源合法性验证及完整性验证:

    完整性验证:

    公钥加密:

      对称加密:加密、解密使用同一密钥;

      非对称加密:密钥是成对儿的;

        public key:公钥,公开所胡人

        secret key:私钥,不能公开

    导入所有需要公钥:

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

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

  

  数据库重建:

    rpm {--initdb|--rebuilddb}

      initdb:初始化

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

      rebuilddb:重建

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

Linux:Day9(下) 程序包管理的更多相关文章

  1. Linux下程序包管理工具RPM

    实验环境: CentOS release 6.6 (Final)  一台 IP地址:172.16.249.230 RPM 是 Red Hat Package Manager 的缩写,本意是Red Ha ...

  2. Linux:Day10 程序包管理

    YUM:yellow dog,Yellowdog Update Modifier yum repository:yum repo 存储了众多rpm包,以及包的相关的无数据文件(放置于特定目录下:rep ...

  3. linux基础之程序包管理(rpm,yum)

    一.rpm 安装:rpm { -i | --install } [ install-options ] PACKAGE_FILE... -v: 显示安装时的详细信息 -vv: 显示许多难以阅读的调试信 ...

  4. Linux程序包管理之yum及源代码安装

    第十六章.Linux程序包管理之yum及源代码安装 目录 yum介绍 yum配置文件 yum的repo配置文件中可用的变量 yum命令的使用 使用光盘作为本地yum仓库 如何创建yum仓库 编译安装的 ...

  5. Linux程序包管理rpm与yum

    Linux程序包管理 Linux中软件的安装主要有两种形式:一种是直接下载源代码包自行编译后安装,另一种直接获取rpm软件包进行安装. 程序的组成部分: 二进制程序:程序的主体文件,比如我们运行一个l ...

  6. Linux 程序包管理-RPM

    程序简介:  POSIX(Portable Openratin System)跨平台系统:不同操作系统平台的标准C库(glibc)都是遵循POSIX规范的,这样基于标准库开发程序的源代码可以夸平台编译 ...

  7. 【程序包管理】篇章3:CentOS平台下软件包安装方法总结

    1.软件包安装前的学习:程序包管理的基础知识 2.程序包安装的方法介绍: rpm文件的二进制包安装:Linux程序包管理之rpm安装总结 yum安装:Linux程序包管理之yum源安装 链接:本地yu ...

  8. Linux 程序包管理-YUM

    前端工具YUM管理程序包:  rpm管理软件虽然方便,但是需要手工解决软件包的依赖关系:很多时候安装一个软件需要首先安装一个或多个(有时多达上百个)其它软件,手工解决很复杂:使用yum可以解决这个问题 ...

  9. Linux程序包管理初步-rpm的使用

    在Linux系统上,一般而言,对于程序包管理器来说分为三类: debian:dpt,dpkg;             (程序包后缀.deb) rhel:rpm (程序包后缀.rpm) suse:rp ...

随机推荐

  1. 汇编语言--微机CPU的指令系统(五)(标志位操作指令)

    (2)标志位操作指令 标志位操作指令是一组对标志位置位.复位.保存和恢复等操作的指令. 1.进位CF操作指令 Ø 清进位指令CLC(Clear Carry Flag):CF←0 Ø 置进位指令STC( ...

  2. c3p0链接池配置使用

    c3p0链接池初步使用:直接上代码 c3p0是开源面粉的连接池,目前使用它的开源项目主要有:Spring,Hibernate等,使用时需要导入相关jar包及配置文件c3p0-config.xml文件 ...

  3. Ansible playbook roles

    1  概述 角色(roles):如果我们使用playbook写成一个文件,这个文件会很大,但是不方便组织,我们可以分组,把playbook根据功能,如handler,tasks等分门别类的放在在各自的 ...

  4. 人类阅读的优越方式打印php数组

    在程序开发过程中:打印数据进行查看调试是非常频繁的:如果没有一种易于阅读的样式那是相当痛苦的:先定义一个数组: $array=array( 't0'=>'test0', 't1'=>'te ...

  5. vue从入门到进阶:计算属性computed与侦听器watch(三)

    计算属性computed 模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的.在模板中放入太多的逻辑会让模板过重且难以维护.例如: <div id="example" ...

  6. C# 利用SharpPcap实现网络包捕获嗅探

    本文是利用SharpPcap实现网络包的捕获的小例子,实现了端口监控,数据包捕获等功能,主要用于学习分享. 什么是SharpPcap? SharpPcap 是一个.NET 环境下的网络包捕获框架,基于 ...

  7. 口碑订单,ERP本地加/退菜无法回流至手机端的解决办法-订单金额不统一erp本地加菜H5没有

    关于 口碑订单,ERP本地加/退菜无法回流至手机端的解决办法-订单金额不统一erp本地加菜H5没有 1. 2. 3. PS:是正餐后付的务必要选择口碑后付 完成以上设置即可

  8. Percona XtraBackup 备份还原篇

    Percona XtraBackup 安装介绍篇已经对Percona XtraBackup的功能和安装做了比较详细的介绍,那么本篇我们直接进入主题,如何使用XtraBackup做备份.还原,下面主要介 ...

  9. SQL Server中sp_spaceused统计数据使用的空间总量不正确的原因

    很多时候,我们经常使用sp_spaceused来查看表的空间使用情况,上个月群里有个网友说他使用DELETE删除了数据后,使用sp_spaceused查看,发现该表的分配的空间总量(reserved) ...

  10. 完全数java

    完全数:小于本身的所有因子的和(包括1) public class test01 { public static void main(String[] args) { Scanner scanner= ...