linux程序包管理
安裝軟件主要有兩種方式:
API:Application Programming Interface
POSIX:Portable OS
程序源代碼 --> 預處理 --> 編譯 --> 彙編 --> 鏈接
靜態編譯:
共享編譯:.so
ABI:Application Binary Interface,而在Windows與Linux不兼容,
rpm的組成方式:二進制文件、庫文件、配置文件、幫助文件
查看二進制程序所依賴的庫文件:ldd /PATH/TO/BINARY_FILE
程序包管理:
功能:將編譯好的應用程序的各組成文件打包一個或幾個程序包文件,從而方便快捷地實現程序包的安裝、卸載、查詢、升級和校驗等管理操作;
1、程序的組成組成清單 (每個包獨有)
文件清單
安裝或卸載時運行的腳本
2、數據庫(公共)
程序包名稱及版本
依賴關係;
功能說明;
安裝生成的各文件的文件路徑及校驗碼信息;
獲取程序包的途徑:
(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: 強行升級;
注意:(1) 不要對內核做升級操作;Linux支持多內核版本並存,因此,對直接安裝新版本內核;
(2) 如果原程序包的配置文件安裝後曾被修改,長級時,新版本的提供的同一個配置文件並不會直接覆蓋老版本的配置文件,而把新版本的文件重命名(FILENAME.rpmnew)後保留;
查詢:如果想查詢那個包,我們常用-qa查看,-ql查詢包安裝的路徑,-qi查詢安裝包的所有信息。這裏就簡單說一下查詢的一些常用的用法以及選項,我們可以多使用man 命令查詢想要的結果,這樣以後工作基本沒有中文給你看,所以我建議看過我這個,你也學會多看看man幫助工具的一些信息。
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
包來源合法性驗正及完整性驗正:
完整性驗正:SHA256
來源合法性驗正:RSA
公鑰加密:
對稱加密:加密、解密使用同一密鑰;
非對稱加密:密鑰是成對兒的,
public key: 公鑰,公開所有人
secret key: 私鑰, 不能公開
導入所需要公鑰:
rpm --import /PATH/FROM/GPG-PUBKEY-FILE
CentOS 7發行版光盤提供的密鑰文件:RPM-GPG-KEY-CentOS-7
數據庫重建:
rpm {--initdb|--rebuilddb}
initdb: 初始化
如果事先不存在數據庫,則新建之;否則,不執行任何操作;
rebuilddb:重建
無論當前存在與否,直接重新創建數據庫;
yum
Yum(全稱爲 Yellow dog Updater, Modified)是一個在Fedora和RedHat以及CentOS中的Shell前端軟件包管理器。基於RPM包管理,能夠從指定的服務器自動下載RPM包並且安裝,可以自動處理依賴性關係,並且一次安裝所有依賴的軟件包,無須繁瑣地一次次下載、安裝。
yum倉庫衆多rpm包,以及包的相關的元數據文件(放置於特定目錄下:repodata)
yum服務文件有多種,而我們常見的有如下幾種:
ftp://
http://
nfs://
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
安裝程序包:
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= -->這裏是自己想要配置的那個名字:例如想要配置【base】
baseurl= -->這裏只得是url的路徑,
gpgcheck= -->這裏問要不要檢查更新,一般如果不檢查寫“0”或者檢查寫“1”
enabled= -->這裏我們選擇啓用,如果不啓用,那我們根本不能啓用想要配置好的yum源。這裏之間等於‘1’,
yum的命令行選項:
--nogpgcheck:禁止進行gpg check;
-y: 自動回答爲“yes”;
-q:靜默模式;
--disablerepo=repoidglob:臨時禁用此處指定的repo;
--enablerepo=repoidglob:臨時啓用此處指定的repo;
--noplugins:禁用所有插件;
如果想配置一個本地的yum源,那麼這裏提供一點詳細的步驟:
第一步:先來創建一個我們的本地文件,必須要在/media目錄下,
cd /media
mkdir /cdrom
接下來我們把/dev/cdrom直接掛載/media/cdrom上
mount /dev/cdrom /media/cdrom
cd /media/cdrom
接下來我們在我倉庫
cd /etc/yum.repos.conf這裏是我們的倉庫配置文件
這裏面基本的倉庫文件我們都用不到,我們可以刪除,也可以把它放在一邊不管,直接創建一個指定的來配置
mkdir media.repo
編輯剛創建好的,vim media.repo文件,這裏我們來配置base文件
[base]
name=base
baseurl=
gpgcheck=0
enabled=1
這樣我們編輯好了。如果這裏沒編輯成功,那麼你可以直接可以去編輯/etc/fstab這個文件
現在我們來簡單說一下編譯安裝的幾個步驟,(前提要準備我們的開發壞境)
第一步: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