CentOS系统上如何实现软件包管理

这篇文章主要介绍了CentOS系统上如何实现软件包管理,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

创新互联,专注为中小企业提供官网建设、营销型网站制作、成都响应式网站建设公司、展示型网站设计、成都网站建设等服务,帮助中小企业通过网站体现价值、有效益。帮助企业快速建站、解决网站建设与网站营销推广问题。

        软件包管理
CentOS系统上使用rpm命令管理程序包
安装、卸载、升级、查询、检验、数据库维护

rpm安装:
        rpm {-i|--install} [安装-选项] 打包;包
        -h  以#符号表示安装进度
        -v  显示安装过程中的详细信息
        -vv
        -vvv
        经常使用组合:-ivh,ivvh
        例如 rpm -ivh 包文件
        安装时的选项:
        --test    测试安装,但不真正执行安装,仅报告依赖关系以及冲突信息等
        --nodeps  忽略依关系,副作用是能安装成功,但未必能运行成功
        --replacepkgs  覆盖安装--重新安装并覆盖原有的文件
        --nosignature  不被监测来源合法性
        --nodigest     不检查包完整性
        --noscipts     不执行程序包脚本的片断
        --foree        强制安装
       
rpm包升级:
         rpm {-U|--upgrade} [安装-选项] 打包;包
              -U   升级或安装
               upgrade:安装有旧版程序包,则“升级”  如果不存在旧版程序包,则“升级”
         rpm {-F|--freshen} [安装-选项] 打包;包
              -F   升级
               freshen:安装有旧版程序包,则“升级”  如果不存在旧版程序包,则不执行升级操作
        常用组合:-Uvh,Fvh
        例如  rpm -Uvh 包文件
        升级选项:
        --oldpackage      降级
        --force           强制升级
升级时需要注意事项:
1  不要对内核执行升级,Linux 支持多个内核共存,可以对此直接安装新版本内核或不同版本的内核
2   如果程序包的配置文件安装后被修改,升级时,新版本的文件不会覆盖老版本的配置文件。而是把新版本的文件重命名加上后缀(.rpmnew) 之后保留

rpm包查询:
         rpm {-q|--query}[选择-选项][查询选项]
         安装选项                                                     ~]# rpm -q tree 后面准确查找包名   
         -a 所有包、                                                 ~]# rpm -qa     查询当前系统安装的所有包  ~]# rpm -qa |grep "^tr"  管道给关键字查找,以tr开头的包名
         -f 查看指定的文件由哪个程序安装生成                          ~]# rpm -qf /etc/issue   查询文件是哪个包生成  
         -p  rpmfuile 针对尚未安装程序包文件做查询操作;              ~]# rpm -qp tree-1.6.0-10.el7.x86_64.rpm
         --whatprovides 性能进程 查询指定的性能进程有哪个包所提供     ~]# rpm -q tree --whatprovides  查询这个功能是由哪个包所提供
         --whatrequires 性能进程 查询指定的性能进程被哪个包所依赖     ~]# rpm -q bash --whatrequires  查询这个功能是被哪个包所依赖 
         rpm2cpio 包文件|cpio -itv  预览包内的文件                    ~]# rpm2cpio tree-1.6.0-10.el7.x86_64.rpm |cpio -itv
rpm2cpio 包文件|cpio -id   "*.conf" 释放包内文件
         查询选项:
         --changelog 查询rpm包的变动日志                              ~]# rpm -qc tree --changelog
         -c   查询程序的配置文件  
         -d   查询程序的文档                                          ~]# rpm -qd tree
         -i   信息                                                    ~]# rpm -qi tree
         -l   查看指定的程序包安装后生成的所有文件                    ~]# rpm -ql tree
         --scripts 程序包自带的脚本片断                               ~]# rpm -q bash --scripts
         -R   查询指定的程序包所依赖的 性能进程                       ~]# rpm -qR bash
         --provides  ;列出指定程序包所提供的 性能进程                ~]# rpm -q bash --provides

rpm卸载:
        rpm  {-e|--erase}
         --allmatches      移除所有符合 的软件包(如果 被指定未多个软件包,常常会导致错误出现)
         --nodeps                         不验证软件包依赖
         --noscripts                      不执行软件包脚本
         --notriggers                     不执行本软件包触发的任何脚本
         --test                           不真正安装,只是判断下是否能安装
包检验:rpm {-V|--verify}
               --nofiledigest                   不验证文件摘要
               --nofiles                        不验证软件包中文件
               --nodeps                         不验证包依赖
               --noscript                       不执行验证脚本

导入所需要公钥:
 ~]# rpm -K tree-1.6.0-10.el7.x86_64.rpm   检查包的完整性和签名
      
rpm数据库:
        数据库重建: /var/lib/rpm
        rpm {--initdb|--rebuilddb}
        initdb  初始化
        如果时间不存在数据库,则新建之,否则 不执行任何操作
        rebuilddb 重建数据库  无论当前存在与否,直接重新创建数据库            
 
 
 
rpm命令实现程序管理   主要核心命令
安装:-vih,--nodeps,--replacepkgs
卸载:-e,--nodeps
升级:-Uvh,-Fvh,--nodeps,--oldpackage
查询:-q,-qa,-qf,-qi,-qc,-q --scripts, -q --chanlog, -q --provides,-q--requires
校验:-V
导入GPG密钥:--import,-K,--nodigest,--nosignature
数据库重建:--initdb,--rebuilddb                                  
===========================================================

yum

    yum是rpm的前端程序,用来解决软件包相关依赖性,可以在多个库之间定位软件包,
资源库: 存储了众多rpm包,以及包的相关的元数据文件(放置于特定目录repodata下)
    文件服务器:ftp:
                http://
                file:///

yum配置文件:
           /etc/yum.conf              主配置文件为所有仓库提供数据
           /etc/yum.repos.d/*.repo    为仓库的指向提供配置
           创库指向的定义:
           文件以.repo 结尾;
           root@Compro ~]# cat /etc/yum.repos.d/base.repo
           [base]                       提供配置信息
           name=CentOS 7                当前仓库的名称
           baseurl=http://10.1.0.1/cobbler/ks_mirror/CentOS-7-x86_64/    教室里的yum源
           enabled=1                    此仓库是否为可用
           gpgcheck=0                   是否对程序包做校验
           gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7    指明访问密钥路径的路径

           [仓库ID]     对于当前系统的yum来将,此仓库ID用于唯一标识此仓库指向,因此,必须唯一
           name=name    当前仓库描述信息名称
           baseurl=url://path/to/repository/  
           enabled={1|0}    此仓库是否可被使用 1是 禁用0是可以 不写是默认
           gpgcheck={1|0}   是否对程序包做校验 
           gpgkey=          指明gpgkey文件路径
           cost= 默认为1000
          

如果使用光盘当作本地yum仓库:
挂载光盘至某目录,例如/media/cdrom
#mount /dev/cdrom /media/cdrom
创建配置文件:
[CentOS7]
name=自定义                  当前仓库描述信息
baseurl=指明资源库的访问路径,通常为一个文件服务器上输出的某资源库,支持的类型:ftp://;http://;file:///
gpgcheck={1|10}          是否对程序包做校验
enabled={1|10}         此仓库上是否可用,默认为可用          

yum命令的语法: yum [选项] [命令] [包]
yum显示仓库列表:
                yum repolist [all|enabled|disabled]
显示程序包:
          yum list
          yum list [all | glob_ exp1 ] [glob_exp2] ...            
          yum list {available|installed|updates}[glob_exp1]...     
安装程序包:
          yum install 包1 [包2] ...
          yum reinstall 包1 [包2]...         重新安装
升级程序包:
          yum update [包1][包2]...
          yum downgrade 包1 [包2]...      降级
卸载程序包:
          yum remove | erase 包1 [包2]  ...                     
               
查看程序包的信息:
          yum info name
查看指定的特性(可以是某文件)是由那个程序包所提供
yum provides | whatprovides 特性1 [特性2] ...               

清理本地缓存:
          yum clean [包|元数据|expire-cache|rpmdf|plugins|all]
构建缓存:
         yum makecache           
 
搜索:
    yum  search 字符串1 [字符串2]
    以指定的关键字搜索程序包名及summary信息 
查看指定包所依赖的capabilities
        yum deplist 包1 [包2] ...
查看 yum事务历史
               yum history
              
日志:
     /var/log/yum.log
    
安装及升级本地程序包
         yum install rpmfile1 [rpmfile2] ...
         yum update  rpmfile1 [rpmfile2] ...
包组管理的相关命令:
         yum groupinstall group1
         yum groupupdate group1
         yum grouplist [hidden][groupwildcard]
         yum groupremove group1
         yum groupinfo group1
        
    
如何使用光盘当作本地yum仓库
 
挂载光盘至某目录
          例如 /media/crom  # mount /dev/cdrom /media/crom
          创建配置文件
          [CentOS7]
          name=name
          baseurl=file:/// 
          gpgcheck=0
          enabled=1   
yum 的命令行选项
yum [选项] 包
     --nogpgcheck     禁止进行gpg check
     -y               自动回答为"yes"
     -q               静默模式
     --disablerepo=repoidglob     临时禁用此处指定的repo
     --enablerepo=repoidglob     临时启动此处指定的repo
     --noplugins                 禁用所有插件
    
 
 =================================================================
 

                    源码编译 
程序包编译安装:
Application-VERSION-release.src.rpm-->
安装后,使用rpmbuild命令制作成二进制格式的rpm包,而后再安装
源代码-->预处理-->编译-->汇编-->链接-->执行

源代码组织格式:
多文件:文件中的代码之间,很可能存在跨文件依赖关系
C、C++:make (项目管理器,configure -->
Makefile.in --> makefile)
java: maven

C代码编译安装三步骤:
                    ./configure
                    通过选项传递参数,指定启动特性、安装路径等;
                    执行时会参考用户的指定以及makefile.in文件生成makefile
                    检查依赖到的外部环境,如依赖的软件包
                    [cdrom]
                    name=centos 7 cdrom
                    baseurl=file:///mnt/cdrom
                    gpgcheck=0
                    enabled=0                  
                    make    根据makefile文件,构建应用程序
                    make install   复制文件到相应路径
开发工具:
         autoconf: 生成configure脚本
         automake:生成Makefile.in
         注意:安装前查看 安装自带文档
开源程序源代码的获取:
官方自建站点:
apache.org (ASF:Apache Software Foundation)
mariadb.org
...
代码托管:
SourceForge.net
Github.com
code.google.com
c/c++编译器: gcc(GNU C Complier)

编译C源代码:
       准备:提供开发工具及开发环境
             开发工具:make,gcc等
             开发环境:开发库,头文件
             glibc:标准库
       实现:通过“包组”提供开发组件
CentOS 6:
Development Tools
Server Platform Development
CentOS 7:
Development Tools
Development and Creative Workstation

编译安装:
        第一步:configure 脚本
        选项:指定安装位置、指定启用的特性
        安装路径设定:./configure --prefix=/usr/local/http2 --sysconfdir=/etc/http2/
可选特性:
--disable-FEATURE
--enable-FEATURE[=ARG]
可选包:
--with-PACKAGE[=ARG],依赖包
--without-PACKAGE,禁用依赖关系    
    
安装后的配置:
二进制程序目录导入至PATH环境变量中;
编辑文件:
 [root@Compro ~]# vim /etc/profile.d/http2.sh
 PATH=$PATH:/usr/local/http2/bin

导入库文件路径:
 编辑/etc/ld.so.conf.d/NAME.conf
 添加新的库文件所在目录至此文件中
让系统重新生成缓存:
 ldconfig[-v]   
    
导入头文件
基于链接的方式实现:
ln -sv

导入帮助手册
编辑/etc/man.config|man_db.conf文件
添加一个MANPATH    
[root@Compro ~]# vim /etc/man_db.conf
MANDATORY_MANPATH /usr/local/http2/ma

感谢你能够认真阅读完这篇文章,希望小编分享的“CentOS系统上如何实现软件包管理”这篇文章对大家有帮助,同时也希望大家多多支持创新互联,关注创新互联行业资讯频道,更多相关知识等着你来学习!


当前题目:CentOS系统上如何实现软件包管理
分享网址:http://hbruida.cn/article/pihopi.html