程序包管理与程序编译安装(第九章)

1. 程序包管理工具前端

1.1 dpkg包管理工具node

dpkg为基于debian发行版中的程序包管理工具,例如Ubuntu、linxu mint。shell

aptitude:软件包管理系统,直接输入此命令可进入包管理的视图数据库

dpkg -L Package_Name:列出指定软件包所包含的所有文件缓存

dpkg --search absolute_file_name:查看指定文件属于哪一个包安全

aptitude search Package_Name:查看全部该名字的软件包,会自动增长通配符,前面下是i表示已安装,c表示软件已被删除,显示p表示配置文件也已经被删除,v表示包可用且未安装。服务器

aptitude safe-upgrade:安全的更新升级,若是存在依赖关系问题,不会强制升级ide

aptitude full-upgrade:更新升级,但不检查依赖关系工具

aptitude dist-upgrade:更新升级,但不检查依赖关系post

aptitude remove Package_Name:删除软件包,但不删除数据和配置文件

aptitude purge Package_Name:删除软件包,同时删除配置文件和数据

aptitude仓库

aptitude仓库配置存放于/etc/apt/sources.list中


1.2 rpm包管理工具

rpm包管理工具广泛用于Redhat系列的操做系统

rpm包命名规则:

name-VERSION-release.arch.rpm

name:包名

Version:版本号

release:发行号,有可能还会显示支持的操做系统,好比release.el7,表示适用于RHEL7

arch:运行平台。例如x8六、x86_x6四、x64,无关平台的一般会显示noarch

rpm包依赖关系:

yum是rpm包管理器的前端工具,用于解决包之间的依赖关系

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

ldconfig:管理与查看本地已装载的库文件

-p:显示本地已经缓存的库文件和文件路径的映射关系

配置文件有/etc/ld.so.conf、/etc/ld.so.conf.d/*.conf,缓存文件有/etc/ld.so.cache

rpm包安装

rpm {-i|--install} [install-options] PACKAGE_FILE ...

-i:安装软件包

rpm -ivh Package_Name:安装软件包,显示安装过程和安装进度

--install-options:安装选项

--test:测试安装,不真正执行

--nodeps:忽略依赖关系,通常不建议

--repleacepkgs:从新安装

--nosignature:不检查包的来源合法性

--nodigest:不检查包完整性

--noscripts:不执行程序包脚本片断

%pre:安装前脚本; --nopre

%post:安装后脚本;--nopost

%preum:卸载后脚本; --nopreun

%postun:卸载后脚本; --nopostun

rpm包升级:

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

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

-U:若是有旧版本则升级,没有旧版本则安装

-F:若是有旧版本则升级,没有旧版本则不执行操做

rpm -Uvh Package_Name

rpm -Fvh Package_Name

--oldpackage:降级

--force:强制升级

对于内核不要执行升级操做,会致使系统故障;

若是程序配置文件已经被修改,升级后配置文件不会被覆盖,而是将新版命名为filename.rpmnew保存

rpm包查询

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

-q:查询

[select-options]

-a:全部包

-f:查看指定文件由那个程序生成

-p /PATH/TO/PACKAGE_FILE:针对于未安装的包作查询操做

--whatprovides CAPABILITTY:查询指定的CAPABILITTY由哪一个包所提供

--whatrequires CAPABILITTY:查询指定的CAPABILITTY被哪一个包所依赖

[query-options]

--changelog:查询rpm包的changelog

-c:查询程序的配置文件

-d:查看程序的文档

-i:查看程序的详细信息

-l:查看指定程序安装后生成的全部文件

--scripts:程序包自带的脚本片断

-R:查看程序包依赖的CAPABILITTY

--provides:查看程序包所提供的CAPABILITTY

经常使用用法:

rpm -qi:查询程序包的详细信息

rpm -qf:查询文件由那个程序包生成

rpm -qc:查看程序包全部的配置文件

rpm -ql:查看程序包全部的文件列表

rpm -qd:查看程序包所包含的文档

rpm -qpi:查看未安装的指定程序包的详细信息

rpm -qpl:查看未安装的指定程序包的文件列表

rpm -qa | grep package_name:查看指定程序包是否安装

rpm卸载程序包

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

rpm包校验

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 differ

导入所须要公钥:

rpm --import /PATH/FROM/GPG-PUBKEY-FILE

rpm 数据库重建

rpm initdb:初始化,若是事先不存在数据库则新建,不然不执行任何操做

rpm rebuilddb:重建,不管事先是否存在,都重建数据库。


1.3 yum仓库管理

yum服务器:

yum服务器上存储了诸多软件包,放置于repodata目录下

yum客户端

配置文件:

/etc/yum.list :为数据仓库提供公共配置

/etc/yum.repo.d/*.repo:提供数据仓库的配置

数据仓库配置:

[repositoryID]                     #ID号

name=repo_name                     #仓库名

baseurl=url://path/to/repository/  #repodata的URL

enabled={0|1}                      #该源是否启用,0为关闭,1为启用

gpgcheck={0|1}                     #是否进行合法性和完整性校验,0为不校验,1为校验

gpgkey=URL                         #校验key的URL

enablegroups={0|1}                 #是否基于组来批量管理程序包

failovermethod={roundrobin|priority}#故障转移方式,轮询根据优先级选择,默认为roundrobin,意思为随机。

cost=                               #开销。默认为1000

yum常见命令用法

显示仓库列表:

yum repolist [all|enabled|disabled]:显示本地yum源[全部的|可用的|不可用的]

显示程序包:

yum list [all | glob_exp1] [glob_exp2] [...]:默认显示全部程序包,可以使用通配符

yum list {available|installed|updates} [glob_exp1] [...]:可用未安装的|已安装的|可升级的

安装程序包:

yum install Package1 [Package2......]:安装程序包

yum reinstall Package1 [Package2......]:从新安装程序包

升级程序包

yum update Package1 [Package2......]:程序包升级。默认升级全部程序包

降级程序包

yum downgrade Package1 [Package2......]:降级程序包

检查可用更新

yum check-update 

卸载程序包

yum remove package1 [package2] [...]:删除软件但保留他的数据和配置文件

yum erase package1 [package2] [...]:删除软件同时删除配置和数据文件

上述两种方法均可以删除软件包且同时删除依赖包

查看指定的特性(能够是某文件)是由哪一个程序包所提供

yum provides feature1 [feature2] [...]

yum whatprovides feature1 [feature2] [...]

清理本地缓存

yum clean [ packages | metadata | expire-cache | rpmdb | plugins | all ]:包缓存|元数据缓存|过时的缓存|rpmDB|插件|所有缓存

构建缓存:

yum makecache

搜索:

yum search string1 [string2] [...]:已指定的关键字搜索程序名及summary信息

查看指定的包所依赖的CAPABILITTY:

yum deplist package1 [package2] [...]

查看事务历史:

yum history [info|list|packages-list|packages-info|summary|addon-info|redo|undo|rollback|new|sync|stats]

安装和升级本地包:

yum localinstall RPMFILES1......:安装

yum localupdate RPMFILES1......:升级

包组管理的相关命令:

yum groupinstall group1 [group2] [...]:安装

yum groupupdate group1 [group2] [...]:升级

yum grouplist [hidden] [groupwildcard]:包组列表,可以使用通配符

yum groupremove group1 [group2] [...]:删除

yum groupinfo group1 [group2] [...]:查询包组信息

处理损坏的包的依赖关系

一、yum clean all 

二、yum update 若是未恢复继续3

三、yum deplist PACKAGE_NAME:显示包的依赖关系,若是未成功请继续4

四、yum update --skip-broken:忽略坏损的包,继续更新其余包

1.4 yum仓库建立

使用光盘作yum源

先挂载光盘

#mount -r -t iso9660 /dev/cdrom /media/cdrom

建立配置文件

[CentOS7]

name=

baseurl=file://....... 

gpgcheck=

enabled=

yum的命令行选项

--nogpgcheck:禁止进行gpgcheck

-y:自动回答为yes

-q:静默模式

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

--enablerepo=repoidglob:临时启用此处的repo

--noplugins:禁用全部插件

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

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

$arch:平台

$basearch:基础平台

$YUM0-$YUM9:这些将会替换为shell环境中相同的值

建立yum仓库

createrepo [options] <directory>

二、 使用源码安装程序

(1)查看INSTALL、README文件中的安装步骤和注意事项

(2)./configure

此命令的用途:

经过选项传递参数,指定启用特性和安装路径等;执行时会参考用户指定以及Makefile.ini文件生成makfile

检查依赖的外部环境

命令执行完成后查看执行结果,如有未安装的外部依赖环境和程序会有提示,安装便可。

(2)make

此命令用途:

根据makefile文件构建应用程序

(3)make install

安装程序

./configure的相关参数

--help:查看帮助

--prefix=/PATH/TO/SOMEFILE:指定安装路径,默认为/usr/local/

--sysconfdir=/PATH/TO/SOMEFIEL:配置文件安装位置

--disable-FEATURE:关闭某特性

--enable-FEATURE:开启某特性

--with-PACKAGE:可选包

--without-PACKAGE:不可选包

安装后的配置

(1)导出二进制程序至PATH环境变量中

编辑文件/etc/profile.d/NAME.sh

export PATH=/PATH/TO/BIN:$PATH

(2)导出库文件路径

编辑/etc/ld.so.conf.d/NAME.conf

添加新的库文件所在目录至此文件中

使用ldconfig 让系统从新生成缓存

(3)导出头文件

基于连接的方式实现

ln -sv 

(4)导出帮助手册

编辑/etc/man.config文件,添加一个MANPATH

相关文章
相关标签/搜索