[授权发表]Docker 快速上手:用 Docker + GitBook 写书

By Falcon of TinyLab.org
泰晓沙龙第二期 @ 2015/04/26

最初发表:泰晓科技 – 聚焦嵌入式 Linux,追本溯源,见微知著!
原文链接:Docker 快速上手:用 Docker + GitBook 写书
评论说明:为更好地聚合大家的讨论,请到上面原文的评论区回复。


准备 GitBook 环境

安装 Docker

  • 以Ubuntu为例

      $ echo deb http://get.docker.io/ubuntu docker main \
          | sudo tee /etc/apt/sources.list.d/docker.list
      $ sudo apt-key adv --keyserver keyserver.ubuntu.com \
          --recv-keys 36A1D7869245C8950F966E92D8576A8BA88D21E9
      $ sudo apt-get update
      $ sudo apt-get install -y lxc-docker
    

安装 GitBook 环境

  • 搜索镜像

      $ sudo docker search gitbook
      NAME  DESCRIPTION   STARS     OFFICIAL   AUTOMATED
      tobegit3hub/gitbook-server 2             [OK]
    
  • 安装镜像

    • ubuntu

    • npm + nodejs

    • gitbook + calibre(ebook-convert)

        $ sudo docker pull tobegit3hub/gitbook-server
      

完善 GitBook 环境

  • 启动 GitBook 环境

      $ sudo docker images | grep gitbook
      tobegit3hub/gitbook-server   latest d171079650c8
      $ sudo docker run -i -t \
      tobegit3hub/gitbook-server /bin/bash
    
  • 安装 字体 和 Git

      $ apt-get install git
      $ apt-get install fonts-arphic-gbsn00lp
    

用 GitBook 写书

基础准备

  • Markdown

    • 当前最流行的内容创作标记语言
    • Google自然设计:突出内容,抛弃繁杂的格式!
    • Markdown 基本语法
    • Markdown 编辑器:retext
  • Pandoc

    • 各种格式自由转换
    • Pandoc Markdown 语法
  • GitBook

    • GitBook 快速上手
    • GitBook 简明教程

GitBook 核心文件

  • GitBook 本身是一个 Git 仓库

    • .gitignore: 需要忽略的临时内容
  • 重要组件

    • README.md: 书籍简介
    • SUMMARY.md: 图书结构,文章索引
    • LANGS.md: 多国语言,每种一个目录
    • GLOSSARY.md: 词汇表
    • cover.jpg: 图书封面
    • cover_small.jpg: 小尺寸图书封面

GitBook 输出格式

  • 静态 HTML 页面

    • gitbook build ./ --output=./_book/
  • PDF

    • gitbook pdf

GitBook 在线预览

  • 启动服务
    • gitbook serve ./

Starting server …

Serving book on http://localhost:4000

  • 在线预览
    • 用浏览器打开: http://localhost:4000

杂项

  • Json 语法错误
    • book.json:不支持注释等。
    • JSON 在线验证

SyntaxError:…/book.json:Unexpected token o

  • GitBook 调试

    • export DEBUG=true
  • GitBook 插件

    • Google Analytics
    • Disqus: Comments
    • Exercises

GitBook 图书实例

下载和编译图书

  • 下载

      $ git clone \
      https://github.com/tobegit3hub/understand_linux_process.git
    
  • 编译

      $ cd understand_linux_process
      $ gitbook build
      $ gitbook pdf
    

在线预览图书

  • Docker 侧

    • 启动图书服务器

        $ ifconfig eth0 | grep "inet addr"
        inet addr:172.17.0.31 ...
        $ gitbook serve ./
        Starting server ...
        Serving book on http://localhost:4000
      
  • 主机侧

    • 在浏览器访问:http://172.17.0.31:4000

从 Docker 拷贝出 pdf

  • Docker 侧:确认 pdf 路径

      $ readlink -f book.pdf
      /gitbook/understand_linux_process/book.pdf
    
  • 主机侧:docker cp CONTAINER_ID:PATH HOSTPATH

      $ sudo docker ps -a
      CONTAINER ID   IMAGE              COMMAND
      cf5925e tobegit3hub/gitbook-server "/bin/bash"
      $ sudo docker cp \
      cf5925e:/gitbook/understand_linux_process/book.pdf .
    

从 主机 拷入 Docker

  • 两个步骤
    • 获取容器挂载路径

    • 通过本地 cp 命令直接拷贝进去

        $ fullid=`sudo docker inspect -f '{{.Id}}' cf5925e`
        $ gitbook=/var/lib/docker/aufs/mnt/$fullid/gitbook/
        $ ls $gitbook
        understand_linux_process
        $ cp book.pdf $gitbook/book-from-host.pdf
      

直接挂载卷共享

  • 挂载主机 GitBook 目录到 Docker

      $ sudo docker run -i -t \
        -v /path/to/mybook/:/gitbook/ \
        tinylab/gitbook /bin/bash
    

新建 GitBook 环境

备份/导出/导入容器

  • 保存容器为新镜像: commit

      $ sudo docker commit cf5925e tinylab/gitbook
      $ sudo docker images | grep tinylab/gitbook
      tinylab/gitbook latest 2106b9f7f675
    
  • 导出镜像文件: save/export

      $ sudo docker save tinylab/gitbook > gitbook.tar
    
  • 导入镜像文件到其他主机上: load/import

      $ sudo docker load < gitbook.tar
    

其他操作

  • 删除/杀掉容器

    • docker rm [-f] contaier_id
    • docker kill contaier_id
  • 停止容器

    • docker stop container_id
  • 启动容器

    • docker start container_id
  • 删除镜像

    • docker rmi image_id

新建 GitBook Dockerfile

# Dockerfile
FROM ubuntu:14.04
MAINTAINER Falcon [email protected]
RUN sed -i -e "s/archive.ubuntu.com/mirrors.163.com/g" \
    /etc/apt/sources.list
RUN apt-get -y update
RUN apt-get install -y nodejs npm git && \
    npm install gitbook -g
RUN apt-get install -y calibre
RUN apt-get install -y fonts-arphic-gbsn00lp
RUN mkdir /gitbook
WORKDIR /gitbook
EXPOSE 4000
CMD ["gitbook", "serve", "/gitbook"]

新建 GitBook Dockerfile(续)

# Dockerfile
FROM ubuntu:14.04
MAINTAINER Falcon [email protected]
RUN sed -i -e "s/archive.ubuntu.com/mirrors.163.com/g" \
    /etc/apt/sources.list
RUN apt-get -y update
RUN apt-get install -y curl git && cd / && \
    git clone https://github.com/creationix/nvm.git nvm && \
    echo ". /nvm/nvm.sh" > ~/.bashrc && . ~/.bashrc && \
    nvm install 0.12.2 && nvm use 0.12.2 && \
    npm install gitbook -g
RUN apt-get install -y calibre
RUN apt-get install -y fonts-arphic-gbsn00lp
RUN mkdir /gitbook
WORKDIR /gitbook
EXPOSE 4000
CMD ["gitbook", "serve", "/gitbook"]

基于 Dockerfile 构建映像

  • 快速构建

      $ sudo docker build -t tinylab/gitbook ./
    
  • 更多参数: Cgroup

-c, --cpu-shares=0 CPU shares (relative weight)

–cpuset-cpus= CPUs in which to allow execution (0-3, 0,1)

-m, --memory= Memory limit

参考资料


  • Gitbook 快速上手
  • GitBook 简明教程
  • Ubuntu環境下,如何安裝nvm以及nodejs
  • Ubuntu環境下,快速開始使用gitbook
  • Docker详细的基本用法
  • 支持中文搜索的gitbook

你可能感兴趣的:(VM,Markdown,Linux,虚拟化技术实践)