常见包管理与构建工具列表
包管理和构建系统是现代的软件开发团队中必不可少的工具,也是Linux软件系统的常见组织方式。 现代编程语言大多给出了自己专用的包管理和构建系统,那么本文便来总结一下小编用过的那些包管理和构建系统。
JavaScript
服务器端 Javascript 通常使用NPM作为依赖管理工具。
- 通过NPM提供的
npm
命令来进行依赖的下载、升级和移除。 - 通过
package.json
来定义软件包的元信息、开发依赖(开发或测试需要)、部署依赖(运行时需要)。 - 依赖递归地存储在
node_modules
中。 - 依赖在项目之间是隔离的,全局安装(
-g
)会使它成为命令行工具而不是全局依赖。递归的依赖下载风格使得NPM的缓存及其重要。缓存位于
~/.npm
下,这里保存这.tgz
格式的包文件。
JavaScript 通常使用 Grunt 进行构建。
- Grunt通过插件来完成任务,每个插件相当于Makefile的一个命令。
- Grunt任务定义在
Gruntfile.js
中。 - NPM提供了众多的Grunt插件,当然你也可以手写。
- Grunt任务继承了JavaScript的异步特性。
前端 lib
前端 lib 可以通过 Bower 来下载。Bower 不仅可以下载已注册的软件包,还可以下载Github Repo,甚至是一个文件的URL。
- 通过
bower
命令进行依赖管理。 bower.json
定义了软件包的元信息与依赖。- 依赖所在路径可以在
bower.json
中进行设置。 - Bower只是一个命令行工具,你需要在正确的路径执行Bower命令。
Bower可以灵活地下载各种依赖,但它的缺点也是明显的:未注册的软件包往往包含冗余的非生产环境的代码,有时甚至需要手动构建。
Java
Maven是基于项目对象模型(POM)的项目管理工具,通过文本文件来描述项目的版本、URL、License、依赖等信息。
- 通过
pom.xml
来描述Maven项目。 - Maven是项目管理工具,其功能包括依赖管理、软件构建。
- Maven通过
.properties
文件和命令行参数读取系统特性。
Ant是由Java写成的编译、测试和部署Java应用的命令行工具。
- 通过
build.xml
来描述构建过程。 build.xml
的逻辑类似Makefile,每个target由命令和参数构成。- 通过命令行参数来读取系统特性。
Gradle是一个基于Apache Ant和Apache Maven概念的项目自动化建构工具。它使用一种基于Groovy的特定领域语言来声明项目设置,而不是传统的XML。
Python
Python的包管理工具能讲一整天的故事:distribute、setuptools、distutils、easy_install、pip、distutils2、packaging、eggs、wheels、pyvenv、virtualenv……
这也是我为什么讨厌安装python软件的原因,与此同时,旧版本的python2比新的python3更加流行以及两者不兼容也常常给Linux包管理造成麻烦。
现在开始讲故事:
- distutils是python的标准库;
- setuptools试图完成distutils缺少的特性而开始开发;
- easy_install是setuptools的命令行接口,有更多的特性;
- 在setuptools的开发过程中产生了分歧,于是出现了distribute,它fork自setuptools,并在2013年取得和解并重新merge到setuptools 0.7版本;
- 相比于上述工具,pip是一个更加高阶的接口,pip成为事实上的python软件的安装工具;
- eggs和wheels成为事实上的二进制python软件的安装工具。
venv
和virtualenv
则是用来创建python虚拟环境来实现应用隔离的。
- venv在python3.3中引入,用于在自己的目录下创建轻量级的虚拟环境,也可以孤立于系统环境。
- virtualenv则是一个python软件包,用于创建孤立的python环境。
Ruby
Ruby的软件包单元为RubyGem。
- Gem由
.gemspec
文件描述。 - Gem的构建过程由
Rakefile
描述。 - Rake是Gem的构建工具,它与Make类似,用以完成自动化测试和代码生成。
- Bundle则是Ruby的包管理工具,用来跟踪和下载正确版本的Gem。
本文采用 知识共享署名 4.0 国际许可协议(CC-BY 4.0)进行许可,转载注明来源即可: https://harttle.land/2015/05/29/pkg-manager.html。如有疏漏、谬误、侵权请通过评论或 邮件 指出。