我是靠谱客的博主 丰富寒风,最近开发中收集的这篇文章主要介绍无法定位软件包 deepin-boot-maker_Linux最全软件包管理!看这个就对了! Wayne,觉得挺不错的,现在分享给大家,希望可以做个参考。
概述
data:image/s3,"s3://crabby-images/01ea8/01ea81d33aa5a4adfd55c64cd9c0d2f4a0a936d9" alt="7567b292-0e16-eb11-8da9-e4434bdf6706.png"
软件包命名规则的定义:
1
name-Version-release.arch.rpm
2
软件包的分类和拆包:
3
Application-Version-Arch.rpm,主包
4
Application-devel-Version-Arch.rpm,开发包
5
Application-utils-Version-Arch.rpm
6
Application-libs-Version-Arch.rpm
7
由于包之间存在存在依赖关系,所以解决依赖包管理工具
8
yum:rpm的前端管理工具
9
apt-get:debian
10
dnf:Fedora 18+
查看二进制程序依赖的库文件
ldd BINARY_FILE
data:image/s3,"s3://crabby-images/b6839/b683954f69741005ae7d68b330834167fad338b0" alt="7767b292-0e16-eb11-8da9-e4434bdf6706.png"
查看系统已经装载的所有的库文件
ldconfig -p,显示本已经缓存的库文件
data:image/s3,"s3://crabby-images/2ae09/2ae0966ac7c14ef34be34333e812491dd0e7e0a9" alt="7967b292-0e16-eb11-8da9-e4434bdf6706.png"
加载库的配置文件路径:/etc/ld.so.conf.d/*.conf,/etc/ld.so.conf
包管理器:
实现程序包的安装、卸载、查询、升级和校验等管理操作
包文件的组成:
rpm包内文件
rpm的元数据
安装或卸载时的脚本
rpm安装包的数据库文件路径:/var/lib/rpm,如果删除这数据库,则无法实现原来的软件的安装、查询,等操作
data:image/s3,"s3://crabby-images/4604c/4604cd40fced3b1849315e2c79dc5e7e3c7d7bb4" alt="7c67b292-0e16-eb11-8da9-e4434bdf6706.png"
rpm
rpm {-i|install}[install-options] PACKAGE_FILE
-i,install
-v,verbose
-h,以#显示安装进度
data:image/s3,"s3://crabby-images/14a83/14a8341074021eb8095655543b67b5d50c9e921b" alt="7f67b292-0e16-eb11-8da9-e4434bdf6706.png"
rpm -K,检查程序包的完整性
data:image/s3,"s3://crabby-images/6ca61/6ca618238d890bff38fcb37d2bbbe522314c4fc1" alt="8367b292-0e16-eb11-8da9-e4434bdf6706.png"
rpm --import,导入程序包的密钥
rpm --root,指定安装的程序包的目录
data:image/s3,"s3://crabby-images/2746f/2746f53dd849e97cf0fb5feb827aa997dbf64c35" alt="8867b292-0e16-eb11-8da9-e4434bdf6706.png"
rpm -q,查询时只需使用包名
--scripts,查询安装包里的脚本
data:image/s3,"s3://crabby-images/ed069/ed069cc5e723fc445a2828cb71aede2df75678bf" alt="8b67b292-0e16-eb11-8da9-e4434bdf6706.png"
rpm -qa,查询所有符合条件的包
data:image/s3,"s3://crabby-images/4d064/4d064de0ddde5040e281bd07d5d21f8172bcc237" alt="8e67b292-0e16-eb11-8da9-e4434bdf6706.png"
rpm -ql,列出包安装后生成的文件列表
data:image/s3,"s3://crabby-images/2d016/2d016989aa94d4ae7c285e976a378107a8c93cd8" alt="9067b292-0e16-eb11-8da9-e4434bdf6706.png"
rpm -qf,查询某个文件是那个安装包生成的
data:image/s3,"s3://crabby-images/e310e/e310e342419cc34152e925ddce62e32c79e1ac2e" alt="9367b292-0e16-eb11-8da9-e4434bdf6706.png"
rpm -p,查询还没安装的软件包的信息,通常与i,d,c等选项一起使用
rpm -qc,查询程序包的安装后生成配置文件
data:image/s3,"s3://crabby-images/4117c/4117c71c363690063ae22f0cda2c43cdec4c2d84" alt="9667b292-0e16-eb11-8da9-e4434bdf6706.png"
rpm -qd,查询程序包安装后生成的帮助文档
data:image/s3,"s3://crabby-images/b1bde/b1bdef18ebe9fa38825660fc34d0c6c9dd63b199" alt="9967b292-0e16-eb11-8da9-e4434bdf6706.png"
rpm -qi,查询程序包的详细信息
data:image/s3,"s3://crabby-images/07232/07232ef5e47d0372a2d9c83a6d97999ee9460800" alt="9b67b292-0e16-eb11-8da9-e4434bdf6706.png"
rpm --whatprovider CAPABILITY,查询指定CAPABILITY由那个包提供
[install-options]
--test,测试安装,不真正执行安装
--nodeps,忽略依赖关系,安装包时,包存在的依赖关系
--replacepkgs|replacefiles,覆盖安装,当某个包出现错误时,可以使用此选项
--nochecksignture,不检测来源的合法性,默认是检查
--nodigest,不检测包的完整性,默认是检查
--noscripts,不执行程序包里的脚本
%pre
--nopre
%post
--nopost
%preun
--nopreun
%postun --nopostun
升级:
rpm {-u|--upgrade}[install-options] PACKAGE_FILE
upgrade,安装有旧版本,则升级,不存在则安装
freshen,安装有旧版本,则升级,不存在则不升级
强制:
force
注意:
1. 内核包的升级,一般使用安装新的内核包(rpm -ivh kernel-version),而不使用升级操作,实现多内核版本并存
data:image/s3,"s3://crabby-images/2adc1/2adc14e640fe0a8153d937abbb0b3c90a8d0c0a9" alt="9d67b292-0e16-eb11-8da9-e4434bdf6706.png"
2. 如果原程序包的配置文件曾被修改,安装或者升级该程序包,原有的程序包的配置文件将被自动重名为Package.rpm.config
卸载
rpm {-e|--erase}[--allmatches][--nodeps][--noscripts]PACKAGE_NAME...
data:image/s3,"s3://crabby-images/845ae/845ae0a0c2c170926ce8f38d1ae30ea60301cd3f" alt="9f67b292-0e16-eb11-8da9-e4434bdf6706.png"
校验
rpm{-V|--verify}[select-options][verify-options]
S file
M Mode
5 digest,md5
T timestamp
U user ownership
G group ownership
data:image/s3,"s3://crabby-images/3ccba/3ccba4c9b796c23dd70f831a6994e5b19f055481" alt="a167b292-0e16-eb11-8da9-e4434bdf6706.png"
rpm包解包
rpm2cpio PACKAGE_FILE | cpio -idv
data:image/s3,"s3://crabby-images/07232/07232ef5e47d0372a2d9c83a6d97999ee9460800" alt="9b67b292-0e16-eb11-8da9-e4434bdf6706.png"
yum,解决rpm安装二进制程序时的产生的依赖关系
repo仓库的路径:/etc/yum.repos.d/
repo的缓存目录:/var/yum/cache
创建一个repo仓库:在/etc/yum.repos.d/新建一个*.repo文件
文件服务器:
http://
ftp://
file://
示例:
data:image/s3,"s3://crabby-images/767fc/767fc8ba05e646d11029849b0c594dc019637236" alt="a867b292-0e16-eb11-8da9-e4434bdf6706.png"
yum [options] command
command
repolist,列出所有的repo仓库
data:image/s3,"s3://crabby-images/3e6ba/3e6ba591995b0e9193fe17d732177fc061a23c4f" alt="ac67b292-0e16-eb11-8da9-e4434bdf6706.png"
yum install,安装指定的二进制程序
data:image/s3,"s3://crabby-images/a8568/a8568752bd3630b510f002d58359202e186d7bff" alt="c467b292-0e16-eb11-8da9-e4434bdf6706.png"
yum search,搜索仓库里带有特定关键字的包
data:image/s3,"s3://crabby-images/87603/87603fa01db230ca610d0a08e00a9d6af4ff828f" alt="c567b292-0e16-eb11-8da9-e4434bdf6706.png"
yum
list,显示当前仓库的所有的包
installed,当前系统已经安装的包
data:image/s3,"s3://crabby-images/a05e4/a05e489314e3cf8dca256ebd524d914984e159f7" alt="c967b292-0e16-eb11-8da9-e4434bdf6706.png"
yum remove,卸载指定的二进制程序
yum info,显示仓库里指定二进制程序的信息
data:image/s3,"s3://crabby-images/3cf0b/3cf0bbe58b85cfcef71e0311b3133e28ec33761b" alt="cc67b292-0e16-eb11-8da9-e4434bdf6706.png"
yum history,显示yum命令的执行历史
info,显示yum历史的详细信息
data:image/s3,"s3://crabby-images/768a1/768a1d3d6adca5fd6d1d6df2bf106641f4b686c5" alt="cd67b292-0e16-eb11-8da9-e4434bdf6706.png"
yum
history list,显示已经执行过的yum的历史
yum histrory undo,撤销yum命令历史中指定的id执行的操作,相当于移除
data:image/s3,"s3://crabby-images/d2c30/d2c30ac1612216939ce7edd577f84f1fa5590b2b" alt="d067b292-0e16-eb11-8da9-e4434bdf6706.png"
yum history redo,重新执行yum命令历史中指定的id执行的操作,相当于安装
data:image/s3,"s3://crabby-images/5f88e/5f88ebee33b254735e612af3be406cd652855d4a" alt="d267b292-0e16-eb11-8da9-e4434bdf6706.png"
yum clean,清理yum仓库的缓存信息
all,清理所有缓存信息
data:image/s3,"s3://crabby-images/f7b90/f7b902ce8e93dbfc60063d0f8e66cc4c0882b779" alt="d667b292-0e16-eb11-8da9-e4434bdf6706.png"
yum的repo配置文件中常用的变量
$realsever,当前OS的主版本号
$arch,平台
$basearch,基础平台
yum-config-manager --enable "仓库名"
yum-config-manager --disable "仓库名"
data:image/s3,"s3://crabby-images/f5232/f5232de6659640e1d8004cd5a8f76dc7d5f3d7d4" alt="d967b292-0e16-eb11-8da9-e4434bdf6706.png"
包组管理的相关命令:
yum groupinstall group1 [group2] [...]
yum groupupdate group1 [group2] [...]
yum grouplist [hidden] [groupwildcard] [...]
yum groupremove group1 [group2] [...]
yum groupinfo group1 [...]
yum的命令行选项:
--nogpgcheck:禁止进行gpg check
-y: 自动回答为“yes”
-q:静默模式
--disablerepo=repoidglob:临时禁用此处指定的repo
--enablerepo=repoidglob:临时启用此处指定的repo
--noplugins:禁用所有插件
程序包编译
CC++:make项目管理器
configure脚本 --> Makefile.in
--> Makefile
C语言源代码编译三步骤:
1. ./configure脚本
(1)传递相应的参数,指定启用特性等,生成相应的Makefile
(2)检查依赖的软件包
2. Make
3. Makeinstll
【年薪30w工程师吐血整理资料大合集】
领取IT资料大合集:http://image.qbangmang.com/counselor.html
data:image/s3,"s3://crabby-images/84495/84495b1a353e87eb899c4a69dd1a82694df70c9a" alt="db67b292-0e16-eb11-8da9-e4434bdf6706.png"
最后
以上就是丰富寒风为你收集整理的无法定位软件包 deepin-boot-maker_Linux最全软件包管理!看这个就对了! Wayne的全部内容,希望文章能够帮你解决无法定位软件包 deepin-boot-maker_Linux最全软件包管理!看这个就对了! Wayne所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复