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 15:43
下一篇 2017-08-13 17:55

相关推荐

  • Linux基础知识——文件查找

    Linux系统的核心思想之一就是一切皆文件,可想而知你要靠记忆去查找一个文件该是多么费劲;今天我们介绍几个文件查找命令:whereis,locate,find whereis locate the binary, source, and manual page files for…

    Linux干货 2016-10-11
  • 邮件原理你真的造吗

    一、前言     虽然现在QQ、微信等即时聊天工具原来越盛行,但是在企业与企业之间大部分还是会使用邮件系统进行信息交换。所以作为运维人员,更需要了解这个技术的原理。下面会慢慢介绍邮件的组件功能,将其组成部分。以及邮件的工作原理。     小贴士:邮件系统是一个比较复杂的系统,过程…

    Linux干货 2015-08-17
  • 网络组(Network Teaming)

    网络组(Network Teaming) 网络组:是将多个网卡聚合在一起的方法,从而实现容错和提高吞吐量 网络组不同于旧版中bonding技术,提供更好的性能和扩展性 网络组由内核驱动和teamd守护进程实现. 多种方式runner     broadcast     roundrobin     …

    Linux干货 2017-03-26
  • 马哥教育网络班22期-第4周博客作业

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@zck ~]# cp -r /etc/skel /home/tuser1 [root@zck ~]# ll -d /hom…

    Linux干货 2016-09-02
  • 网络基础

    1、OSI模型七层结构 应用层   为应用程序进程提供网络服务   提供用户身份验证   表示层     确保接收系统可以读出该数据     格式化数据     构建数据 &nbs…

    Linux干货 2016-09-06
  • DNS服务器搭建从协议到实现详解

    一、域名和服务概述    1.FQDN:Fully Qualified Domain Name,完全限定域名,全局唯一           FQDN是指主机名加上全路径,全路径中列出了序列中所有域成员。全域名可以从逻辑上准确地表示…

    Linux干货 2016-04-30