软件包管理

t01c8d0a587f7a91802

 

软件包管理

API:Application Programming Interface

POSIX:Portable OS

程序源代码 –> 预处理 –> 编译 –> 汇编 –> 链接

静态编译:.a

动态编译:.so

二进制应用程序的组成部分:

二进制文件、库文件、配置文件、帮助文件

程序包管理器:

debian:deb文件,dpkg包管理器

redhat:rpm文件,rpm包管理器

rpm:Redhat package manager

rpm package manager

命名格式:mame-version-release.arch.rpm

源代码:name-version.tar.gz|bz2|xz

version:major.minor.release

常见的arch:

x86:i386,i486,i586,i686

x86_64:x64,x86_64,amd64

powerpc:ppc

跟平台无关:noarch

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

解决依赖包管理工具:

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

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

zypper:suse上的rpm前端工具

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

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

ldd 二进制所在目录

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

ldconfig

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

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

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

程序包管理器:

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

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

rpm包内的文件

rpm的元数据,如名称、版本、依赖性和描述等安装或卸载时运行的脚本

数据库(公共):/var/lib/rpm

程序包名称及版本

依赖关系

功能说明

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

rpm命令

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

安装:

rpm -i 安装

-v 显示安装过程

-h 以#显示安装进度

-l 列出rpm包中的文件

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

–nodeps:忽略依赖关系

–replacepkgs |replacefiles软件遭到破坏重新安装时找回破坏的文件

–nosignature: 不检查来源合法性

–nodigest:不检查包完整性

–noscripts:不执行程序包脚本

%pre: 安装前脚本; –nopre

%post: 安装后脚本; –nopost

%preun: 卸载前脚本; –nopreun

%postun: 卸载后脚本; –nopostun

升级:

upgrade:安装并升级,有旧版本升级,没有就安装(-U)

freshen:升级,有旧版本升级,没旧版本报错(-F)

以上两项不能用于升级内核版本

升级内核版本时直接安装,安装后

–oldpackage:降级

–force:强制安装

查询:

-q:查询

-a:所有包

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

-d: 查询程序的文档

-i: information

-l: 查看指定的程序包安装后生成的所有文件

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

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

-p rpmfile:针对没有安装的包文件查询(跟文件名)

–changelog:查询rpm包的changelog

–scripts:程序包自带的脚本

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

–whatprovides  关键字\功能 :查询指定的 CAPABILITY 由哪个包所提供

–whatrequires  关键字\功能 :查询指定的 CAPABILITY 被哪个包所依赖

rm -rf /var/lib/rpm 从删库到跑路的第四步

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

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

以上方法可以恢复损坏的包文件,但可能会影响到文件属性

卸载:

-e卸载

–allmatches:卸载多个同名包文件

包校验:

-V:校验包错误(后面跟文件名,加a查询包全部文件)

S:文件大小不同

M:模式不同

5:哈希值不同

D:设备号码不匹配

L:路径不匹配

U:校验用户权限

G:校验组权限

T:校验包时间的一致性

P:功能不同

-K:检查包的完整性和前面(需要导入签名文件)

rpm –import 签名文件

光盘默认路径:/etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7

系统光盘根目录下也有

rpm被卸载:

进入救援模式:mount 挂在光盘;rpm -ivh [包名称] –root=/mnt/sysimage/

yum

解决rpm依赖性问题,基于C/S(client/server)架构,可在多个库之间定位软件包

文件

文件服务器

http://

https://

ftp://

file://

yum客户端配置文件

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

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

日志:/var/log/yum.log

仓库指向的定义:

[repositoryID]

name=Some name for this repository

baseurl=url://path/to/repository/

enabled={1|0}

gpgcheck={1|0}

gpgkey=URL

enablegroups={1|0}

failovermethod={roundrobin|priority}

roundrobin:意为随机挑选,默认值

priority:按顺序访问

cost= 默认为1000

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

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

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

$basearch:基础平台;i386, x86_64

$YUM0-$YUM9:自定义变量

yum命令

显示仓库列表

yum repolist

显示程序包

yum list

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 | erase package1 [package2] […]

查看程序包information:

yum info […]

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

yum provides | whatprovides feature1 [feature2] […]

清理本地缓存:

清除/var/cache/yum/$basearch/$releasever缓存

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

构建缓存:

yum makecache

yum的命令行选项:

–nogpgcheck:禁止进行gpg check

-y: 自动回答为“yes”

-q:静默模式

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

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

–noplugins:禁用所有插件

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

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

#mount /dev/cdrom /media/cdrom

2.创建配置文件

[CentOS7]

name=

baseur1=

gpgcheck=0

enabled=

yum repolist:自动获取新的yum源

 

创建yum仓库:

createrepo rpm包目录

 

程序包编译安装:

xxxx.src.rpm 未编译的rpm包,安装后,使用rpmbuild命令制作成二进制格式的rpm包,而后再安装;

 

源程序从获取到使用过程:源代码–>预处理–>编译(gcc)–>汇编–>链接–>执行

 

源代码组织格式:

多文件:文件中的代码之间,很可能存在跨文件依赖关系;

 

C、C++:make (用configure脚本–>对Makefile.in模板–>生成makefile文件)项目管理器

java:maven

 

编译安装三步骤:

./configure:

1.通过选项传递参数,制定启动特性、安装路径;执行时会参考用户的指定以及Makefile.in文件生成makefile;

2.检查依赖到的外部环境;

make:

根据makefile文件,构建应用程序;

make install

 

开发工具:

autoconf:生成configure脚本

automake:生成Makefile.in

开源程序源代码的获取:

官方自建站点:

apache.org

mariadb.org

代码托管:

SourceForge

githup.com

code.google.com

 

c/c++:gcc (GNU C Complier)

 

编译C源代码:

前提:提供开发工具及开发环境;

开发工具:make,gcc等

开发环境:开发库,头文件

glibc:标准库

 

通过“包组”提供开发组件

centos 6:“Development Tools”,“Server Platform Development”,

centos 7:grouplist

 

第一步:configure脚本

选项:只等安装位置、指定启用的特性

选项分类:

安装路径设置:

–prefix=/PATH/TO/SOMEWHERE:指定默认安装位置

–sysconfidir:配置文件安装位置

 

第二步:make

第三部:make install

安装后的配置:

1.导出二进制程序目录至PATH环境变量中:

编辑文件/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

wget:下载

rpm是不可替代的,如果被卸载,yum也不能使用,yum是基于rpm的

man配置文件:

/etc/man.config centos6

man_db.conf centos7

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/96571

发表评论

登录后才能评论

联系我们

400-080-6560

在线咨询:点击这里给我发消息

邮件:1823388528@qq.com

工作时间:周一至周五,9:30-18:30,节假日同时也值班