Linux笔记 软件管理

|▌冷眼眸甩不掉的悲伤 提交于 2020-01-06 01:22:34
 
一、软件包分类
 
1.软件包分类:源码包、二进制包
 
源码包:源代码
1)优点:开源,有能力可修改源代码
            可以自由选择所需的功能
            软件是编译安装,更适合Linux系统,更稳定效率更高
            卸载方便。
2)缺点:安装过程步骤多,编译时间较长,安装过程中一旦报错新手很难解决。
 
 
二进制包:源码包经过编译之后生成的二进制程序(0101000...)。Linux的二进制包后缀为.rpm
1)二进制包分类:DPKG包:主要应用在Debian和ubuntu中
                             RPM包:主要的Linux系统包管理方式
2)优点:安装简单,安装速度快
3)缺点:不开源,有依赖性。
4)RPM包依赖性:树形依赖:a---->b---->c
                               环形依赖:a---->b---->c---->a
                               模块依赖(函数库依赖) 
 
 
2.软件包选择建议
 
源码包:如果服务是给大量客户提供访问则建议使用源码包,源码包效率更高
RPM包:如果程序是给少量用户访问,或者是在本地使用,建议RPM包。
 

3.软件包的组成部分:

  • 二进制程序,位于 /bin, /sbin, /usr/bin, /usr/sbin, /usr/local/bin, /usr/local/sbin 等目录中。
  • 库文件,位于 /lib, /usr/lib, /usr/local/lib 等目录中。Linux中库文件以 .so(动态链接库)或 .a(静态链接库)作为文件后缀名。
  • 配置文件,位于 /etc 目录中。
  • 帮助文件:手册, README, INSTALL (/usr/share/doc/)v
 
二、RPM人工安装
 
1.RPM包命名规则 
 
    wireshark-1.10.14.7-7.el7.x86_64.rpm
                wireshark     软件包名称
                -1.10.14       版本
                -7                 版本修订号
                .el7               适用的系统(red hat)
                .x86_64        适用的cpu硬件架构
 
  包全名:包含软件包名称、版本等详细信息的文件名,如果操作的是未安装软件包,则使用包全名,而且需要注意绝对路径。
  包名:只有软件包名称,如果操作的是已经安装的软件包,则使用包名则可。因为已安装的软件包系统会产生RPM包的数据库(/var/lib/rpm/)。
 
2.RPM包安装
 
注意:RPM包建议不指定路径,安装在默认目录下,即系统的习惯位置,卸载命令根据数据库记录的位置进行卸载删除,否则卸载命令无法找到

 

RPM命令的使用

RPM常用选项:

-i:表示安装。

-v, -vv, -vvv:表示详细信息。

-h:以"#"号显示安装进度。

-q:查询指定包名。

-e:卸载指定包名。

-U:升级软件,若未软件尚未安装,则安装软件。

-F:对已安装的软件进行升级。

-V:对RPM包进行验证。

--force:忽略软件包及文件的冲突。即使系统中已经安装也可以重新安装。

--test:仅作测试,不真正执行,可用于测试安装,测试卸载。

--prefix=路径:指定安装路径(不建议)

--nodeps:忽略依赖关系。强行安装不检测依赖性的软件无法使用,一般用于卸载(不建议使用)

--query:查询指定包名。同-q选项。

--hash:同-h。

--install:表示安装,同-i选项。

--replacepkgs:重新安装。替换原有的安装。

--initdb:新建RPM的数据库。

--rebuilddb:重建RPM的数据库。

--percent:以百分比的形式输出安装的进度。

RPM包的查询:

rpm -q:查询某一个RPM包是否已安装

rpm -qi:查询某一个RPM包的详细信息

rpm -ql:列出某RPM包中所包含的文件。

rpm -qf:查询某文件是哪个RPM包生成的。

rpm -qa:列出当前系统所有已安装的包

 

安装或卸载时,可能出现如下类似警告信息:warning:/etc/sysconfig/named created as /etc/sysconfig/named.rpmnew

该警告信息表示:rpm的配置文件被另存为了一份文件。

  

安装RPM包

命令格式:rpm -i /PATH/TO/RPM_FILE

一般组合起来使用:-ivh

命令格式:rpm -ivh PATH/TO/RPM_FILE

 

卸载RPM包

命令格式:rpm -e 包名

RPM包卸载依然有依赖性,卸载时需要将上层库文件先卸载(安装时安装下层库文件),假如用yum强制卸载可能会导致某些系统功能无法运行。
 
 

查询RPM相关信息

结合-q选项,RPM提供了许多种查询信息的方式。

命令格式:rpm -q 包名

命令格式:rpm --query 包名

查询所有已经安装包:rpm -qa

配合grep的使用:rpm -qa | grep 'zip'

查询包的摘要信息:rpm -qi 包名

 

查询包安装生成的文件 清单:rpm -ql 包名

查询某文件是由哪个rpm包安装生成的:rpm -qf /path/to/some_file

查询包安装生成的配置文件:rpm -qc 包名

 

查询包安装生成的帮助文档:rpm -qd 包名

查询包相关的脚本:rpm -q --scripts 包名

RPM包的脚本有四个:

preinstall:安装前脚本

postinstall:安装后脚本

preuninstall:卸载前脚本

postuninstall:卸载后脚本

 

对未安装的RPM包查询信息,使用"-p",可以与其他查询相关的其他选项组合使用。

命令格式:rpm -qpi /path/to/rpm_file

查询未安装包准备安装的位置:rpm -qlp 包名
 
 

升级软件

命令格式:rpm -Uvh rpm包

命令格式:rpm -Fvh rpm包

 

校验RPM包

命令格式:rpm -V 包名

对已经安装的软件,进行检验。若无输出,则表示已安装的软件没有被修改。若软件被修改,则会输出信关信息。具体请查看RPM相关手册。

S 文件大小是否改变

M 文件的类型或文件的权限(rwx)是否被改变

5 文件MD5校验和是否改变(可以看成文件内容是否改变)

D 设备的主从代码是否改变

L文件路径是否改变

U 文件的属主(所有者)是否改变)

G 文件的属组是否改变

T 文件的修改时间是否改变

 

数字证书导入

数字证书有如下特点:1、首先必须找到原厂的公钥文件,然后进行安装;2、安装RPM包时,会去提取RPM包中的证书信息,然后与本机安装的原厂证书进行校验;3、如果校验通过,则允许安装,如果验证不通过,则不允许安装并警告。

命令格式:rpm --import 证书路径

              rpm --import /mnt/cdrom/RPM-GPG-KEY-CentOS-7

 

RPM的数据库

数据库文件位于:/var/lib/rpm

若库损坏,很多RPM的查询将无法使用。

 

对损坏的数据库,可以进行数据库重建:

rpm --initdb    #新建数据库

rpm --rebuilddb  #重建数据库

注意:重建数据库时间会比较长。

 

源码格式的RPM包

SPRM即源码格式的RPM包。一般后缀名为".src.rpm"。其中包含了源码与spec文件。rpm通过spec文件进行打包。

 

 

三、RPM在线安装(yum安装)

 

YUM被称为 Yellow dog Updater, Modified,是一个在Fedora和RedHat以及SUSE中的Shell前端软件包管理器。YUM使用Python语言写成。YUM客户端基于RPM包进行管理,可以通过HTTP服务器下载、FTP服务器下载、本地软件池的等方式获得软件包,可以从指定的服务器自动下载RPM包并且安装,可以自动处理依赖性关系。

YUM在安装RPM时,会从服务器下载相应包,且缓存在本地。

使用YUM进行RPM包的管理,非常简单方便。

 

1、YUM客户端的使用

YUM客户端的配置

YUM的配置方式是基于分段配置的。

主配置文件:/etc/yum.conf

YUM的片段配置:/etc/yum.repos.d/*.repo

 

主配置文件配置了一个特殊的仓库,名称为main。main是为其他仓库提供默认的全局配置的。

 

 

配置文件的说明:

[main]        #main仓库。[ ]中括号表示一个仓库的定义。其中是仓库的名称。
cachedir=/var/cache/yum/$basearch/$releasever    #RPM包的缓存位置。
keepcache=0    #RPM包在本地是否需要长期保存。1表示yes,0表示no。
debuglevel=2    #日志级别。
logfile=/var/log/yum.log    #日志文件。
exactarch=1    #下载的RPM包是否需要与本地平台完全匹配。1表示yes,0表示no。
obsoletes=1
gpgcheck=1    #是否需要自动来源合法性检测。
plugins=1
installonly_limit=5
bugtracker_url=http://bugs.centos.org/set_project.php?project_id=16&ref=http://bdistroverpkg=centos-release
 

查看其他配置文件:

CentOS自带的这些配置文件中,其实只有CentOS-Base.repo文件有效。按照需求,这些文件可以删除,或改名,或自己建立一个.repo的配置文件。实际使用中,可以参考CentOS-Base.repo的配置自定义.repo文件。

 

查看CentOS-Base.repo配置文件:

 

对配置文件中的一些配置项作说明:

[ ... ]:仓库的名称。不能重复。

name:对仓库的描述,该项必须有。

baseurl:配置仓库的路径。用于指定一个url。

mirrorlist:指向一个镜像列表,里面有多个url。

*baseurl与mirrorlist只能有一个生效

enabled:是否启用当前仓库。值为1或0,默认为1。

gpgcheck:是否需要gpg校验。值为1或0,默认为1。

gpgkey:验证RPM包的密钥文件路径。该文件可以在远处服务器上,也可以在本地。

cost:代价,其本质是仓库优先级的配置。值越低,表示访问的代价越低,也即优先使用。

 

注意:配置文件中的"="号的前后不能有空格。

例:自己写一个repo配置文件。

[base]
name=CentOS 6.4 x86_64
baseurl=http://1 72.16.0.1/cobbler/ks_mirror/centos-6.4-x86_64/
enabled=1
gpgcheck=0
 
 

2、yum命令的使用

yum的命令形式一般是如下:yum [options] [subcommand] [package ...]

 

yum list相关命令

获取yum仓库(非本机安装的)中所有的包信息。

命令:yum list all

结果说明:

第一列:软件包名称.平台名称。

第二列:软件版本号-release号。

第三列:安装情况。

若显示@则表示该软件已经通过仓库安装。如@anaconda-CentOS-201303020151.x86_64/6.4 表示已经通过naconda-CentOS-201303020151.x86_64/6.4仓库安装。

install,则表示系统已经安装,未通过仓库安装。

若无@或不是install,则表示尚未安装。如base,表示未安装,包位于base仓库中。updates,表示未安装,包位于updates仓库中。

 

查看yum仓库中指定包名的软件包,可以使用通配符。

命令:yum list all mysql*

 

 

Installed Package:表示已经安装的包。

Avaliable Package:表示没有安装,但可以安装的包。

 

只显示已安装的包。

命令:yum list installed

 

只显示没有安装,但可安装的包。

命令:yum list available

 

查看所有可更新的包。

命令:yum list updates

 

显示不属于任何仓库的,额外的包。

命令:yum list extras

 

显示被废弃的包

命令:yum list obsoletes

 

新添加进yum仓库的包

命令:yum list recent

 

模糊匹配搜索 

当不记得包名只记得某个关键字时使用,也可查找某个命令属于哪个软件包。

命令格式:yum search 查询名

例:查询软件包名中出带有init的软件包。

命令:yum search init

 

查看仓库

查看当前能够使用的yum仓库

命令:yun repo list

显示所有仓库

命令:yum repo list all

 

显示禁用的仓库

命令:yum repo list enabled

 

显示启用的仓库

命令:yum repo list disabled

 

显示软件包的摘要信息

命令格式:yum info 包名

类似于rpm -qi 包名 ,yum info没有rpm -qi显示的详细全。但可以显示出安装状态(Installed,Available)

查询某个文件是由哪个软件包生成的

该功能类似于rpm -qf 包名。

命令格式:yum provides 文件

命令格式:yum whatprovides 文件

 

例:查询某文件的生成包。

说明:

setup-2.8.14-20.el6_4.1.noarch 位于仓库中,尚未安装。但若安装了该包,也会生成 /etc/fstab

setup-2.8.14-20.el6.noarch显示已被安装。当前/etc/fstab由该包生成。

 

yum甚至可以查询出未来将会存在的文件所属于的软件包。

 

例:查询/etc/named.conf将会由哪个包生成。

首先,说明目前实验目录中无named.conf

输入:yum provides /etc/named.conf

显示两个包,都位于仓库中,尚未安装。

 
 

清空本地yum的缓存

yum仓库若更新,则本地缓存就没有意义了。所以本地缓存需要清空。

命令格式:yum clean [ packages | metadata | expire-cache | rpmdb | plugins | all ]

 

手动在本地建立缓存

yum客户端会下载远程yum的文件。在本地生成缓存。

命令:yum makecache

 

安装应用程序

基本格式:yum [-y] install 包1 包2 ... 包n

说明:

若安装多个包,则使用包名之间使用空格隔开。

安装过程中,yum会询问用户是否安装,使用yum -y 选项,表示自动回答为yes。

 

例:使用安装wget。

命令:yum install wget

重新安装软包

命令格式:yum [-y] reinstall 包1 包2 ... 包n

 
 

升级软件包

命令格式:yum update 包1 包2 ... 包n

命令格式:yum update-to 包-版本号

说明:update-to可以指定版本号。

 

检测可升级的包

命令:yum check-update

 
 

卸载软件包

命令格式:yum remove 包1 包2 ... 包n

注意:若该包被依赖,则该卸载可能会导致一些问题。如A依赖B,若卸载B,则A也会被卸载,可能导致将上层重要文件卸载。建议不使用yum卸载。

 
 

本地安装升级RPM包

在RHEL6/CentOS6可以直接使用install,update命令安装本地rpm包。

命令格式:yum install rpm包路径

命令格式:yum update rpm包路径

 

或者使用localinstall,localupdate。在RHEL5/CentOS5下必须使用localinstall,localupdate。

命令格式:yum localinstall rpm包路径

命令格式:yum localupdate rpm包路径

 

yum安装rpm默认会查询软件包来源合法性,但有时没提供密钥,无法安装。使用--nogpgcheck选项,可以避免yum作校验。

命令:yum localinstall --nogpgcheck

 
 

包组管理

rpm包可以组合成包组,安装卸载 可以共同进行。当不清楚安装的软件包名信息时使用

 

查看yum仓库里的包组

命令:yum grouplist

Installed Groups 表示已安装的组。其他组类似。

 

显示指定的包组信息

命令:yum groupinfo "Development tools"

 

安装包组

命令格式:yum [-y] groupinstall 包组1 包组2 ... 包组n

 

例:安装开发环境,构建编译源码的环境。

一般为了防止出现不必要的问题,开发环境需要配置如下三个包组:

RHEL6/CentOS6:"Development tools"、"Server Platform Development"、"Desktop Platform Development"

RHEL5/CentOS5:"Development tools"、"Development Libraries"

输入命令:yum [-y] groupinstall "Development tools" "Server Platform Development" "Desktop Platform Development"

 

升级包组

命令格式:yum [-y] groupupdate包组1 包组2 ... 包组n

 

卸载包组

命令格式:yum [-y] groupremove包组1 包组2 ... 包组n

 

查看此前安装卸载等操作历史

命令:yum history

 

3、搭建YUM仓库

yum仓库又称为yum源,yum仓库一般会支持ftp协议(ftp://),http协议(http://),文件协议(file://)。

 

本地的YUM仓库

使用系统安装盘当作YUM仓库。对于RHEL系列的Linux,其安装光盘就是一个yum仓库。挂在上光盘,将yum客户端的仓库指向光盘路径。

 

例:将baseurl指向光盘路径。使用file://协议。

 

 

在配置完后,需要清空yum缓存。命令:yum clean all

查看当前的可用的yum仓库。命令:yum repolsit

配置yum仓库为网易镜像站中CentOS 6.4 x86_64的目录。只需要修改repo的baseurl。

baseurl=http://mirrors.sohu.com/centos/6.4/os/x86_64/

 
 

YUM内置变量

yum内置变量是关于操作系统、CPU平台的一些信息。可用于动态的配置yum路径。

 

说明:

$releasever:当前操作系统的主版本号。若CentOS6.4 该值为6。

$arch:当前平台版本架构。x86_64 或 i386/i586/i686。

$basearch:当前平台的基本架构。x86_64 或 i386。

$YUM0-9:这十个变量分别被 shell 环境中的同名变量的值所替代。如果 /etc/yum.conf 文件中设置了这些变量,而 shell 环境中没有同名变量,它的值则不被代替。

 

例:配置基于网易镜像站的跨平台路径。

baseurl=http://mirror.sohu.com/centos/relasever/os/basearch/

 
 

创建YUM仓库

使用createrepo命令创建YUM仓库。该命令系统中默认是没有的。可以使用rpm或yum安装上该命令。

格式:

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!