Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/re-zero-khis/gitbook-server-docker

docker 一键部署 GitBook 服务器
https://github.com/re-zero-khis/gitbook-server-docker

docker gitbook learning

Last synced: 29 days ago
JSON representation

docker 一键部署 GitBook 服务器

Awesome Lists containing this project

README

        

# GitBook-Server-Docker

> docker 一键部署 GitBook 服务器

------

## 简介

使用 [GitBook](https://docs.gitbook.com/) 的初衷主要是为了可以利用 Github 为数据载体,在线上和线下同时搭建个人博客。

但是在线下搭建 GitBook 服务器最大的问题是环境部署复杂,因此本文利用 Docker 实现一键部署服务器。

> 在线上部署的方法则比较多:

 利用 [GitBook](http://app.gitbook.com/) 官方提供的免费空间

 利用 GitHub Pages (有 300M 免费空间)

 租用个人云服务器,同样可以用 Docker 搭建

------
## 运行环境

 ![](https://img.shields.io/badge/Platform-Windows%2010%20x64-brightgreen.svg) ![](https://img.shields.io/badge/Platform-Linux%20x64-brightgreen.svg) ![](https://img.shields.io/badge/Platform-Mac%20x64-brightgreen.svg)

> 注:

 因为 gitbook 服务是运行在 Docker 中,所以不论使用哪个平台,都要预装好 Docker 环境

 但是本文所使用的基础镜像是基于 Linux 的,因此 Docker in Windows 是无法直接安装的

 所以针对 Windows 10 ,推荐使用 WSL ( Windows Subsystem for Linux )

 通过 WSL 安装 Ubuntu 系统,然后再[在 Ubuntu 里面安装 Docker Deamon](https://docs.docker.com/install/linux/docker-ce/ubuntu/)

 最后 Docker in Windows 做端口映射,就可以实现 Windows 到 Linux 的无缝对接

 具体的 Windows Docker 环境部署方法可参考 《[简书: Win10 内置 Ubuntu 完美使用 Docker in Windows](https://www.jianshu.com/p/97d16b68045f)》

 至于 Linux 和 Mac 则简单得多,直接安装 Docker Deamon 即可使用,具体方法自行谷歌

展开查看图片

![](https://github.com/lyy289065406/gitbook-server-docker/blob/master/img/00.png)

------
## 使用方法

### 构建 GitBook 镜像

首先安装 `git` 命令行工具,然后 `clone` 本仓库到本地:

`git clone https://github.com/lyy289065406/gitbook-server-docker`

在命令行环境下 **打开本地仓库目录** 。 Docker 脚本已经编排好在 [`./Dockerfile`](https://github.com/lyy289065406/gitbook-server-docker/blob/master/Dockerfile) 中,可以不修改直接使用。

构建 Docker 镜像(镜像名称 `exp/gitbook-server` 可根据 Docker 规范自定义修改):

`docker build . -t exp/gitbook-server:latest`

![](https://github.com/lyy289065406/gitbook-server-docker/blob/master/img/01.png)

至此镜像已经安装完毕,下文主要是测试 GitBook 镜像是否可用。

### 初始化 GitBook 项目

在 Docker 镜像中执行命令 `gitbook init`:

`docker run --rm -v "$PWD/gitbook:/gitbook" exp/gitbook-server gitbook init`

> 该命令会自动创建用于 **示例** 的 GitBook 文件 。

 实际效果就是在工作目录 `./gitbook` 下创建两个符合 GitBook 语法的文件 `README.md` 和 `SUMMARY.md` 。

 *更多的 GitBook 语法详见 《[GitBook 学习笔记](https://yangjh.oschina.io/gitbook/)》*

![](https://github.com/lyy289065406/gitbook-server-docker/blob/master/img/02.png)

### 构建 GitBook 项目

在 Docker 镜像中执行命令 `gitbook build`:

`docker run --rm -v "$PWD/gitbook:/gitbook" exp/gitbook-server gitbook build`

> 该命令会根据 GitBook 文件 `README.md` 和 `SUMMARY.md` 构建 html 项目 。

 实际效果就是在工作目录 `./gitbook` 下构建目录名为 `_book` 的静态网页文件 。

 本地可以通过 `./gitbook/_book/index.html` 测试访问 。

![](https://github.com/lyy289065406/gitbook-server-docker/blob/master/img/03.png)

### 启动 GitBook 服务

在 Docker 镜像中执行命令 `gitbook serve`:

`docker run --rm -v "$PWD/gitbook:/gitbook" -p 4000:4000 exp/gitbook-server gitbook serve`

> 该命令效果就是构建一个可以访问 `./gitbook/_book/index.html` 的 Web 服务。

![](https://github.com/lyy289065406/gitbook-server-docker/blob/master/img/04.png)

------
## FAQ

### 0x01 前文中 Docker 命令的参数是什么含义?

`docker run --rm -v "$PWD/gitbook:/gitbook" -p 4000:4000 exp/gitbook-server `

- `docker run`:运行镜像
- `--rm`:退出镜像后自动删除运行时产生的数据(此镜像目的是提供 GitBook 服务的运行环境,因此没必要保留数据)
- `-v "$PWD/gitbook:/gitbook"`:把本地工作目录 `$PWD/gitbook` 挂载到镜像的工作目录 `/gitbook` (这样运行 GitBook 期间的工作数据就会从本地映射到镜像内,即使镜像退出运行,数据依旧会保留在本地)
- `-p 4000:4000`:把镜像内 GitBook 的 4000 服务端口暴露到本地物理机的 4000 端口
- `exp/gitbook-server`:目标镜像名称
- ``:要在镜像内执行的命令,如 `gitbook serve` 等,更多命令可见 [gitbook-cli](https://github.com/GitbookIO/gitbook-cli)

### 0x02 怎样以后台运行方式启动 GitBook 服务?

增加 `-d` 参数即可:

`docker run -d --rm -v "$PWD/gitbook:/gitbook" -p 4000:4000 exp/gitbook-server gitbook serve`

### 0x03 怎样停止 GitBook 服务?

先用 `docker ps` 命令查看正在运行的 GitBook 容器,然后执行命令 `docker stop ` 即可 。

![](https://github.com/lyy289065406/gitbook-server-docker/blob/master/img/05.png)

### 0x04 怎样进入这个 Docker 镜像?

执行下面命令即可:

`docker run --rm -v "$PWD/gitbook:/gitbook" -it exp/gitbook-server /bin/sh`

- `-it`:表示以交互方式运行
- `/bin/sh`:此镜像的基础镜像是 `node:8.5-alpine` ,shell 只支持 `/bin/sh`

### 0x05 怎样安装 GitBook 插件?

GitBook 的精粹在于丰富的插件以扩展其功能,插件可通过工作目录下的 [`book.json`](https://github.com/lyy289065406/exp-blog/blob/master/gitbook/book.json) 配置并控制,相关说明见 [官方文档](https://docs.gitbook.com/v2-changes/important-differences#plugins)。

推荐 GitBook 安装的插件可参考 [这份清单](http://gitbook.zhangjikai.com/plugins.html) 。

根据插件命名约定,若 **插件名称** 为 `prism` ,则其对应 **安装包名称** 为 `gitbook-plugin-prism` 。

以 `prism` 插件为例,安装方式有两种:

- 通过 GitBook 安装:把插件名称 `prism` 添加到 `book.json` 的 `plugins` 列表,执行 `gitbook install` 命令
- 通过 nodejs 安装:执行 `npm install gitbook-plugin-prism` 命令安装指定插件,然后把插件名称 `prism` 配置到 `book.json` 的 `plugins` 列表使其生效

> 方法一每次执行都会检查现有插件是否需要更新。

 方法二只有特定插件受影响,适合于存在自定义修改过插件代码的情况。

注意, Guthub Pages 不支持使用了 Octopress 框架的插件,详见 《[About GitHub Pages and Jekyll](https://help.github.com/en/github/working-with-github-pages/about-github-pages-and-jekyll)》 。

若使用了这类插件,Guthub Pages 是无法发布成功的。 判定是不是使用了这类插件的方法也很简单:

- 提交变更内容后,点击 Github 仓库下的 branch 查看 master 分支
- master 分支会提示最近提交内容的 Guthub Pages 构建情况
- 若构建失败,可以点击 Details 查看详情
- 假如提示 `is not a recognised Liquid tag` 说明就是采用了 Octopress 框架的插件

![](https://github.com/lyy289065406/gitbook-server-docker/blob/master/img/08.png)
![](https://github.com/lyy289065406/gitbook-server-docker/blob/master/img/09.png)
![](https://github.com/lyy289065406/gitbook-server-docker/blob/master/img/10.png)

### 0x06 怎样开发 GitBook 自定义插件?

> 参考[这里](https://github.com/iuap-design/blog/issues/11)

### 0x07 怎样共享这个 Docker 镜像?

先执行 `docker login` 命令登陆,然后提交到个人的 Docker Hub 仓库:

`docker push exp/gitbook-server:latest`

若提示 *denied: requested access to the resource is denied* 提交失败,是因为镜像 tag 名称 `/` 前面部分的空间名不是个人的用户名,先修改 tag 名称即可(例如我的用户名是 *expm02* ):

`docker tag fdc060ba7253 expm02/gitbook-server:latest`

![](https://github.com/lyy289065406/gitbook-server-docker/blob/master/img/06.png)

### 0x08 怎样获取共享的 Docker 镜像?

直接执行以下命令即可(这样就不用执行前文的安装步骤了):

`docker pull expm02/gitbook-server:latest`

![](https://github.com/lyy289065406/gitbook-server-docker/blob/master/img/07.png)

### 0x09 Github Page 构建超时?

GitBook 构建的仓库有个问题,会随着内容增多、构建次数增加,变得越来越大。

当仓库超过一定大小时, Github Page 会因为超时而构建失败。

此时最有效的做法就是清洗仓库历史记录,按顺序执行以下命令即可:

```
rm -rf .git
git init
git add -A
git commit -m "clear history"
git remote add origin
git push -f -u origin master
```