Linux软件包管理与实例

Linux系统的早期,编译是利用程序代码生成可执行文件的过程的手动编译。虽具有一定优势,但是专业知识要求高,不利于实际操作。因此出现了许多软件包管理器,最具代表的是由Red Hat 推出的RPMYum则有利于解决linux安装软件时的依赖性。

所谓依赖性,就是linux系统中的软件将不同的功能模块单独写入到不同的软件包中,最后将多个相互依存的软件包结合起来形成一个应用程序(网上答案)。通俗来说,就是你在linux安装程序时,会接二连三的要求你先安装与正要安装的程序有依赖性的软件才可以。

以下分别讲述rpmyum

rpm包命名方式:

name -VERSION-release.arch.rpm

VERSION: minor major release

release: release.OS

常见的arch:

×86i386, i486, i586, i686

×86_64: ×64, ×86_64, amd64

以下是RPM软件包名称格式:

Linux软件包管理与实例

包命名和工具:

Linux软件安装包的类型

通常Linux应用软件的安装包有三种:
1tar包,如software-1.2.3-1.tar.gz。他是使用UNIX系统的打包工具tar打包的。
2rpm包,如software-1.2.3-1.i386.rpm。他是Redhat Linux提供的一种包封装格式(www.rpmfind.NET)。
3dpkg包,如software-1.2.3-1.deb。他是Debain Linux提供的一种包封装格式。
4) bin包,如RealPlayer11GOLD.bin,它是realplayerlinux文件下的二进制安装格式,它是源程序经过编译后的一种机器语言。
5)脚本安装文件,这一类格式比较多,例如后缀为shplrun的文件都是脚本文件。不过对于普通用户不太常见。安装这类文件要注意的问题是,多数要给文件先增加可执行权限,否则有可能会提示找不到文件。具体方法:终端或控制台下执行 chmod +x ***.*,然后再安装

一:rpm

Rpm命令基本格式:

rpm [option]

-q : 使用查询模式

-a : 查询所有软件包

-i : 显示所有详细信息。如果指定了软件包,则安装软件包

–install 安装

–test 检测

–nodeps 忽略依赖性关系直接安装

–replacepkgs 已安装过的包重装

–nosignature 不检查来源合法性

–nodigest 不检查包完整性

–noscripts 不执行程序包脚本

%pre: 安装前脚本; –nopre

      %post: 安装后脚本; –nopost

      %preun: 卸载前脚本; –nopreun

      %postun: 卸载后脚本; –nopostun

-l : 显示软件包的文件列表

-p : 查询指定的软件包

-f : 查询指定文件所属软件包

-v : 显示命令执行过程

-h : 安装软件包时显示进度信息

-e : 卸载指定的软件包

-U : 升级软件包

实例:

如果想查看已经安装的所有软件包:

[root@localhost ~]# rpm -qa

如果想查看某个软件包:

[root@localhost ~]# rpm -qa | grep 软件包名

查询文件所属软件包(需要输入文件的绝对路径)

[root@localhost ~]# which ls

[root@localhost ~]# rpm -qf /usr/bin/ls

使用rpm命令安装软件包

[root@localhost ~]# df #查看光盘是否挂载

Filesystem     1K-blocks    Used Available Use% Mounted on

/dev/sda2       48803552 4772816  44030736  10% /

devtmpfs         1001392       0   1001392   0% /dev

tmpfs            1016064      84   1015980   1% /dev/shm

tmpfs            1016064    9172   1006892   1% /run

tmpfs            1016064       0   1016064   0% /sys/fs/cgroup

/dev/sda5       48803552   33008  48770544   1% /app

/dev/sda1         972452  156004    816448  17% /boot

tmpfs             203216      16    203200   1% /run/user/42

tmpfs             203216       0    203216   0% /run/user/0

/dev/sr0         8086368 8086368         0 100% /media

[root@localhost ~]# cd /media

[root@localhost media]# ls

CentOS_BuildTag  GPL       LiveOS    RPM-GPG-KEY-CentOS-7

EFI              images    Packages  RPM-GPG-KEY-CentOS-Testing-7

EULA             isolinux  repodata  TRANS.TBL

[root@localhost media]# cd Packages/

[root@localhost Packages]# rpm -ivh tree-1.6.0-10.el7.x86_64.rpm

Preparing…                          ################################# [100%]

Updating / installing…

   1:tree-1.6.0-10.el7                ################################# [100%]

[root@localhost Packages]# rpm -qa tree

tree-1.6.0-10.el7.x86_64

使用rpm卸载软件包:

[root@localhost Packages]# rpm -e tree

-Uvh 当有旧的版本的包时,则卸载旧包再装新包,如没有旧包,直接装新包

-Fvh 当有旧的包时,卸载旧包装新包,无旧包时,什么也不做

–oldpackage 降级 已有新包,装旧包

–force 强制安装

 -q 软件包名  查询已安装过的软件包名。

     -qa 列出所有的已安装过的rpm

      -qa “name*”

      -qa |grep name

     -qf 查询一个文件来自于哪一个rpm包 (已安装的rpm

     -q –changelog 版本更新日志

     -qc 查询软件包的配置文件(不是所有包都有配置文件)

     -qd 查询软件包的帮助文档

     -qi 查询软件包的详细信息

     -ql 查询软件包所安装到系统当中的所有文件路径

     -q –scripts 查询软件包自带的脚本

     -q –provides 查询自身的功能

     -qR 查询实现自身的功能需要什么能力

     -qp[licd] rpm包 查看未安装的rpm包的各项信息二:yum

-e 软件名

    –nodeps 忽略依赖性。强制卸载

二:yum

Yumyum仓库,yum仓库里放着rpm包文件和元数据文件(放置于特定目录repodate下)。其工作原理是:

当执行yum install rpmfilename(安装软件包时),会先下载元数据里记录rpm依赖关系数据的文件,同时临时产生一个文件来缓存这些数据,然后就会下载所有有依赖关系的安装包,最后执行安装,安装完成之后会删除那个临时文件。

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:意为随机挑选,默认值

priority:按顺序访问

cost=默认为1000

Yum的用法:

yum check-update 列出所有可更新的软件清单

yum update 安装所有更新软件

yum install <package_name> 仅安装指定的软件

yum remove <package_name> 删除指定软件包

yum list 列出所有可装的软件清单

yum list updates 列出所有可更新的软件包

yum list installed 列出所有已安装的软件包

yum list extras 列出所有已安装但不在yum repository 内的软件包

yum search <keyword> 查找软件包

yum info 列出所有软件包的信息

yum provides <package_name>  列出软件包提供哪些文件

yum clean packages 清除缓存目录(/var/cache/yum)下的软件包

yum clean headers 清除缓存目录(/var/cache/yum)下的headers

以上所列有针对所有文件,若你想只针对单个包文件进行操作,只需跟上包文件名就可以了。

注意:不建议只执行yum update命令,因为会造成所有软件都会更新安装,如非需要,在工作中尽量不要执行此条命令。

原创文章,作者:xxcj,如若转载,请注明出处:http://www.178linux.com/84631

(0)
xxcjxxcj
上一篇 2017-08-13
下一篇 2017-08-13

相关推荐

  • cat命令了解

    1 查看文件在LINUX下一切皆文件,光看见文件名和目录名对我们来说,还远远不够。今天,就来介绍一下可以打开文件的命令cat。当然,二进制的可执行文件,不能用cat。在CentOS7下,以/etc/profile文件为例,如下: 首先,怎么打开这个文件呢?直接执行:cat /etc/passwd. 这么多行,能不能看见行号呢?cat -n /etc/pass…

    Linux干货 2017-04-03
  • n28 第二周作业

    n28 第二周作业

    Linux干货 2017-12-09
  • nginx反向代理负载均衡集群配置详解

    反向代理负载均衡集群配置详解 反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时站在服务器角度来看,代理服务器对外就表现为一个反向代理服务器。 对反向代理服务器的攻击并不会使得后端内网Web服务器上网页信息遭到…

    Linux干货 2016-11-07
  • Linux磁盘、文件系统管理

    对Linux而言,其哲学思想之一就是一切皆文件,因此Linux之上所有设备的操作都是通过文件接口来实现的,也就是说在访问设备的时候就如同访问一个文件一样,因为他们使用的都是文件系统接口。  设备也分种类,如:     1、块设备:block 其存取单位是“块”,如硬盘    &n…

    Linux干货 2016-08-29
  • N22-第三周作业

    列出当前系统上所有已经登录的用户名,注意:同一个用户登录多次,则只显示一次即可。 [root@localhost ~]# w |cut -d ' ' -f1 |sort -u lucy root USER 2.取出最后登录到当前系统的用户的相关信息。 [root@localhost ~]# last -1 root   &nbs…

    Linux干货 2016-08-28
  • Linux发展史

    适用对象:本文适合希望开始学习以及想了解Linux的朋友阅读。本文中所有内容仅供参考,不作为科学依据。 一、      Linux的起源 最初的计算机其实是具有单一功能的大型计算器,只能完成指定或者设定好的工作。多数情况下计算机资源是处于空闲状态的,为了不使资源浪费,就需要使计算机能够或者可以进行多种工作。或…

    Linux干货 2016-10-14