一.软件运行环境基础
1.gcc编译程序的大致过程
- gcc 编译程序主要经过四个过程:
预处理(Pre-Processing)
编译 (Compiling)
汇编 (Assembling)
链接 (Linking)
- 如上图gcc编译过程
gcc -E hello.c -o hello.i
对hello.c文件进行预处理,生成了hello.i 文件
gcc -S hello.i -o hello.s
对预处理文件进行编译,生成了汇编文件
gcc -c hello.s -o hello.o
对汇编文件进行编译,生成了目标文件
gcc hello.o -o hello
gcc hello.c -o hello
或者直接编译链接成可执行目标文件
2.C程序编译过程
3.静态和动态链接
- 链接主要作用是把各个模块之间相互引用的部分处理好,使得各个模块之间能够正确地衔接,分为静态链接和动态链接
- 静态链接
把程序对应的依赖库复制一份到包
libxxx.a
嵌入程序包
升级难,需重新编译
占用较多空间,迁移容易
- 动态链接
只把依赖加做一个动态链接
libxxx.so
连接指向
占用较少空间,升级方便
- 静态链接和动态链接示意
- Java程序运行示意
二.软件包基础
1.包和包管理器
- 早期只提供.tar.gz的打包的源码文件,用户必须自已编译每个想在
GNU/Linux上运行的软件。用户急需系统能提供一种更加便利的方法来
管理这些软件;当Debian诞生时,这样一个管理工具也就应运而生,它
被命名为dpkg,从而著名的“package”概念第一次出现在GNU/Linux
系统中,在这之后Red Hat才开发自己的“rpm”包管理系统 - 包的组成
二进制文件、库文件、配置文件、帮助文件 - 程序包管理器:
debian: deb文件, dpkg包管理器
redhat: rpm文件, rpm包管理器
rpm:Redhat Package Manager
后改名为RPM Package Manager
2.rpm包的命名规则和相关工具
- 源代码
name-VERSION.tar.gz|bz2|xz
VERSION: major.minor.release
- rpm包命名方式
name-VERSION-release.arch.rpm
例:bash-4.2.46-19.el7.x86_64.rpm
VERSION: major.minor.release
release:release.OS
- 常见的arch
x86: i386, i486, i586, i686
x86_64: x64, x86_64, amd64
powerpc: ppc
跟平台无关:noarch
- 包:分类和拆包
Application-VERSION-ARCH.rpm: 主包
Application-devel-VERSION-ARCH.rpm 开发子包
Application-utils-VERSION-ARHC.rpm 其它子包
Application-libs-VERSION-ARHC.rpm 其它子包
包之间:可能存在依赖关系,甚至循环依赖
所以需要解决依赖的包管理工具:
yum:rpm包管理器的前端工具
apt:deb包管理器前端工具
zypper:suse上的rpm前端管理工具
dnf:Fedora 18+ rpm包管理器前端管理工具
3.库文件
查看二进制程序所依赖的库文件
ldd /PATH/TO/BINARY_FILE
管理及查看本机装载的库文件
ldconfig
加载配置文件中指定的库文件
/sbin/ldconfig –p 显示本机已经缓存的所有可用库文件名及文件路径
映射关系
配置文件:/etc/ld.so.conf, /etc/ld.so.conf.d/*.conf
缓存文件:/etc/ld.so.cache
三.rpm包管理器
1.rpm包管理器介绍
程序包管理器
功能:将编译好的应用程序的各组成文件打包一个或几个程序包文件,从而
方便快捷地实现程序包的安装、卸载、查询、升级和校验等管理操作
包文件组成 (每个包独有)
- RPM包内的文件
- RPM的元数据,如名称,版本,依赖性,描述等
- 安装或卸载时运行的脚本
- 数据库(公共):/var/lib/rpm
-
- 程序包名称及版本
-
- 依赖关系
-
- 功能说明
-
- 包安装后生成的各文件路径及校验码信
程序包的来源
管理程序包的方式:
使用包管理器:rpm
使用前端工具:yum, dnf
获取程序包的途径:
(1) 系统发版的光盘或官方的服务器
CentOS镜像:
www.centos.org
mirrors.aliyun.com
mirrors.sohu.com
mirrors.163.com
(2) 项目官方站点
(3) 第三方组织:
Fedora-EPEL:
Extra Packages for Enterprise Linux
Rpmforge:RHEL推荐,包很全
搜索引擎:
pkgs.org
rpmfind.net
rpm.pbone.net
sourceforge.net
(4) 自己制作
注意:第三方包建议要检查其合法性
来源合法性,程序包的完整性
2.rpm包管理器使用
2.1使用rpm可以实现软件的安装、卸载、升级、查询、校验、数据库维护
2.1.1安装
rpm {
-i|--install} [install-options] PACKAGE_FILE…
-v: verbose
-vv:显示更多信息
-vvv:显示更更多信息
-h: 以#显示程序包管理执行进度
rpm -ivh PACKAGE_FILE ...
[install-options]
--test: 测试安装,但不真正执行安装,即dry run模式
--nodeps:忽略依赖关系
--replacepkgs | replacefiles
--nosignature: 不检查来源合法性
--nodigest:不检查包完整性
--noscripts:不执行程序包脚本
%pre: 安装前脚本 --nopre
%post: 安装后脚本 --nopost
%preun: 卸载前脚本 --nopreun
%postun: 卸载后脚本 --nopostun
2.1.2升级
rpm {
-U|--upgrade} [install-options] PACKAGE_FILE...
rpm {
-F|--freshen} [install-options] PACKAGE_FILE...
upgrade:安装有旧版程序包,则“升级”
如果不存在旧版程序包,则“安装”
freshen:安装有旧版程序包,则“升级”
如果不存在旧版程序包,则不执行升级操作
rpm -Uvh PACKAGE_FILE ...
rpm -Fvh PACKAGE_FILE ...
--oldpackage:降级
升级注意项
注