Linux编译工具演化
1.gcc/g++
GNU编译器套装(英语:GNU Compiler Collection,缩写为GCC),一套编程语言编译器,以GPL及LGPL许可证所发行的自由软件,也是GNU项目的关键部分,也是GNU工具链的主要组成部分之一。GCC(特别是其中的C语言编译器)也常被认为是跨平台编译器的事实标准。1985年由理查德·马修·斯托曼开始发展,现在由自由软件基金会负责维护工作。
原名为GNU C语言编译器(GNU C Compiler),因为它原本只能处理C语言。GCC很快地扩展,变得可处理C++。之后也变得可处理Fortran、Pascal、Objective-C、Java、Ada,以及Go与其他语言。
许多操作系统,包括许多类Unix系统,如Linux及BSD家族都采用GCC作为标准编译器。苹果电脑预装的Mac OS X操作系统也采用这个编译器。
GCC原本用C开发,后来因为LLVM、Clang的崛起,它更快地将开发语言转换为C++。许多C的爱好者在对C++一知半解的情况下主观认定C++的性能一定会输给C,但是Taylor给出了不同的意见,并表明C++不但性能不输给C,而且能设计出更好,更容易维护的程序[(GCC's move to C++)。gcc--wiki
gcc应该是Linux系统中最基础的编译方式了,后来演化出的makefile、cmake等等最后也转化成了相应的gcc命令来执行,对于test.cc
,gcc的一步到位的命令如下
gcc test.c -o test
实际上,这个过程经过了预编译,编译,汇编,链接四个步骤,具体解释可以参见Linux GCC常用命令,但是每次编译都需要输入命令行太麻烦了,于是可以使用make命令。
2.make
在软件开发中,make是一个工具程序(Utility software),经由读取叫做“makefile”的文件,自动化建构软件。它是一种转化文件形式的工具,转换的目标称为“target”;与此同时,它也检查文件的依赖关系,如果需要的话,它会调用一些外部软件来完成任务。它的依赖关系检查系统非常简单,主要根据依赖文件的修改时间进行判断。大多数情况下,它被用来编译源代码,生成结果代码,然后把结果代码连接起来生成可执行文件或者库文件。它使用叫做“makefile”的文件来确定一个target文件的依赖关系,然后把生成这个target的相关命令传给shell去执行。make--wiki
make命令的一般使用方式是先读取相关系统配置,之后使用make进行编译,等待编译完成以后将相关库文件或者可执行文件安装到系统路径。
./configure
make
sudo make install
一个makefile的教程,跟我一起写Makefile。使用makefile也会产生一个问题,会在源代码所在目录产生许多中间文件,虽然可以使用make clean
进行删除,但还是很麻烦,而且makefile的抽象程度并不高,所以产生了,cmake、autotools等高度抽象工具,cmake还能在不污染源代码目录的情况下进行编译,所以很多开源项目开始采用cmake的方式进行编译。
3.cmake/qmake
CMake前面已经介绍过了,不再赘述。
qmake是编译Qt项目时用的,但是不如CMake好用。
其实cmake等工具也是生成makefile的方式进行编译项目,在执行cmake ..
命令以后可以在build
目录下发现makefile文件。
4.二进制分发
顾名思义,就是直接将编译好的可执行程序或者动态库拷贝到生产环境中,这种情况下的部署速度应该只有网速或者U盘读取速度有关了,缺点也很明显,需要保证开发环境与生产环境的基本一致,需要保证依赖库在生产环境中存在。
5.git
git是一个分布式的版本管理工具,也是目前最流行的版本管理工具,同时github也成为了目前最流行的项目托管平台,同时gitlab、gitea等开源工具也能用来搭建私人的项目托管服务器,所以git也可以算是一个很方便的分发、部署工具,对于一般项目,只需要短短几行代码就能从源码进行构建。
面对一个全新的环境,我们完全可以用这种方法进行软件分发,项目部署,但是缺点也很明显,每次都需要从源码进行构建,在项目较大或者计算机性能不足够的时候费时费力。
git clone http://path/to/test.git
cd test
mkdir build
cd build
cmake .. && make && sudo make install
6.包管理
软件包管理系统是在电脑中自动安装、配制、卸载和升级软件包的工具组合,在各种系统软件和应用软件的安装管理中均有广泛应用。
在Linux发行版中,几乎每一个发行版都有自己的软件包管理系统。常见的有:
- 管理deb软件包的dpkg以及它的前端apt(使用于Debian、Ubuntu)。
- RPM套件管理員以及它的前端dnf(使用于Fedora)、前端yum(使用于Red Hat Enterprise Linux)、前端ZYpp(使用于openSUSE)、前端urpmi(使用于Mandriva Linux、Mageia)等。使用软件包管理系统将大大简化在Linux发行版中安装软件的过程。软件包管理系统---wiki
使用cpack进行打包,会在deb包中添加相关的依信息,参考这篇文章。优点很明显,解决了二进制分发的依赖的问题,只要在包信息中添加相关信息,会在部署时自动安装相关依赖,也解决了源码分发的速度问题,缺点也很明显,如果目标系统中没有包管理系统,就GG了。所以产生了另一种分发机制,镜像分发,其中比较流行的是docker。
7.docker
详细介绍参见docker--gitbook。
docker的实质是一种虚拟化技术,传统的虚拟化技术是在宿主机虚拟出一套完整的硬件后运行一个完整的操作系统,并在该虚拟系统中运行所需应用,而docker直接运行与宿主内核,相比传统虚拟机更为轻便。
如果通过docker进行分发,只需要在相应的docker镜像中编译相应的程序以及依赖库,然后将镜像推送到服务器上,在开发环境中进行下载即可,这种方式对需要大规模部署的项目来说,效率很高,而且更加易于维护和扩展。