rpm包及rmp命令詳解

一、軟件運行環境

         ? API: Application Programming Interface

             國際標準 POSIX: Portable OS

        ?執行流程: 程序源代碼 –> 預處理 –> 編譯 –> 匯編 –> 鏈接

    

            靜態編譯:將編譯完成的程序代碼以及所依賴的庫文件一起打包使用

            共享(動態)編譯:使用獨立的外置的庫文件,與系統中的其他程序共享庫,linux 中以 .so結尾,譯為共享對象

    

        ? ABI: Application Binary Interface 應用程序二進制接口

            (Windows與Linux的ABI不兼容)

            linux: ELF(Executable and Linkable Format)

            windows:PE( Portable Executable)

        庫級別的虛擬化:

            Linux: WINE

            Windows: Cywin

二、C程序編譯過程

C編譯過程.JPG

三、Java程序運行

java運行過程.JPG

三、開發語言

                ? 系統級開發

                    C

                    C++

                ? 應用級開發

                    java

                    delphi

                    Python

                    go

                    php

                    perl

                    ruby

四、包管理器

                ?二進制應用程序的組成部分:

                    二進制文件、庫文件、配置文件、幫助文件

                

                ?程序包管理器:

                    debian: deb文件, dpkg包管理器

                    redhat: rpm文件, rpm包管理器

                    rpm: Redhat Package Manager

                    RPM Package Manager

               

        包命名

            ? 源代碼: 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, amd64

            powerpc: 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

        (當安裝時需要依賴庫時,需要手動在conf文件中加入依賴庫的路徑,然后用ldconifg,讀取庫的地址到緩存中,以供安裝時候調用)

    包管理器

        ? 程序包管理器:

            功能:將編譯好的應用程序的各組成文件打包一個或幾個

            程序包文件,從而方便快捷地實現程序包的安裝、卸載、查詢、

            升級和校驗等管理操作

        ? 1、包文件組成 (每個包獨有)

            RPM包內的文件

            RPM的元數據,如名稱,版本,依賴性,描述等

            安裝或卸載時運行的腳本 (非官方包,則應特別注意此腳本,確認無誤才安裝)

        ? 2、數據庫(公共)

            程序包名稱及版本

            依賴關系

            功能說明

            包安裝后生成的各文件路徑及校驗碼信息

    程序包的來源

        ? 管理程序包的方式:

            使用包管理器: rpm

            使用前端工具: yum, dnf

        ? 獲取程序包的途徑:

            (1) 系統發版的光盤或官方的服務器;

                CentOS鏡像:

                https://www.centos.org/download/

                http://mirrors.aliyun.com

                http://mirrors.sohu.com

                http://mirrors.163.com

            (2) 項目官方站點

             (3) 第三方組織:

                Fedora-EPEL:

                Extra Packages for Enterprise Linux

                Rpmforge:RHEL推薦,包很全

            搜索引擎:

                    http://pkgs.org

                    http://rpmfind.net

                    http://rpm.pbone.net

                    https://sourceforge.net/

          ? (4) 自己制作

            ? 注意:檢查其合法性: 來源合法性,程序包的完整性

    rpm包管理

        ? CentOS系統上使用rpm命令管理程序包:

        安裝、卸載、升級、查詢、校驗、數據庫維護

           

          安裝:

            rpm {-i|–install} [install-options] PACKAGE_FILE…

            -v: verbose 顯示詳細信息

            -vv: 顯示更詳細的信息

            -ql  顯示包內容

            -h: 以#顯示程序包管理執行進度

            rpm -ivh PACKAGE_FILE …

            rpm包安裝

                ? [install-options]

                –test: 測試安裝,但不真正執行安裝; dry run模式

                –nodeps:忽略依賴關系

                –replacepkgs 替代、覆蓋安裝 |   replacefiles  安裝包、版本等不同,但是生成的

                    系統內容一樣,覆蓋安裝

                –nosignature: 不檢查來源合法性

                –nodigest:不檢查包完整性

                –noscipts:不執行程序包腳本片斷

                %pre: 安裝前先運行腳本; –nopre

                %post: 安裝后腳本; –nopost

                %preun: 卸載前腳本; –nopreun

                %postun: 卸載后腳本; –nopostun

    16

            rpm包升級

              ? 升級:

                ? rpm {-U|–upgrade} [install-options] PACKAGE_FILE…

                ? rpm {-F|–freshen} [install-options] PACKAGE_FILE…

                upgrade:安裝有舊版程序包,則“升級”

                如果不存在舊版程序包,則“安裝”

                freshen:安裝有舊版程序包,則“升級”

                如果不存在舊版程序包,則不執行升級操作

                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 rpmfile:針對尚未安裝的程序包文件做查詢操作;

                    –whatprovides CAPABILITY:查詢指定的CAPABILITY

                                    由哪個包所提供

                    –whatrequires CAPABILITY:查詢指定的CAPABILITY被

                                哪個包所依賴

                ? rpm2cpio 包文件|cpio –itv 預覽包內文件

                ? rpm2cpio 包文件|cpio –id “ *.conf” 釋放包內文件

            包查詢

                ? [query-options]

                    –changelog:查詢rpm包的changelog

                    -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

    22

    

                ? 包來源合法性驗正及完整性驗正:

                    完整性驗正: SHA256

                    來源合法性驗正: RSA

                ? 公鑰加密:

                    對稱加密:加密、解密使用同一密鑰;

                    非對稱加密:密鑰是成對兒的

                    public key: 公鑰,公開所有人

                    secret key: 私鑰, 不能公開

                ? 導入所需要公鑰:

                    rpm -K|checksig rpmfile 檢查包的完整性和簽名

                    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:重建

                    無論當前存在與否,直接重新創建數據庫

   

原創文章,作者:ldt195175108,如若轉載,請注明出處:http://www.www58058.com/37308

(0)
ldt195175108ldt195175108
上一篇 2016-08-22 09:29
下一篇 2016-08-22 09:29

相關推薦

  • 很認真的第十三周作業哦

    1、建立samba共享,共享目錄為/data,要求:(描述完整的過程) mkdir /data #建立共享目錄 1)共享名為shared,工作組為magedu vim /etc/samba/smb.conf 修改 workgroup = MYGROUP 為 workgroup = magedu 修改 passdb backend = tdbsam 為 pas…

    Linux干貨 2017-03-27
  • shell腳本編程之補充知識點

    一、處理用戶輸入   shell中使用read命令來實現與用戶的交互輸入。   格式:read [options] 變量    常用選項:      -p “提示信息”:顯示提示信息;      -t #:等待用戶輸入的秒數;     &n…

    Linux干貨 2016-02-14
  • 子網掩碼快速劃分-心算

    問題狀況: 不管作為一名網絡工程師還是一名運維工程師,快速心算劃分出網絡掩碼是必備得技能, ???? 為什么要進行子網掩碼劃分? 純二層環境不能隔離廣播 有安全 管理方面的問題 解決辦法:在二層環境下增加三層設備 將原本的一個主類網絡號劃分成多個子網 ? ? 掩碼基礎知識: ????注意:此步沒記住不要往下進行 ????死記硬背1: ????2^0=1 ??…

    Linux干貨 2017-03-26
  • Linux磁盤和文件系統基礎

    概述     Linux系統上,磁盤要正常的進行數據的存儲,需要先進行分區,再進行格式化生成文件系統,最后掛載到某個目錄下,才能進行正常的數據存取,本篇就介紹一下磁盤從分區到正常使用的幾個步驟,具體分為以下幾個部分:     1、磁盤的基礎概念   &nbsp…

    Linux干貨 2016-08-29
  • linux的tty

    原創作品,允許轉載,轉載時請務必以超鏈接形式標明文章 原始出處 、作者信息和本聲明。否則將追究法律責任。http://jeffyyko.blog.51cto.com/28563/140012 最近做了一個小測試,得到了以下結論 測試linux發行版本:rhel AS4.0 環境:VMware 5.0 目的:修改 vi /etc/initt…

    Linux干貨 2015-03-26
  • sed簡介及常見用法

    sed是一個文本流處理器,配合正則表達式用可以實現很多文本處理操作。 和grep一樣,sed是一行一行的處理的。sed處理文本時,首先會將源文件復制一份到內存中,然后將文本一行一行拿到模式空間內進行操作,最后輸出到標準輸出,即屏幕上。 在模式空間中,每一行都會根據用戶給的條件進行匹配,匹配到了進行編輯后輸出,沒有匹配到,直接輸出到標準輸出。sed除了模式空間…

    2018-01-04
欧美性久久久久