第一篇 基础篇:Docker基础
第1章 Docker简介
1.1 Docker简介
1.1.1 Docker的概念
1.1.2 Docker的背景
1.1.3 容器与虚拟机
1.1.4 Docker与容器
1.1.5 Docker的应用场景
1.2 Docker的组件
1.3 Docker的相关技术
1.4 Docker的安装
1.4.1 Ubuntu下的安装
1.4.2 Red Hat下的安装
1.4.3 OS X下的安装
1.4.4 Windows下的安装
第2章 容器
2.1 容器的管理操作
2.1.1 创建容器
2.1.2 查看容器
2.1.3 启动容器
2.1.4 终止容器
2.1.5 删除容器
2.2 容器内信息获取和命令执行
2.2.1 依附容器
2.2.2 查看容器日志
2.2.3 查看容器进程
2.2.4 查看容器信息
2.2.5 容器内执行命令
2.3 容器的导入和导出
第3章 镜像
3.1 镜像的概念
3.1.1 镜像与容器
3.1.2 镜像的系统结构
3.1.3 镜像的写时复制机制
3.2 本地镜像的管理
3.2.1 查看
3.2.2 下载
3.2.3 删除
3.3 创建本地镜像
3.3.1 使用commit命令创建本地镜像
3.3.2 使用Dockerfile创建镜像
3.4 Docker Hub
3.4.1 Docker Hub简介
3.4.2 镜像的分发
3.4.3 自动化构建
3.4.4 创建注册服务器
第4章 数据卷及容器连接
4.1 容器网络基础
4.1.1 暴露网络端口
4.1.2 查看网络配置
4.2 数据卷
4.2.1 创建数据卷
4.2.2 挂载主机目录作为数据卷
4.2.3 挂载主机文件作为数据卷
4.2.4 数据卷容器
4.2.5 数据的备份与恢复
4.3 容器连接
4.3.1 容器命名
4.3.2 容器连接
4.3.3 代理连接
第二篇 案例篇:综合案例
第5章 创建SSH服务镜像
5.1 基于commit命令的方式
5.2 基于Dockerfile的方式
第6章 综合案例1:Apache+PHP+MySQL
6.1 构建mysql 镜像
6.1.1 编写镜像Dockerfile
6.1.2 构建和上传镜像
6.2 构建apache+php镜像
6.2.1 编写镜像Dockerfile
6.2.2 构建和上传镜像
6.3 启动容器
第7章 综合案例2:DLNNM
7.1 构建mongodb镜像
7.1.1 编写镜像Dockerfile
7.1.2 构建和上传镜像
7.2 构建Node.js镜像
7.2.1 项目源文件
7.2.2 编写镜像Dockerfile
7.2.3 构建和上传镜像
7.3 连接Node.js服务和MongoDB服务
7.3.1 制作代理镜像mongoabassador
7.3.2 启动MongoDB服务
7.3.3 启动Node-Web-API服务
7.4 搭建前端Nginx
7.4.1 构建镜像并运行
7.4.2 验证Web应用
第8章 阿里云Docker开发实践
8.1 阿里云Docker介绍
8.2 部署镜像注册服务器
8.3 开发
8.3.1 项目开发
8.3.2 制作和上传镜像
8.4 测试
8.5 部署
第9章 在阿里云上部署WordPress
9.1 初始化阿里云Docker环境
9.2 部署MySQL容器
9.3 部署WordPress容器
第10章 使用私有仓库
10.1 使用docker-registry
10.2 用户认证
第11章 使用Docker部署Hadoop集群
11.1 Hadoop简介
11.2 构建Hadoop镜像
11.3 构建Hadoop集群
11.3.1 Ambari简介
11.3.2 部署Hadoop集群
第三篇 高级篇:高级话题、API、工具及集群管理
第12章 容器网络
12.1 容器网络的原理
12.1.1 基础网络工具
12.1.2 网络空间虚拟化
12.1.3 网络设备虚拟化
12.1.4 容器运行的4 种网络模式
12.1.5 手动配置容器的网络环境
12.2 配置及原理
12.2.1 基本配置
12.2.2 容器互联配置及原理
12.2.3 容器内访配置及原理
12.2.4 容器外访配置及原理
12.2.5 创建点对点连接
12.3 网桥
12.3.1 配置网桥
12.3.2 构建自己的网桥
第13章 安全
13.1 命名空间
13.2 cgroups
13.3 Linux能力机制
第14章 DockerAPI
14.1 API 概述
14.2 绑定Docker后台监听接口
14.3 远程API
14.3.1 容器相关的API
14.3.2 镜像相关的API
14.4 平台API
14.4.1 注册服务器架构及流程
14.4.2 操作Hub API
14.5 API 实战:docker-py库编程
14.5.1 docker-py开发环境的搭建
14.5.2 docker-py库编程
第15章 Fig
15.1 Fig简介
15.2 Fig安装
15.3 Rails开发环境配置
15.4 Django开发环境配置
15.5 WordPress开发环境配置
15.6 Flocker:跨主机的Fig应用
第16章 Kubernetes
16.1 Kubernetes简介
16.2 核心概念
16.2.1 节点
16.2.2 Pod
16.2.3 服务
16.2.4 标签
16.3 架构和组件
16.3.1 主控节点
16.3.2 从属节点
16.3.3 组件交互流程
16.4 Kubernetes实战
16.4.1 环境部署
16.4.2 应用操作
第17章 shipyard
17.1 简介
17.2 shipyard操作
17.2.1 鉴权
17.2.2 引擎
17.2.3 容器
17.2.4 服务密钥
17.2.5 Web钩子密钥
17.2.6 事件
17.2.7 集群信息
第18章 Machine+Swarm+Compose
18.1 Machine
18.2 Swarm
18.2.1 架构和组件
18.2.2 实操
18.2.3 发现服务和调度
18.3 Compose
第四篇 附录
附录A 常见镜像
附录B Docker API列表
附录C 参考资料
展开
——郝林,Go语言北京用户组发起人,《Go并发编程实战》作者
★腾讯的互娱的开发节奏,只有Docker跟得上!如果你想你的团队加快开发速度,那么我推荐你使用Docker,而本书从基础、案例到高级话题,都有很全面的覆盖。
——易剑,腾讯互动娱乐事业群高级架构师
★这是一本关于Docker的好书,值得所有想了解Docker的人放在键盘左边。
——李毅秋,人人网技术总监
★云计算的初级是数据的云化,下一步是程序的云化,而Docker则是当前程序云化工具。让你的程序一次配置,全网增量迁移、运行。本书出自一线互联网研发人员之手,它是实战的结晶,所涉案例都是互联网公司的真实应用,对Docker的应用都不是浅尝辄止,而是带你登堂入室。
——潘向荣,迅雷看看高级技术经理