程序包管理:rpm、yum以及(make)源代码编译安装

程序包管理:rpmyum以及(make)源代码编译安装

Linux上安装程序一般都有三种方法:源代码编译安装,rpm包安装和rpm包的前端安装yum, (rpm,和yum程序包管理器是针对CentOS6平台的)

程序包管理方式都大同小异:  源代码–>目标二进制格式(二进制程序、库文件、配置文件、帮助文件)–>组织称为一个或者几个包文件;包含的功能:安装、升级、卸载、修复、查询、校验。

程序包的命名方式: 源代码:NAME-VERSION.tar.gz VERSION:major.minor.releaserpm包:NAME-VERSION-release.os.arch.rpm; VERSION:major.minor.release

第一:源代码编译安装

一般源代码都是打包了的文件格式有:*.tar.gz,*.tar.bz2,*.tar.xz等等

步骤:

1), 解压包,tar  -zvxf|jvxf|Jvxf  PACKAGE; 可以不用指定解压方式

2), 切换到解压目录:先看看INSTALL README

3), ./configure; 通过选项传递参数,指定启用相关特性,安装路径,执行时参考Makefile,让后生成makefile;还有检查外部环境变量

相关选项:–help  获取这个源代码包中,配置相关信息的选项(可能每个包都是不同的);   

                    –prefix=/path/to/somedir  :指定安装的目录, 默认是安装到/usr/local;

      –sysconfdir=/path/to/somedir  ;配置文件的安装目录;

     –builddir=/path/to/somedir

4) make && make install ; 编译和建立相应的程序文件

     安装后配置程序环境

     1), 导出二进制文件,编辑:/etc/profile.d/NAME.sh  添加:export PATH=/path/to/bin:$PATH

 2), 导出库文件,编辑/etc/ld.so.conf.d/NAME.conf,添加新的库文件到此文件中,让系统重新生成缓存 ldconfig  [-v]

 3), 导出头文件  基于链接的方式实现,ln -sv

 4), 导出帮会手册 编辑/etc/man.config文件 添加 一个 MANPATH

 

第二、rpm包管理(CentOS6平台测试的)

1,程序包的组成清单:

文件清单和安装和卸载时运行的 脚本

2,数据库包含的信息(CentOS系列/var/lib/rpm

程序包的名称和版本;依赖关系;功能说明;安装生成的指定文件路径及校验信息

3,获取一个包,我们看其合法性和完整性:一是,获取程序包的时候,一般都是在官方获取;二是验证完整性:rpm -V package

https://www.linux178.com/linux/6.html :可以参考这个

rpm命令  主要包含下列几类:

安装:-i

升级:-U,–update

卸载:-e,–erase

查询:-q,–query

校验:-V,–verifyf

数据库维护:–builddb

安装:

-v 详细信息;-vv 更详细的信息

-h:以hash进度条显示安装百分比,每个#表示2%的进度

–test:测试安装,检查报告依赖和冲突

–nodeps 忽略依赖关系,不建议使用

-ivh  –replacepkgs  ;删除必要的程序文件,而又找不回来,就重新安装

–nosignature:不检查包的签名

–nodigest:不检查包完整

升级:

–force  强制执行

–oldpackage 降级到老版本

-U,升级或者安装

-F,系统没有老版本,就不能升级操

注意:不建议系统内核升级,linux支持多版本内核并存,所以直接安装多版本内核就行

卸载:

-e 卸载

–allmatches 卸载所有匹配指定名称的程序包各版本

–nodeps:忽略依赖关系

–test:测试卸

查询:

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

-q  查询是否安装及包的版本

-a,–all:查询所有已经安装过的包

-qa  :查询系统上所有已经安装的包

-qf  somefile  :查询这个文件所有哪个包生成的

-p,–package PACKAGE_FILE:用于实现未安装的程序包的安装后生成哪些文件而进行的查询

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

–whatrequires CAPABILITY:查询指定的CAPABILITY依赖于哪个程序包

[query-options]

–changelog :查询程序的日志,就是它的故事

-l:列出一个程序包安装生成所有的文件列表

-i,–info  程序包相关的信息,版本号,大小,包组

-c,–configfiles :查询指定程序包的配置文件

-d,–docfiles,查询指定的程序包的帮助文档

–provides:查询指定程序提供了什么功能

-R,–requires :查询指定程序包的依赖关系

–scripts :查询定指定程序包中使用的脚本

 

校验:

-V:校验查询,查询安装后文件是否被修改过

rpm -V 程序

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

   S file Size differs

   M Mode differs (includes permissions and file type)

   5 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 mTime differs

   P caPabilities

导入校验方式:

rpm –import  /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7 : 导入公钥

手动验证:rpm -K PACKAGE_FILE

重建数据库

/var/lib/rpm ; rpm数据库位置

rpm查询操作就是基于此数据库实现的

rpm { –initdb | –rebuilddb } [–dbpath=/tmp/rpm]

–initdb :初始化数据库,当前无数据库时,可实现创建一个新的数据库,当前有时不执行任何操作

–rebuilddb:重新构建,有数据库,但是不完整

 

第三、yum源安装

yum源安装—>配置文件指定服务器(URL:统一资源配置服务)—>匹配包列表文件—>下载相关联的程序包安装,yum repository:yum repos;存在rpm包的库,以及包相关的元数据文件(存放特定目录下:repodata)

支持的文件服务器有:ftp:// ;http://nfs://  ; file:///

yum的客服端:配置文件

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

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

仓库的定义:查询文档(man yum.conf),基本格式

[repositoryid]

name=some name for this repository

baseurl=url://path/to/repository

enabled={1|0} 是否启用此仓库,默认开启的

gpgcheck={1|0} 是否校验签名信息

gpgkey=URL ;指明秘钥文件

enabledgroups:支持组的方式管理此程序包

failovermethod 随机

安装:

   yum install package1 …..  ;默认安装最新版本的程序包,可以安装指定 版本号的程序包

   yum updates [package1] … 升级

   yum check-update ;  检查可用升级

   yum remove|erase package1 …   卸载

   yum info     ;查包的信息

   yum provides | […]   查看某文件有哪个包提供的 相当于 rpm -qf PACKAGE_FILE 

   yum clean  [packages|metadata|all} 清楚本地指定相关缓存

   yum search string1 [….] 以指定关键字搜索程序包名以及summary信息

   yum deplist package1 … 查看指定包的依赖关系

   yum history : 查看使用yum 操作的相关事务历史(使用yum的日志) stats :查看统计数据

–nogpgcheck  不检查秘钥

-y 自动选择“yes

-q  安静安装,不输出信息

-noplugins:禁用所有插件

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

    $releasever:当前系统的发新版的主版本号

    $arch:系统架构

    $basearch:基础平台

    $YUM0-YUM9 ;自定义的变量


比如配置本地光盘的Package ,(挂载到/mnt/cdrom

备份原有的.repo文件,vim /etc/yum.repos.d/CentOS-local.repo,如下:

[Base]

name=CentOS Linux release 7.3

baseurl=file:///mnt/cdrom/

enable=1

gpgcheck=1

gpgkey=file:///media/RPM-GPG-KEY-CentOS-7

 

实例:

lrzsz安装

rpm -ivh /home/giveup/soft/lrzsz-0.12.20-27.1.el6.x86_64.rpm

 blob.png

安装zsh为例,利用yum源安装

~]# yum install zsh

 blob.png

blob.png

 

 

原创文章,作者:不忘初衷,如若转载,请注明出处:http://www.178linux.com/66369

(1)
不忘初衷不忘初衷
上一篇 2017-01-10
下一篇 2017-01-10

相关推荐

  • lvs的四种调度类型和调度算法介绍

    lvs是linux内核级的负载均衡解决方案,作为netfilter的补充套件,其工作在INPUT hook上。 相比nginx等负载均衡解决方案的差异如下: lvs工作于内核空间,不受用户空间套接字和端口数量的限制,而且所有调度工作在内核空间完成,效率更高; nginx为七层负载均衡器,虽然通过stream模块也可以做到四层负载均衡,但是受到套接字数量限制,…

    Linux干货 2017-06-25
  • 1017练习题

    1017练习题 作业 10月17日 柴震 1.生产环境发现一台服务器系统时间产生偏差,造成服务异常,请帮忙校正。 hwclock 查看硬件是否准确,如准确无误,可以使用hwclock -s以硬件时间为准。 或者使用ntpdate命令指定一台NTP服务器,进行同步。 2.生产有一个数据同步脚本需要执行很长时间,怎样做到无人值守,在…

    Linux干货 2016-10-18
  • M20 – 1- 第二周(2):课堂练习与作业

    课堂练习: 1、显示/var目录下所有以l开头,以一个小写字母结尾,且中间出现至少一位数字的文件和目录 [root@centos6 ~]# ls /var/l*[[:digit:]]*[[:lower:]] ls: cannot access /var/l*[[:digit:]]*[[:lower:…

    Linux干货 2016-08-02
  • ps常用命令

    Linux上进程有5种状态: 1. 运行(正在运行或在运行队列中等待) 2. 中断(休眠中, 受阻, 在等待某个条件的形成或接受到信号) 3. 不可中断(收到信号不唤醒和不可运行, 进程必须等待直到有中断发生) 4. 僵死(进程已终止, 但进程描述符存在, 直到父进程调用wait4()系统调用后释放) 5. …

    Linux干货 2017-07-02
  • Linux命令date命令详解

    在linux环境中,熟练运用date命令来表示自己想要表示的时间,肯定可以给自己的工作带来诸多方便,下面是详细的使用说明和示例 在linux环境中,不管是编程还是其他维护,时间是必不可少的,也经常会用到时间的运算,熟练运用date命令来表示自己想要表示的时间,肯定可以给自己的工作带来诸多方便。 1.命令格式:date[参数]… [+格式] 2.命…

    2017-07-18
  • yum函数介绍以及自建yum仓库

    一、前言     在之前介绍了yum的配置(详细请移步 http://www.178linux.com/archives/6445)。但是有没有发现一个问题,虽然我们已将仓库指向一个可用的仓库服务器,但是随着Linux的不断升级和改版,我们是否还需要不断的去修改仓库的配置文件,如果只有一台还好,那如果我们有多…

    Linux干货 2015-07-24

评论列表(1条)

  • 马哥教育
    马哥教育 2017-04-10 16:14

    yum可结果后面的http进行搭建,加油!!!