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系统上如何实现软件包管理”这篇文章对大家有帮助,同时也希望大家多多支持创新互联,关注创新互联行业资讯频道,更多相关知识等着你来学习!

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


文章名称:CentOS系统上如何实现软件包管理-创新互联
URL链接:http://csdahua.cn/article/diocee.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流