Linux软件包管理之rpm和yum的使用

rpm命令的使用

什么是RPM?

rpm:RPM Package Manager (原Redhat Package Manager) Linux 软件包管理工具

特定的程序由应用程序组成;

    GPL:源码

    glibs:标准的C库

常见Linux发行版的软件包管理器:

     Debian:.deb dpkg

     RadHat: .rpm(perl编写),rpm(RadHat Package Manager)

              rpm:RPM is Package Manager

     SUSE  :  rpm

软件运行环境

API:Application Programming Interface 意味开发库兼容,因此,源代码可跨平台

    遵循POSIX规范:Portable Openratin System  可跨平台调用

    程序的过程:预编译、编译、汇编、链接

        编译:源代码翻译成cpu指令集的过程

        静态链接:将库包含在程序中

        动态链接:so(shared object)(相当于windows系统的.dll文件)

            库为函数,function

            库:可执行程序,本身不能作为程序执行入口,但可以被调用是编译好的二进制格式

ABI:Application Binary Interface 编译后的程序可以跨平台

注意:1.os平台:编译好的应用程序必须为特定平台所支持的版本(linux和windows平台不兼容)

      2.硬件平台:应用程序为特定的cpu所支持

包的组成部分

     二进制程序:/bin,/sbin /usr/sbin,/usr/local.bin,/usr/local/sbin

     自身库文件:/lib /lib64 /usr/lib /usr/lib64 /usr/local/lib  /usr/local/lib64

                 开发时调用API,运行时调用ABI

                 通过调整  /etc/ld.so.conf   /etc/ld.so.conf.d/*.conf

      配置文件: /etc,无须额外配置

      帮助文件: man文件,info文件,README,INSTALL,ChangeLog

                 man COMMAND

                 到某路径下查找与命令名同名的通常以。gz结尾的压缩文件的名字

                 /usr/share/man

包命名格式:

源代码:

        name-VERSION.tar.gz|bz2|xz

             VERSION:major.minor.release

rpm包命名方式:

         name-VERSION-release.arch.rpm

   例如:bash-4.2.46-19.el7.x86_64.rpm

VERSION: major.minor.release

release:release.OS,通常包含rpm的只做发行号,还包含使用的OS

   例如:el6:redhat enterprise linux6

常见的arch:

x86: i386, i486, i586, i686

x86_64: x64, x86_64, amd64

ppc:powerpc

noarch:跟平台无关

包分类:

Application-VERSION-ARCH.rpm:       主包

Application-devel-VERSION-ARCH.rpm  开发子包

Application-utils-VERSION-ARHC.rpm  其它子包

Application-libs-VERSION-ARHC.rpm   其它子包

软件包之间可能存在依赖关系,甚至循环依赖

解决依赖包管理工具:

    yum:rpm包管理器的前端工具

    apt-get:deb包管理器前端工具

    zypper: suse上的rpm前端管理工具

    dnf: Fedora 18+ rpm包管理器前端管理工具

库文件

查看二进制程序所依赖的库文件:

    ldd [options] 二进制文件

    ldd /PATH/TO/BINARY_FILE

Linux软件包管理之rpm和yum的使用

管理及查看本机装载的库文件:

    ldconfig

    /sbin/ldconfig -p: 显示本机已经缓存的所有可用库文件名及文件路径映射关系

配置文件:/etc/ld.so.conf, /etc/ld.so.conf.d/*.conf

缓存文件:/etc/ld.so.cache

Linux软件包管理之rpm和yum的使用

包管理器

程序包管理器:

功能:将编译好的应用程序的各组成文件打包一个或几个程序包文件,从而方便快捷地实现程序包的安装、卸载、查询、升级和校验等管理操作

1、包文件组成(每个包独有)

    RPM包内的文件清单

    RPM的元数据,如名称,版本,依赖关系,功能性描述等

    安装或卸载时运行的脚本

2、数据库(公共)

    程序包名称及版本

    依赖关系

    功能说明

    包安装后生成的各文件路径及校验码信息

程序包的来源

管理程序包的方式:

    使用包管理器:rpm

    使用前端工具:yum, dnf(这个可能是未来版本)

获取程序包的途径:

(1) 系统发版的光盘或官方的服务器;

CentOS镜像:

    https://www.centos.org/download/

    http://mirrors.aliyun.com

    http://mirrors.sohu.com

    http://mirrors.163.com

(2) 项目官方站点

(3) 第三方组织:

    EPEL:Extra Packages for Enterprise Linux

(4) 自己制作

注意:检查其合法性:来源合法性,程序包的完整性

rpm包管理

CentOS系统上使用rpm命令管理程序包基本功能:

安装、卸载、升级、查询、校验、数据库维护

安装

rpm {-i|–install} [install-options] PACKAGE_FILE…

    -i –install:安装

    -v:显示安装信息

    -vv:二级详细

    -vvv:三级详细

    -h:hash 以#的个数显示安装进度,一个#表示2%的进度

安装选项[install-options]

    –test: 测试安装,但不真正执行安装;dry run模式

    –nodeps:忽略依赖关系

    –replacepkgs| replacefiles 重新安装 

       原来的配置文件不会被覆盖,新安装的配置文件将会重命名为以.rpmnew为后缀的文件

    –nosignature: 不检查来源合法性

    –nodigest:不检查包完整性

    –noscipts:不执行程序包脚本片断

        %pre: 安装前脚本;–nopre

        %post: 安装后脚本;–nopost

        %preun: 卸载前脚本;–nopreun

        %postun: 卸载后脚本;–nopostun

示例:rpm -ivh PACKAGE_FILE …

Linux软件包管理之rpm和yum的使用

升级:

rpm {-U|–upgrade} [install-options] PACKAGE_FILE…

rpm {-F|–freshen} [install-options] PACKAGE_FILE…

    upgrade:安装有旧版程序包,则“升级”

             如果不存在旧版程序包,则“安装”

    freshen:安装有旧版程序包,则“升级”

             如果不存在旧版程序包,则不执行升级操作

    –oldpackage:降级

    –force: 强行升级

例如:rpm -Uvh PACKAGE_FILE …

例如:rpm -Fvh PACKAGE_FILE …

升级注意项

(1) 不要对内核做升级操作;Linux支持多内核版本并存,因此,对直接安装新版本内核

(2) 如果原程序包的配置文件安装后曾被修改,升级时,新版本的提供的同一个配置文件并不会直接覆盖老版本的配置文件,而把新版本的文件重命名(FILENAME.rpmnew)后保留

示例:用centos6.8的内核升级到centos7.2的内核,但是失败了,原因是没有安装相关的依赖文件

如果一定要升级,就需要安装相关依赖的文件

Linux软件包管理之rpm和yum的使用

添加 –nodeps忽略依赖包的选项强行升级测试

Linux软件包管理之rpm和yum的使用

升级完内核以后,发现内核挂了,请小伙伴谨慎操作

Linux软件包管理之rpm和yum的使用

查询:

rpm {-q|–query} [select-options] [query-options]

[select-options]

    -q: 查询某单个包是否安装

        Linux软件包管理之rpm和yum的使用

    -qa: 查询所有已安装的包

    -qf: 查看指定的文件由哪个程序包安装生成

        Linux软件包管理之rpm和yum的使用

    -p:查询尚未安装的rpm包文件的相关信息

        -qpl rpm_file:针对尚未安装的程序包文件做查询操作;

        -qpi rpm_file: 查询其简单描述信息Linux软件包管理之rpm和yum的使用

    –whatprovides CAPABILITY:查询指定的CAPABILITY由哪个包所提供

    –whatrequires CAPABILITY:查询指定的CAPABILITY被哪个包所依赖

Linux软件包管理之rpm和yum的使用

    rpm2cpio 包文件|cpio–itv :预览包内文件

    rpm2cpio 包文件|cpio–id “*.conf” :释放包内文件

查询选项(配合-q)[query-options]

    -qc: 查询安装后生成的配置文件

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

    Linux软件包管理之rpm和yum的使用

    -qi: 查询包的描述信息

Linux软件包管理之rpm和yum的使用    -ql: 查看指定的程序包安装后生成的所有文件;

Linux软件包管理之rpm和yum的使用

    -qR: 查询指定的程序包所依赖的CAPABILITY;

Linux软件包管理之rpm和yum的使用

    –provides: 列出指定程序包所提供的CAPABILITY;

Linux软件包管理之rpm和yum的使用

    –changelog:查询rpm包的changelog

Linux软件包管理之rpm和yum的使用

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

            preinstall 安装前脚本

            postinstall 安装后脚本

            preuninstall 卸载前脚本

    postuninstall 卸载后脚本

卸载:

    rpm {-e|–erase} [–allmatches] [–nodeps] [–noscripts] [–notriggers] [–test] PACKAGE_NAME …

例如:rpm -e package_name

如果卸载被其他程序所依赖的包

1、把依赖者一同卸载

2、忽略依赖关系:–nodeps

3、不在卸载

Linux软件包管理之rpm和yum的使用

校验:检查包安装后生成的文件是否被修改过

rpm {-V|–verify} [select-options] [verify-options]

    S  大小       file Size differs 

    M  头文件     Mode differs (includes permissions and file type)

    5  MD5        digest (formerly MD5 sum) differs

    D  设备错误   Device major/minor number mismatch

    L  链接       readLink(2) path mismatch

    U  属主       User ownership differs

    G  主组改变   Group ownership differs

    T  修改时间   mTimediffers

    P  能力改变   capabilities differ

包来源合法性验正及完整性验正:

包完整性:通过单向加密机制(MD5|sha1)

来源合法性:通过公钥加密机制(RSA)

公钥加密:

对称加密:加密、解密使用同一密钥;

非对称加密:密钥是成对儿的

    public key: 公钥,公开所有人

    secret key: 私钥, 不能公开

            

导入所需要公钥:

rpm  -K|checksig  rpmfile 检查包的完整性和签名

    –nosigeature:不检查来源合法性

    –nodigest:不检查包完整性

rpm  –import  /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7  导入以后再做验证

CentOS 7发行版光盘提供:RPM-GPG-KEY-CentOS-7

rpm  -qa  gpg-pubkey*

示例:导入公钥以后,查询包的时候,我们会发现没有提示信息了,这是因为默认没有校验包的公钥,所以系统会对所有的包对提示报错的信息

Linux软件包管理之rpm和yum的使用

Linux软件包管理之rpm和yum的使用

Linux软件包管理之rpm和yum的使用

Linux软件包管理之rpm和yum的使用

rpm数据库

数据库重建:

    /var/lib/rpm

rpm {–initdb|–rebuilddb}

    initdb: 初始化

    如果事先不存在数据库,则新建之,否则,不执行任何操作

    rebuilddb:重建

    无论当前存在与否,直接重新创建数据库

Linux软件包管理之rpm和yum的使用


yum命令的使用

CentOS前端工具: yum, dnf

yum: YellowdogUpdate Modifier,rpm的前端程序,用来解决软件包相关依赖性,可以在多个库之间定位软件包,up2date的替代工具

    yum repository: yum repo,存储了众多rpm包,以及包的相关的元数据文件(放置于特定目录repodata下)

    文件服务器:通过yum所支持的文件共享机制将各rpm包通过文件服务共享

    ftp  ftp://server/path/to/repo

    http http://server/path/to/repo

    nfs  nfs://servr/nfs_path

    file file:///path/to/path

yum客户端作用

     1.配置文件:指定各可用的yum仓库;

     2.缓存元数据:yum会到各可用yum仓库获取元数据,并缓存至本地

     3.分析元数据:根据具体的操作请求完成元数据分析,可能包括依赖关系、文件列表等信息

     4.执行具体操作

yum客户端配置文件:

要使用yum管理应用程序,首先得配置其可用的yum仓库,保存在配置文件中

/etc/yum.conf:为所有仓库提供公共配置

/etc/yum.repos.d/*.repo:为仓库的指向提供配置

配置文件格式:由两段组成。类似window的ini配置文件

    [main]:主配置段

    [repo]:仓库配置段

仓库指向的定义:

[repositoryID]                         仓库ID

name=Some name for this repository     仓库名

baseurl=url://path/to/repository/      仓库的访问路径

enabled={1|0}                          1,表示启用,0表示不启用

gpgcheck={1|0}                         1,校验gpg,0表示不验证

gpgkey=URL                             公钥地址(可以是本地,也可以是服务器端路径)

enablegroups={1|0}

failovermethod={roundrobin|priority}   默认为:roundrobin,意为随机挑选;

cost=                                  定义此仓库开销,默认为1000

yum-config-manager  命令

    –add-repo= URL 添加仓库

    –disable      “仓库名” 禁用仓库

    –enable       “仓库名” 启用仓库

示例:创建一个仓库

Linux软件包管理之rpm和yum的使用Linux软件包管理之rpm和yum的使用

yum命令的用法:

yum [options] [command] [package …]

显示仓库列表:

    repolist[all|enabled|disabled]

Linux软件包管理之rpm和yum的使用

显示程序包:

    list

    # yum list [all | glob_exp1] [glob_exp2] […]

    # yum list {available|installed|updates} [glob_exp1] […]

示例yum list 支持通配符。由于里面的安装包太多。所以这里用通配符只看部分

Linux软件包管理之rpm和yum的使用

安装程序包:

    install package1 [package2] […]

    reinstall package1 [package2] […] (重新安装)

Linux软件包管理之rpm和yum的使用

升级程序包:

    update [package1] [package2] […]

    downgrade package1 [package2] […] (降级)

检查可用升级:

    check-update

Linux软件包管理之rpm和yum的使用

卸载程序包:

    remove | erase package1 [package2] […]

Linux软件包管理之rpm和yum的使用

查看程序包information:

    info […]

Linux软件包管理之rpm和yum的使用

查看指定的特性(可以是某文件)是由哪个程序包所提供:

    provides | whatprovidesfeature1 [feature2] […]

Linux软件包管理之rpm和yum的使用

清理本地缓存:一般来说,除非仓库出了问题或者使用新的仓库,否则一般情况下面不需要清理缓存

    clean [ packages | metadata | expire-cache | rpmdb| plugins | all ]

Linux软件包管理之rpm和yum的使用

构建缓存:

    makecache

Linux软件包管理之rpm和yum的使用

搜索:search string1 [string2] […]

    以指定的关键字搜索程序包名及summary信息

Linux软件包管理之rpm和yum的使用

查看指定包所依赖的capabilities:

    deplist package1 [package2] […]

Linux软件包管理之rpm和yum的使用

查看yum事务历史:

    history [info|list|packages-list|packages-info|

    summary|addon-info|redo|undo|

    rollback|new|sync|stats]

    yum history

    yum history info 6

    yum history undo 6

Linux软件包管理之rpm和yum的使用

 查看指定yum历史的操作

Linux软件包管理之rpm和yum的使用

撤销指定历史操作

Linux软件包管理之rpm和yum的使用

Linux软件包管理之rpm和yum的使用

日志存放位置:

    /var/log/yum.log

Linux软件包管理之rpm和yum的使用

安装及升级本地程序包:

    localinstallrpmfile1 [rpmfile2] […]

(用install替代)

    localupdaterpmfile1  [rpmfile2] […]

(用update替代)

Linux软件包管理之rpm和yum的使用

包组管理的相关命令:

    group install group1 [group2] […]

    group update group1 [group2] […]

    group list[hidden] [groupwildcard] […] 加hidden可以显示隐藏文件

    group remove group1 [group2] […]

    group info group1   […]

Linux软件包管理之rpm和yum的使用

注意:包组需要用group install安装

Linux软件包管理之rpm和yum的使用

如何使用光盘当作本地yum仓库:

 (1) 挂载光盘至某目录,例如/media/cdrom

# mount /dev/cdrom/media/cdrom

 (2) 创建配置文件

    [CentOS7]

    name=

    baseurl=

    gpgcheck=

    enabled=

示例:centos7的cdrom当作仓库配置,注意的是,得先手动配置挂载光盘到该目录,由于centos7不支持自动挂载,可以把挂载的命令写入到/etc/profile.d里面以实现开机自动挂载cdrom

Linux软件包管理之rpm和yum的使用

Linux软件包管理之rpm和yum的使用

示例:centos6建立yum的光盘仓库

Linux软件包管理之rpm和yum的使用

yum的命令行选项:

    –nogpgcheck:禁止进行gpgcheck

    -y: 自动回答为“yes”

    -q:静默模式

    –disablerepo=repoidglob:临时禁用此处指定的repo

    –enablerepo=repoidglob:临时启用此处指定的repo

    –noplugins:禁用所有插件

Linux软件包管理之rpm和yum的使用

yum仓库

yum的repo配置文件中可用的变量:

    $releasever: 当前OS的发行版的主版本号

    $arch: 平台,i386,i486,i586,x86_64等

    $basearch:基础平台;i386

    $YUM0-$YUM9:自定义变量

示例:

    http://server/centos/$releasever/$basearch/

    http://server/centos/7/x86_64

    http://server/centos/6/i384

示例:系统自带的仓库里面的url的链接均是变量,这样的话,在生产环境中,如果是有大量的服务器,因为服务器的系统版本很可能不一样,这样配置的话,系统可以自动识别版本号,以免安装错了其他系统发行版的包导致出其他问题。

Linux软件包管理之rpm和yum的使用

自己创建yum仓库:

    createrepo[options] <directory>

示例:在/root/treedir下面创建一个仓库,并且把一个tree的安装包放在里面

Linux软件包管理之rpm和yum的使用

可以跟cd里面的repodata目录对比一下基本是一样的

Linux软件包管理之rpm和yum的使用编辑/etc/yum.repos.d/base.repo文件,启动treedir的仓库,并且关闭其他仓库

Linux软件包管理之rpm和yum的使用

安装tree命令,并且成功,可以查看到tree命令是在tree的仓库里面安装的。

Linux软件包管理之rpm和yum的使用

思考问题

删除kernel包后,系统无法启动,怎么恢复?

一言不合就把内核干掉了O.O

Linux软件包管理之rpm和yum的使用

Linux软件包管理之rpm和yum的使用

重启以后发现内核真的挂了,怎么办怎么办?T_T

Linux软件包管理之rpm和yum的使用

此时我们可以把安装光盘放进去服务器,然后选择cd-rom启动

Linux软件包管理之rpm和yum的使用

点击进去Rescue installed system救援模式

Linux软件包管理之rpm和yum的使用

选择系统语言

Linux软件包管理之rpm和yum的使用

选择默认键盘格局。在天朝都是us的

Linux软件包管理之rpm和yum的使用

是否启用网络,这一个可以选择no,因为我们是用光盘的,无需联网

Linux软件包管理之rpm和yum的使用

问你是否继续,选择Continue

Linux软件包管理之rpm和yum的使用

这里提示如果你需要用root环境的权限可以输入chroot /mnt/sysimage

Linux软件包管理之rpm和yum的使用

这里会提示你的系统已经挂载到/mnt/sysimage这个目录下面

Linux软件包管理之rpm和yum的使用

此时选择Start shell,然后救援模式就开始了..

Linux软件包管理之rpm和yum的使用

因为是内核不小心卸载掉了(实际上是故意的),所以我们只需要从光盘里面安装一个内核即可,我们把光盘挂载到一个空的文件夹里面。

注意,千万不要直接挂载/dev/sr0到/mnt下面,不然会出错的,出错以后只能重启又重复这个操作。

挂载完光盘以后,输入rpm -ivh kernel-2.6.32-642.el6.noarch.rpm –root=/mnt/sysimage

等待安装完毕以后,重启电脑

Linux软件包管理之rpm和yum的使用

重启电脑可能会看见这样的提示,意味着你要等一个很长的时间才能进入系统,这个就慢慢等一下吧

Linux软件包管理之rpm和yum的使用

漫长的等待,看见可以正常进入系统了,并且登陆正常,ok,内核已经修复完

Linux软件包管理之rpm和yum的使用

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

(0)
~微风~~微风~
上一篇 2016-08-25
下一篇 2016-08-25

相关推荐

  • 马哥linux0803课堂笔记

    课堂笔记   重定向的几种方式 标准输入 0 (stdin) 标准输出 1 (stdout) 标准错误 2 (stderr)   标准输入的重定向方法 cat < file cat << string (多行重定向) xxx aaa string结束 cat file | cat   标准输出的重定向 ls e…

    Linux干货 2016-08-08
  • Nginx介绍及使用

       Nginx(engine x)是一个高性能的HTTP和反向代理服务器, 也是一个IMAP/POP3/SMTP服务器. Nginx是由IgorSysoev为俄罗斯访问量第二的Rambler.ru站点开发的, 第一个公开版本在2004年发布. 因为它的稳定性, 丰富的功能集, 示例配置文件和低系统资源的消耗而闻名. Nginx是一款轻量…

    Linux干货 2016-11-11
  • LVS集群类型

     lvs:Linux Virtual Server         l4:四层路由、四层交换          根据请求报文的目标IP和目标PORT将其调度转发至后端的某主机;      IPTABLES:  …

    Linux干货 2017-01-10
  • 网络基础知识子网划分

    一、某公司申请到一个C 类IP 地址,但要连接6 个的子公司,最大的一个子 公司有26 台计算机,每个子公司在一个网段中,则子网掩码应设为?  根据要划分的子网数量来算子网掩码的。2的M次方大于等于N。其中M是划分子网时要借的位数。N是要划分的子网数。 将需求代入公式,M=3,C类IP默认的掩码为24位,再从主机位中借来3位,就是27位。二进制表示…

    Linux干货 2016-09-06
  • VIM编辑器入门

    VIM简介 VIM是一个类似于Vi的著名的功能强大、高度可定制的文本编辑器,在Vi的基础上改进和增加了很多特性。VIM是纯粹的自由软件。 VIM的使用 在介绍基本使用前,先了解下VIM的基本模式 基本模式可分为三种:命令模式、输入模式、末行模式 命令模式:Vim启动后的默认模式,通过输入指令完成对应的编辑操作。输入模式和末行模式从命令模式进入&nb…

    Linux干货 2016-04-05
  • 权限管理和文本过滤

    1.复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限 [root@study ~]# cp -r /etc/skel/ /home/tuser1|chmod -R 700 tuser1/ [root@…

    Linux干货 2016-11-20