亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Linux程序包管理(CentOS)

發布時間:2020-06-28 12:42:14 來源:網絡 閱讀:385 作者:_R1cky_ 欄目:數據庫

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

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

程序包管理器:

debian:deb, dpt

redhat: rpm, rpm

rpm: Redhat Package Manager(RPM is Package Manager)

    
源代碼:name-VERSION.tar.gz

VERSION: major.minor.release


rpm包命名方式:

name-VERSION-release.arch.rpm

VERSION: major.minor.release

release:OS

常見的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-ARHC.rpm


包之間:存在依賴關系

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:不檢查包完整性

--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: 強行升級

Notes:

(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


卸載:

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


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

完整性驗正:SHA256

來源合法性驗正:RSA


導入所需要公鑰:

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

CentOS 7發行版光盤提供的密鑰文件:RPM-GPG-KEY-CentOS-7


數據庫重建:

rpm {--initdb|--rebuilddb}

initdb: 初始化

如果事先不存在數據庫,則新建之;否則,不執行任何操作

rebuilddb:重建

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


rpm命令小結:
        安裝:-ivh, --nodeps, --replacepkgs
        卸載:-e, --nodeps
        升級:-Uvh, -Fvh, --nodeps, --oldpackage
        查詢:-q, -qa, -qf, -qi, -qd, -qc, -q --scripts, -q --changlog, -q --provides, -q --requires
        校驗:-V

        導入GPG密鑰:--import, -K, --nodigest, --nosignature
        數據庫重建:--initdb, --rebuilddb


yum程序包管理:

YUM: yellow dog, Yellowdog Update Modifier

yum repository: yum repo

存儲了眾多rpm包,以及包的相關的元數據文件(放置于特定目錄下:repodata)

文件服務器:

ftp://、http://、nfs://、file:///

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命令的用法:yum [options] [command] [package ...]

顯示倉庫列表:

repolist [all|enabled|disabled]

顯示程序包:

list

# yum list [all | glob_exp1] [glob_exp2] [...]

# yum list {available|installed|updates} [glob_exp1] [...]

安裝程序包:

install package1 [package2] [...]

reinstall package1 [package2] [...]  (重新安裝)

升級程序包:

update [package1] [package2] [...]

downgrade package1 [package2] [...] (降級)

檢查可用升級:

check-update

卸載程序包:

remove | erase package1 [package2] [...]

查看程序包information:

info [...]

查看指定的特性(可以是某文件)是由哪個程序包所提供:

provides | whatprovides feature1 [feature2] [...]

清理本地緩存:

clean [ packages | metadata | expire-cache | rpmdb | plugins | all ]

構建緩存:

makecache

搜索:

search string1 [string2] [...]

以指定的關鍵字搜索程序包名及summary信息

查看指定包所依賴的capabilities:

deplist package1 [package2] [...]

查看yum事務歷史:

history [info|list|packages-list|packages-info|summary|addon-info|redo|undo|rollback|new|sync|stats]

安裝及升級本地程序包:

localinstall rpmfile1 [rpmfile2] [...] (maintained for legacy reasons only - use install)

localupdate rpmfile1 [rpmfile2] [...] (maintained for legacy reasons only - use update)

包組管理的相關命令:

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的命令行選項:

--nogpgcheck:禁止進行gpg check

-y: 自動回答為“yes”

-q:靜默模式

--disablerepo=repoidglob:臨時禁用此處指定的repo

--enablerepo=repoidglob:臨時啟用此處指定的repo

--noplugins:禁用所有插件

yum的repo配置文件中可用的變量

$releasever: 當前OS的發行版的主版本號

$arch: 平臺

$basearch:基礎平臺

創建yum倉庫:

createrepo [options] <directory>


程序包編譯安裝:

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

源代碼 --> 預處理 --> 編譯(gcc) --> 匯編 --> 鏈接 --> 執行

源代碼組織格式:

多文件:文件中的代碼之間,很可能存在跨文件依賴關系

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

C代碼編譯安裝三步驟:

./configure:

(1) 通過選項傳遞參數,指定啟用特性、安裝路徑等;執行時會參考用戶的指定以及Makefile.in文件生成makefile

(2) 檢查依賴到的外部環境;

make:

根據makefile文件,構建應用程序

make install

移動應用程序到指定位置


開發工具:

autoconf: 生成configure腳本

automake:生成Makefile.in

建議:安裝前查看INSTALL,README


開源程序源代碼的獲取:

官方自建站點:

apache.org (ASF)

mariadb.org

...

代碼托管:

SourceForge

Github.com

code.google.com


c/c++: gcc (GNU C Complier)

編譯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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

济源市| 孟连| 正定县| 扶绥县| 朝阳市| 沂南县| 咸阳市| 饶平县| 浦北县| 星子县| 长兴县| 唐海县| 洛南县| 都昌县| 高清| 鄢陵县| 安新县| 江川县| 张家界市| 治县。| 义乌市| 马尔康县| 辉县市| 吴堡县| 宜黄县| 荥经县| 平定县| 西充县| 庐江县| 盐源县| 遵义市| 霍城县| 东至县| 富平县| 恭城| 营口市| 万安县| 新沂市| 新晃| 洛川县| 荣成市|