您好,登錄后才能下訂單哦!
怎么在CentOS中使用rpm包管理器?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
RPM包的命名
例如,bash-4.3.2-1.centos6.x86_64.rpm
rpm的應用
安裝
代碼如下:
rpm {-i|--install} [install-options] PACKAGE_FILE ...
-i 安裝
-v 顯示詳細信息,可疊加使用查看更加詳細信息,如-vv,-vvv
-h 顯示進度,用50個#來作為進度條
我們一般組合使用-ivh來安裝rpm包
--nodeps 取消依賴關系
--replacepkgs 重新安裝
--test 測試安裝,而不是真正安裝
舉例:
代碼如下:
[root@localhost ~]# rpm -ivh package.rpm
升級
rpm {-U|--upgrade} [install-options] PACKAGE_FILE ...
如果有較舊的版本程序包,則升級安裝;若沒有,則直接安裝
rpm {-F|--freshen} [install-options] PACKAGE_FILE ...
如果有較舊的版本程序包,則升級安裝;若沒有,則終止
我們一般組合使用-Uvh、-Fvh來安裝rpm包
[install-options]
--oldpackage 降級安裝
--force 忽略沖突,強制執行
注意:
不要對內核包執行升級操作;linux支持多版本內核并存,因此,對新版本內核可直接安裝;
如果原程序包的配置文件安裝后曾被改動,升級時,新版本的文件并不會直接覆蓋老版本的文件,而是把新版本的文件重命(加后綴.rpmnew)名后保留;
舉例:
代碼如下:
[root@localhost ~]# rpm -Uvh package.rpm
卸載
代碼如下:
rpm {-e|--erase} [--allmatches] [--nodeps] [--noscripts] [--notriggers] [--test] PACKAGE_NAME ...
--nodeps 忽略依賴關系
--test 卸載測試
舉例:
代碼如下:
[root@localhost ~]# rpm -ev package
查詢
代碼如下:
rpm {-q|--query} [select-options] [query-options]
[select-options]
1、查詢該包是否安裝
rpm -q PACKAGE_NAME...
2、查詢已安裝的所有包
rpm -qa
3、查詢某文件是由哪個包安裝生成
rpm -qf /path/to/somefile
4、查詢尚未安裝包的相關信息
rpm -qp PACKAGE_FILE
[query-options]
1、查詢某包的簡要說明信息
rpm -qi PACKAGE_NAME
2、查詢某包安裝后生成的所有文件列表
rpm -ql PACKAGE_NAME
3、查詢某包安裝后生成的所有配置文件列表
rpm -qc PACKAGE_NAME
4、查詢某包安裝后生成的所有幫助文件列表
rpm -qd PACKAGE_NAME
5、查詢某rpm包制作時隨版本變化的changelog列表信息
rpm -q --changelog PACKAGE_NAME
6、查詢某包提供的capabilities
rpm -q --provides PACKAGE_NAME
7、查詢某包所依賴的capabilities
rpm -q --requires PACKAGE_NAME
8、查詢某包安裝卸載時的腳本
rpm -q --scripts
安裝卸載時的腳本有四種:
preinstall: 安裝前執行的腳本
postinstall: 安裝后執行的腳本
preuninstall: 卸載前執行的腳本
postuninstall: 卸載后執行的腳本
舉例:
查詢系統中所有已安裝 RPM 包
代碼如下:
[root@localhost ~]# rpm -qa
查詢 RPM 包中包含的文件列表
代碼如下:
[root@localhost ~]# rpm -qlp package
查詢 RPM 包中包含的幫助文件列表
代碼如下:
[root@localhost ~]# rpm -qdp package
校驗
代碼如下:
rpm {-V|--verify} [select-options] [verify-options]
常用用法:rpm -V PACKAGE_NAME
文件改動后校驗會有下列相關信息提示:
5:文件的MD5校驗值
S:文件大小
L:鏈接文件
T:文件創建的時間
D:設備文件
U:文件的用戶
G:文件的用戶組
M:文件的權限
舉例:
先用vim對yum.conf文件進行修改,再進行校驗
代碼如下:
[root@localhost ~]# rpm -V yum.conf
S.5....T. c /etc/yum.conf
包來源合法性及完整性驗正
rpm --import PUBKEY ...
導入密鑰
rpm {-K|--checksig} [--nosignature] [--nodigest] PACKAGE_FILE ...
驗證密鑰
--nosignature: 不檢查來源合法性
--nodigest: 不檢查完整性
舉例:
代碼如下:
[root@localhost ~]# rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-*
[root@localhost ~]# rpm -k /var/ftp/pub/Server/kernel-PAE-2.6.18-194.el5.i686.rpm
/var/ftp/pub/Server/kernel-PAE-2.6.18-194.el5.i686.rpm: (sha1) dsa sha1 md5 gpg OK
公共數據庫:/var/lib/rpm
重建數據庫
代碼如下:
rpm {--initdb|--rebuilddb}
初始化:--initdb
如果事先不存在數據,則會新之;否則,不執行任何操作
重新構造:--rebuilddb
無論當前是否已經存在數據庫,都會直接重建并覆蓋現有數據庫
舉例:
代碼如下:
[root@localhost ~]# rpm --initdb
[root@localhost ~]# rpm --rebuilddb
yum: Yellow dog Updater,Modified
主要功能是更方便的添加/刪除/更新RPM包,它能自動解決包的倚賴性問題,便于管理大量系統的更新問題
使用rpm2cpio,cpio提取rpm包的中的特定文件
有些時候,我們需要提取rpm包中的一些文件,通過如下方法可以快速提取
首先查詢rpm包中的文件
代碼如下:
[root@taotips ~]# rpm -qpl anaconda-11.4.1.62-1.src.rpm
anaconda-11.4.1.62.tar.bz2
anaconda.spec
我們需要提取 anaconda-11.4.1.62.tar.bz2 這個文件,執行下面的命令,提取到當前目錄
代碼如下:
rpm2cpio anaconda-11.4.1.62-1.src.rpm | cpio -idv anaconda-11.4.1.62.tar.bz2
注意: cpio參數后的文件路徑 "anaconda-11.4.1.62.tar.bz2" 必須和前面查詢的相對路徑一樣,否則提取不成功。
相關知識說明
cpio參數說明:
-t 列出的意思,和"--list"等同,注意,此時列出的是“相對路徑”
-i 抽取的意思,和"--extract"等同
-d 建立目錄,和"--make-directories"等同
-v 冗余信息輸出,和"--verbose"等同
rpm參數說明:
-q --query 查詢
-l --list 列出
-f --file 指定文件
-p --package 指定rpm包
rpm 數據庫修復的方法
第一種方法:
當進行包安裝、升級、卸載等操作時,可能損壞RPM DB,需要通過--rebuild參數來修復RPM DB,但有時會碰到這樣的問題:
代碼如下:
[root@taotips lib]# rpm -v --rebuilddb
rpmdb: fatal region error detected; run recovery
error: db4 error(-30982) from dbenv->open: DB_RUNRECOVERY: Fatal error, run database recovery
error: cannot open Packages index
此時需要手動刪除/var/lib/rpm目錄下的類似 __db.* 的文件
代碼如下:
rm -fr /var/lib/rpm/__db*
然后再運行
代碼如下:
rpm -v --rebuilddb
即可.
第二種方法 :
代碼如下:
# cd /var/lib
# mv rpm rpm.old
# mkdir rpm
# rpmdb --initdb
# cp rpm.old/Packages rpm
# rpmdb --rebuilddb
關于怎么在CentOS中使用rpm包管理器問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。