Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/gaoding-inc/ci-task-runner

大型代码仓库按需构建解决方案
https://github.com/gaoding-inc/ci-task-runner

ci git gitlab-ci glup grunt jenkins-ci svn task-runner webpack

Last synced: 3 months ago
JSON representation

大型代码仓库按需构建解决方案

Awesome Lists containing this project

README

        

# ci-task-runner

[![NPM Version](https://img.shields.io/npm/v/ci-task-runner.svg)](https://npmjs.org/package/ci-task-runner)
[![NPM Downloads](http://img.shields.io/npm/dm/ci-task-runner.svg)](https://npmjs.org/package/ci-task-runner)
[![Node.js Version](https://img.shields.io/node/v/ci-task-runner.svg)](http://nodejs.org/download/)
[![Travis-ci](https://travis-ci.org/huanleguang/ci-task-runner.svg?branch=master)](https://travis-ci.org/huanleguang/ci-task-runner)
[![Coverage Status](https://coveralls.io/repos/github/huanleguang/ci-task-runner/badge.svg)](https://coveralls.io/github/huanleguang/ci-task-runner)

[[English]](./README.md) - [[简体中文]](./README.ZH-CN.md)

这是一个基于 NodeJS 编写的多进程构建任务调度器,它支持增量与并行构建,可以大幅度提高服务器端构建速度。

ci-task-runner 作为一个通用的任务调度器,它并不是为了取代 Jenkins、Gitlab-CI 等持续集成工具或 Webpack、Gulp 等构建程序,而是提高它们运行任务的速度。

> “我们将一个大型前端项目迁移到持续集成系统进行构建后,每修改一个小文件都需要近 10 分钟的时间才能完成构建完成,于是我们开发了 ci-task-runner,将这个过程缩短到 1 分钟左右”。[详情](https://github.com/huanleguang/ci-task-runner/issues/7)

## 原理

1\. **增量构建**:

在中大型项目中,如果因为修改一个小文件就需要全量构建,这样构建速度必然会非常慢。为了解决这个问题,ci-task-runner 会对比 Git 或 Svn 的提交记录,只构建有差异的文件。

2\. **并行构建**:

如果有多个任务需要执行,ci-task-runner 会根据当前服务器 CPU 核心的数量启动新的进程,以多进程并行运行的方式加快任务完成。

## 安装

```shell
npm install ci-task-runner -g
```

## 入门

ci-task-runner 的任务都是在 JSON 配置文件定义的,在项目中新建一个 `.ci-task-runner.json` 配置,范例:

```json
{
"tasks": ["mod1", "mod2", "mod3"],
"repository": "git",
"program": "cd ${taskPath} && webpack --color"
}
```

然后在项目目录运行命令即可执行上述定义的 `tasks`:

```shell
ci-task-runner
```

上述例子中:仓库中的 mod1、mod2、mod3 目录有变更则会依次执行 `cd ${taskPath} && webpack --color`。

通过入门教程可以看到,ci-task-runner 的任务概念与其他任务运行器最大的不同是:每一个任务都是基于代码仓库中的文件或文件夹。

> 在服务器上可以使用 CI 工具启动 ci-task-runner,参考: [持续集成](#持续集成)。

## 配置

### `tasks`

任务目标列表。目标可以是仓库中的任意目录或文件。

简写形式:`{string[]}`

```json
{
"tasks": ["mod1", "mod2", "mod3"]
}
```

进阶形式:`{Object[]}`

```json
{
"tasks": [
{
"name": "mod1",
"path": "path/mod1",
"dependencies": ["common/v1"],
"program": "cd ${taskPath} && gulp"
},
"mod2",
"mod3"
]
}
```

1. [`dependencies`](#dependencies) 与 [`program`](#program) 会继承顶层的配置,也可以覆盖它们
2. [`tasks`](#tasks) 支持配置并行任务,参考 [多进程并行任务](#多进程并行任务)

### `cache`

ci-task-runner 缓存文件写入路径,用来保存上一次任务的信息。默认为:`node_modules/.cache/ci-task-runner/${Package.version}.json`

### `dependencies`

任务目标外部依赖列表。如果任务目标依赖了目录外的库,可以在此手动指定依赖,这样外部库的变更也可以触发任务运行。

> ci-task-runner 使用 Git 或 Svn 来实现变更检测,所以其路径必须已经受版本管理。

### `repository`

设置仓库的类型。支持 git 与 svn。

### `parallel`

设置最大并行进程数。默认值为 `require('os').cpus().length`。

### `program`

执行任务的程序配置。

简写形式:`{string}`

```json
{
"program": "cd ${taskPath} && node build.js"
}
```

进阶形式:`{Object}`

```json
{
"program": {
"command": "node build.js",
"options": {
"cwd": "${taskPath}",
"timeout": 360000
}
}
}
```

#### `program.command`

设置执行的命令。

> 程序会将 `${options.cwd}/node_modules/.bin` 与 `${process.cwd()}/node_modules/.bin` 加入到环境变量 `PATH` 中,因此可以像 `npm scripts` 一样运行安装在本地的命令。

#### `program.options`

设置进程的选项。

* `cwd` 当前子进程的工作目录
* `env` 环境变量
* `timeout` 超时时间
* `uid` 设置进程的用户标识
* `gid` 设置进程的组标识

#### 变量

`program` 支持的字符串变量:

* `${taskName}` 任务名称
* `${taskPath}` 任务目标绝对路径
* `${taskDirname}` 等同于 `path.diranme(taskPath)`,[详情](https://nodejs.org/api/path.html#path_path_dirname_path)

## 配置范例

### 多进程并行任务

如果任务之间没有依赖,可以开启多进程运行任务,这样能够充分利用多核 CPU 加速运行。

tasks 最外层的任务名是串行运行,如果遇到数组则会并行运行:

```json
{
"tasks": ["dll", ["mod1", "mod2", "mod3"]],
"repository": "git",
"program": "cd ${taskPath} && webpack --color"
}
```

上述例子中:当 dll 构建完成后,mod1、mod2、mod3 会以多进程的方式并行构建。

### 依赖变更触发构建

```json
{
"tasks": ["dll", ["mod1", "mod2", "mod3"]],
"dependencies": ["dll", "package.json"],
"repository": "git",
"program": "cd ${taskPath} && webpack --color"
}
```

上述例子中:当 dll 和 package.json 变更后,无论其他任务目标是否有修改都会被强制构建。

### 自动更新 Npm 包

```json
{
"tasks": [
{
"name": "package.json",
"program": "npm install"
},
"dll",
["mod1", "mod2", "mod3"]
],
"dependencies": ["package.json", "dll"],
"repository": "git",
"program": "cd ${taskPath} && webpack --color"
}
```

上述例子中:当 package.json 变更后,则会执行 `npm install` 安装项目依赖,让项目保持最新。

## 持续集成

使用 CI 工具来在服务器上运行 ci-task-runner。

**相关工具:**

* gitlab: gitlab-ci
* github: travis
* Jenkins

CI 工具配置请参考相应的文档。

> Webpack 遇到错误没退出的问题解决方案:[Webpack configuration.bail](http://webpack.github.io/docs/configuration.html#bail)

## 授权协议

[MIT](./LICENSE)