分享更有价值
被信任是一种快乐

Linux中如何实现程序包管理与使用rpm命令

文章页正文上

这篇文章主要为大家展示了“Linux中如何实现程序包管理与使用rpm命令”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Linux中如何实现程序包管理与使用rpm命令”这篇文章吧。Linux的程序包管理:程序:指令+数据程序:算法+数据结构应用程序的存在形式:1.源代码:包含了整个应用程序的编程语言的所有代码的文本文件;2.二进制:将源代码经过一系列的转换操作之后得到的可以直接执行的文件使用源代码安装应用程序:预处理(预处理器) –> 编译(编译器) –> 汇编(汇编器) –> 链接(链接器) –> 可以直接执行的二进制程序文件POSIX:POS,Portable Operating System,可移植操作系统API:Application Program Interface,应用编程接口ABI:Application Binary Interface,应用二进制接口Unix-like:ELFWindows:exe,msi库级别的兼容,库级别的虚拟化;cywin:在Windows系统中模拟Linux的共享库;WinE:在Linux系统中模拟Windows的库;应用级编程语言:Java/Python/Perl/ruby/PHP/GOJava:hadoop2, hbase, ELK, (JVM)Python:Openstack, saltstack (PVM)系统级编程语言:C/C++LinuxUnix源代码编译:需要有编译开发环境支持C/C++:编译开发环境:预处理器,编译器,头文件,开发库文件Java/Python:编译开发环境:预处理器,编译器,开发库文件通常情况下:源代码文件是多个,这些文件直接存在着一定的关联关系;我们称这种关联关系为依赖关系;autoconfautomake软件项目构建工具:C/C++:makeJava:mavenPython:buildoutRedhat程序包管理器:在指定系统中进行程序的安装、卸载、升级、查询及校验等工作;不同的Linux发行版本,有着不同的程序包管理器:Debian:dpt, Debian Package Toolkits, dpkg工具, .deb后缀名的包文件;Redhat:rpm, Redhat Package Manager, rpm工具, .rpm后缀名rpm成为Linux的程序包管理器的行业标准;rpm是使用perl语言编写的,用C语言重新rpm,rpm is package managerS.u.S.E:rpm, .rpmGentoo:采用了FreeBSD的portage的程序包管理机制,emerge的工具ArchLinux:pacman以CentOS为例,rpm程序包管理器的相关内容:CentOS的程序包管理器:程序包的命名规则:源代码包:software_name-VERSION.tar.gzVERSION:major.minor.releasemajor:主版本号,通常代表重大功能改进的版本分支;minor:次版本号,通常代表在某个版本的分支中的某个功能发生变化;release:发行版本号,修复了某些bug或者对某段代码进行了优化;apache-tomcat-7.0.63.tar.gzrpm程序包命名规则:源码包:source codesoftware_name-VERSION.src.rpm二进制包:software_name-VERSION-[release].[os].arch.rpmVERSION:major.minor.release[release]:rpm封包的发行版本号[os]:所支持的操作系统版本,el6, el7, suse11, fedora22, …arch:硬件平台类型,I386, x64(amd64), ppc, sparc, noarch, …puppet-3.8.7-1.el7.noarch.rpm在制作rpm程序包的时候,通常其制作者会采用分包技术来构建rpm程序包;根据程序的不同功能,构建多个程序包;被分包的程序包一般分为两类:主程序包:software_name-VERSION-[release].[os].arch.rpm附属功能包:software_name-function-VE免费主机域名RSION-[release].[os].arch.rpm一般来讲,主程序包和附属功能包具有相同的版本号,发行版本号,操作系统及兼容平台的标识;所以,主程序包往往被所有的附属功能包所依赖;不安装主程序包就不能安装附属功能包;function:devel, utils, libs, tools, manual, client, common, …依赖关系:A –> B –> C D –> A 依赖黑洞程序包管理的前端工具:RHEL|CentOS系统的前端管理工具:yum, Yellow dog Update Midifieryum在实施安装、升级、卸载等工作的时候,会开启事务;所谓事务,将这个操作过程视为一个整体,要么全执行,要么全不执行;Fedora 22+:dnfDebian系的前端工具:apt-get,apt-cacheapt-get:实现安装、卸载等功能;apt-cache:实现基于关键字进行搜索功能,管理本地缓存及缓存的元数据suse前端工具:zypperrpm程序包管理器:1.rpm命令行工具;2.yum工具;rpm命令行工具:功能:1.将编译好的应用程序的各个组成文件打包成一个或多个程序包文件;2.软件包的安装、卸载、升级、查询、校验及数据库管理功能rpm程序包中文件的组成清单:1.程序的文件2.文件清单3.软件安装或卸载时所运行的脚本文件,共分为四类:preinstall:在正式的安装操作开始之前所运行的脚本,%prepostinstall:在安装完成后所执行的脚本,%postpreuninstall:在正式卸载操作开始之前所运行的脚本,%preunpostuninstall:在卸载完成后所执行的脚本,%postunrpm数据库(公共):已经安装好的程序包名称及版本/var/lib/rpm获取程序包的途径:1.系统的发行版的光盘2.官方的文件服务器或者镜像站点:http://mirrors.aliyun.comhttp://mirrors.sohu.comhttp://mirrors.163.comhttps://mirrors.tuna.tsinghua.edu.cnhttp://mirrors.hust.edu.cn3.某个项目的官方站点:4.第三方组织制作的rpm程序包站点Fedora EPEL:红帽官方的社区组织,在镜像站点中也包含EPEL镜像;搜索引擎:http://pkgs.orghttp://rpmfind.nethttp://rpm.pbone.net5.自己制作建议:获得程序包之后,实施完整性检查来源合法性:通过程序提供者的数字签名加密的数据,我们通过其公钥进行解密验证;程序包完整性:sha-1校验码rpm和yum两个工具的使用rpm命令行工具:安装、卸载、升级(降级)、查询、文件校验、验证、数据库维护;rpm命令的通用选项:-v:显示安装例程的信息,仅仅显示安装软件名-vv:显示非常详细的操作信息安装:rpm {-i|–install} [install-options] PACKAGE_FILE …install-options:-h, –hash:用50个”#”来表示安装进度–test:并不是真正的安装软件包,仅仅是测试是否在安装时能够正常完成,dry run模式;–nodeps:忽略因为依赖关系导致的安装错误,不建议使用;–replacefiles:在安装软件包时,软件包中的文件会直接将原来安装的文件替换;–replacepkgs:无需卸载软件包而重新安装;–noscripts:不运行任何脚本–nopre–nopost–nosignature:不考虑软件包的来源是否合法;–nodigest:不考虑软件包是否完整;例:~]# rpm -ivh php-mysql-5.3.3-40.el6_6.x86_64.rpm php-pdo-5.3.3-40.el6_6.x86_64.rpm升级:rpm {-U|–upgrade} [install-options] PACKAGE_FILE …如果选择被安装的程序包事先并未安装,则全新安装;如果已经安装了旧版本,则可以升级安装;rpm {-F|–freshen} [install-options] PACKAGE_FILE …仅仅只能对已经安装的低版本的程序包进行升级安装;常用选项:与安装相同–oldpackage:降级安装,用老版本的程序包替换新版本的程序包;–force:强制升级注意:1.强烈建议,不要对内核进行升级操作;Linux可以支持多内核,可以直接安装新版本的内核,在启动界面可以手动更换;2.升级安装可能会带来文件的变化,因此,系统默认不会直接更改之前安装过的软件的配置文件,新程序包中的配置文件会被重命名,通常会是:FINENAME.rpmnew卸载:rpm {-e|–erase} [–allmatches] [–nodeps] [–noscripts] [–notriggers] [–test] PACKAGE_NAME …–allmatches:卸载所有匹配指定名称的程序包的各个版本;–nodeps:卸载时忽略依赖关系,不建议使用;–test:测试卸载,dry run模式;查询:rpm {-q|–query} [select-options] [query-options][select-options]PACKAGE_NAME:直接给出程序包名-a,–all:查询所有已经安装的程序包名;~]# rpm -qa | grep mysql-f,–file FILE:查找指定的文件是由哪个程序包提供的;-p,–package PACKAGE_FILE:对还没有安装的程序包文件中执行查询操作–whatprovides CAPABILITY:查询指定的CAPABILITY是由哪个程序包提供的–whatrequires CAPABILITY:查询指定的CAPABILITY被哪个程序包所依赖[query-options]–changelog:查询rpm程序包的changelog;-c,–configfiles:查询指定程序包中有哪些是配置文件;-d,–docfiles:查询指定程序包中有哪些文档文件;-i,–info:查询程序包相关的信息,包括版本号,发行号,大小等;-l,–list:列表显示程序包安装会生成哪些文件–provides:列出指定程序包提供的所有的CAPABILITY;-R,–requires:查询指定程序包的依赖关系;–scripts:查看程序包所携带的脚本的内容;具体使用方法:-qf FILE-qc|-ql|-qd|-qi PACKAGE_NAME-qpl|-qpc|-qpd|-qpi PACKAGE_FILE校验:rpm {-V|–verify} [select-options] [verify-options]S file Size differsM Mode differs (includes permis免费主机域名sions and file type)5 digest (formerly MD5 sum) differsD Device major/minor number mismatchL readLink(2) path mismatchU User ownership differsG Group ownership differsT mTime differsP caPabilities differ认证:rpm –import /PATH/TO/KEY_FILErpm -K /PATH/TO/PACKAGE_FILE数据库管理:数据库的初始化和重建/var/lib/rpmrpm {–initdb|–rebuilddb}[–dbpath DIRECTORY]以上是“Linux中如何实现程序包管理与使用rpm命令”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注云技术行业资讯频道!

相关推荐: 怎么解决Oracle中报错PRVF-4007问题

这篇文章主要介绍“怎么解决Oracle中报错PRVF-4007问题”,在日常操作中,相信很多人在怎么解决Oracle中报错PRVF-4007问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么解决Oracle中报错PRVF-4…

文章页内容下
赞(0) 打赏
版权声明:本站采用知识共享、学习交流,不允许用于商业用途;文章由发布者自行承担一切责任,与本站无关。
文章页正文下
文章页评论上

云服务器、web空间可免费试用

宝塔面板主机、支持php,mysql等,SSL部署;安全高速企业专供99.999%稳定,另有高防主机、不限制内容等类型,具体可咨询QQ:360163164,Tel同微信:18905205712

主机选购导航云服务器试用

登录

找回密码

注册