第一本Docker书(The docker book)

第一本Docker书(The docker book)





作者简介

James Turnbull是一位技术作家,还是一名开源极客。他最近的大作是一本讲述流行开源日志工具的书——The LogStash Book。James还写了两本关于Puppet的书,一本是Pro Puppet以,另一本是较早的Pulling Strings with Puppet: Configuration Management Made Easy。此外,James还写了Pro Linux System Administration、Pro Nagios 2.0和Hardening Linux这三本书。
James真正的工作是Kickstarter的工程副总裁。之前,James曾担任Docker公司服务与支持副总裁、Venmo公司工程副总裁和 Puppet Labs的技术运维副总裁。James热爱美食、美酒、阅读、摄影,还很喜欢猫咪,但对在海滩上手牵手散步却并不热衷。 

译者简介

兆海 网名Googol Lee。使用Googol这个名字真的是因为“10的100次方”这个意思,和后来的Google公司没有一点儿关系。多年后端程序员,早期以C、C++ 为主,后来转向Python,现在以Go为生。曾写过《Golang初探》发表于2011年2月号《程序员》。Docker早期使用者。平时喜欢乱翻书, 遇到感兴趣的都会研究一番。Twitter账户@googollee。  李兆海 网名Googol Lee。使用Googol这个名字真的是因为“10的100次方”这个意思,和后来的Google公司没有一点儿关系。多年后端程序员,早期以C、C++ 为主,后来转向Python,现在以Go为生。曾写过《Golang初探》发表于2011年2月号《程序员》。Docker早期使用者。平时喜欢乱翻书, 遇到感兴趣的都会研究一番。Twitter账户@googollee。


斌 具有10余年软件开发经验,关注后台开发技术和各种编程语言。做过电子商务、金融、企业系统以及Android手机开发;写过Delphi,也兼做系统管 理员和DBA(现在都改叫DevOps了);既做后台应用,也要调用前台CSS和JavaScript,可还是不敢自称Full Stack;今又舶来Growth Hacker,我想我要做一个Growth Engineer。


震 北京大学软件工程硕士,服务器端开发者。目前就职于创业公司,使用Node.js、Golang进行服务器端开发。2013年底开始研究Docker,是 Docker中文社区的活跃贡献者,负责Docker技术文章和视频的翻译、校对工作。生

活中喜欢美食、骑行,热衷于PC硬件,喜爱折腾,热爱一切计算机 相关的技术,坚信技术改变世界。最崇拜的技术传奇人物是前id Software首席程序员、现Oculus VR首席技术官John Carmack。

目录章节

第1 章 简介
1.1 Docker 简介
1.1.1 提供一个简单、轻量的建模方式
1.1.2 职责的逻辑分离
1.1.3 快速、高效的开发生命周期
1.1.4 鼓励使用面向服务的架构
1.2 Docker 组件
1.2.1 Docker 客户端和服务器
1.2.2 Docker 镜像
1.2.3 Registry 
1.2.4 容器
1.3 我们能用Docker 做什么
1.4 Docker 与配置管理
1.5 Docker 的技术组件
1.6 本书的内容
1.7 Docker 资源

第2 章 安装Docker  
2.1 安装Docker 的先决条件 
2.2 在Ubuntu 中安装Docker  
2.2.1 检查前提条件 
2.2.2 安装Docker  
2.2.3 Docker 与UFW  
2.3 在Red Hat 和Red Hat 系发行版中安装Docker 
2.3.1 检查前提条件 
2.3.2 安装Docker 
2.3.3 在Red Hat 系发行版中启动Docker 守护进程 
2.4 在OS X 中安装Boot2Docker  
2.4.1 在OS X 中安装Boot2Docker  
2.4.2 在OS X 中启动Boot2Docker  
2.4.3 测试Boot2Docker  
2.5 在Windows 中安装Boot2Docker 
2.5.1 在Windows 中安装Boot2Docker  
2.5.2 在Windows 中启动Boot2Docker  
2.5.3 测试Boot2Docker  
2.6 使用本书的Boot2Docker 示例 
2.7 Docker 安装脚本 
2.8 二进制安装 
2.9 Docker 守护进程 
2.9.1 配置Docker 守护进程 
2.9.2 检查Docker 守护进程是否正在运行 
2.10 升级Docker  
2.11 Docker 图形用户界面 
2.12 小结

第3 章 Docker 入门 
3.1 确保Docker 已经就绪 
3.2 运行我们的第一个容器 
3.3 使用第一个容器 
3.4 容器命名 
3.5 重新启动已经停止的容器 
3.6 附着到容器上 
3.7 创建守护式容器 
3.8 容器内部都在干些什么 
3.9 查看容器内的进程 
3.10 在容器内部运行进程 
3.11 停止守护式容器 
3.12 自动重启容器 
3.13 深入容器 
3.14 删除容器 
3.15 小结

第4 章 使用Docker 镜像和仓库 
4.1 什么是Docker 镜像 
4.2 列出镜像 
4.3 拉取镜像 
4.4 查找镜像 
4.5 构建镜像 
4.5.1 创建Docker Hub 账号 
4.5.2 用Docker 的commit 命令创建镜像 
4.5.3 用Dockerfile构建镜像 
4.5.4 基于Dockerfile构建新镜像 
4.5.5 指令失败时会怎样 
4.5.6 Dockerfile 和构建缓存 
4.5.7 基于构建缓存的Dockerfile模板 
4.5.8 查看新镜像 
4.5.9 从新镜像启动容器 
4.5.10 Dockerfile 指令 
4.6 将镜像推送到Docker Hub 
4.7 删除镜像 
4.8 运行自己的Docker Registry 
4.8.1 从容器运行Registry  
4.8.2 测试新Registry  
4.9 其他可选Registry 服务 
4.10 小结

第5 章 在测试中使用Docker 
5.1 使用Docker 测试静态网站 
5.1.1 Sample 网站的初始Dockerfile  
5.1.2 构建Sample 网站和Nginx镜像 
5.1.3 从Sample 网站和Nginx 镜像构建容器 
5.1.4 修改网站 
5.2 使用Docker 构建并测试Web应用程序 
5.2.1 构建Sinatra 应用程序 
5.2.2 创建Sinatra 容器 
5.2.3 构建Redis 镜像和容器 
5.2.4 连接到Redis 容器 
5.2.5 连接Redis 
5.2.6 让Docker 容器互连 
5.2.7 使用容器连接来通信 
5.3 Docker 用于持续集成 
5.3.1 构建Jenkins 和Docker服务器 
5.3.2 创建新的Jenkins 作业
5.3.3 运行Jenkins 作业
5.3.4 与Jenkins 作业有关的下一步
5.3.5 Jenkins 设置小结
5.4 多配置的Jenkins
5.4.1 创建多配置作业
5.4.2 测试多配置作业
5.4.3 Jenkins 多配置作业小结
5.5 其他选择
5.5.1 Drone 
5.5.2 Shippable 
5.6 小结

第6 章 使用Docker 构建服务
6.1 构建第一个应用
6.1.1 Jekyll 基础镜像
6.1.2 构建Jekyll 基础镜像
6.1.3 Apache 镜像
6.1.4 构建Jekylll Apache 镜像
6.1.5 启动Jekylll 网站
6.1.6 更新Jekyll 网站
6.1.7 备份Jekyll 卷
6.1.8 扩展Jekyll 示例网站
6.2 使用Docker 构建一个Java应用服务
6.2.1 WAR 文件的获取器
6.2.2 获取WAR 文件
6.2.3 Tomecat7 应用服务器
6.2.4 运行WAR 文件
6.2.5 基于Tomcat 应用服务器的构建服务
6.3 多容器的应用栈
6.3.1 Node.js 镜像
6.3.2 Redis 基础镜像 
6.3.3 Redis 主镜像 
6.3.4 Redis 从镜像 
6.3.5 创建Redis 后端集群 
6.3.6 创建Node 容器 
6.3.7 捕获应用日志 
6.3.8 Node 程序栈的小结 
6.4 不使用SSH 管理Docker 容器 
6.5 小结

第7 章 使用Fig 编配Docker 
7.1 Fig  
7.1.1 安装Fig  
7.1.2 获取示例应用 
7.1.3 fig.yml 文件 
7.1.4 运行Fig  
7.1.5 使用Fig  
7.1.6 Fig 小结 
7.2 Consul、服务发现和Docker  
7.2.1 构建Consul 镜像 
7.2.2 在本地测试Consul 容器 
7.2.3 使用Docker 运行Consul集群 
7.2.4 启动具有自启动功能的Consul 节点 
7.2.5 启动其余节点 
7.2.6 配合Consul,在Docker里运行一个分布式服务 
7.3 其他编配工具和组件 
7.3.1 Fleet 和etcd 
7.3.2 Kubernetes 
7.3.3 Apache Mesos 
7.3.4 Helios  
7.3.5 Centurion  
7.3.6 Libswarm 
7.4 小结

第8 章 使用Docker API 
8.1 Docker API 
8.2 初识Remote API
8.3 测试Docker Remote API 
8.3.1 通过API 来管理Docker镜像
8.3.2 通过API 管理Docker容器
8.4 改进TProv 应用
8.5 对Docker Remote API 进行认证
8.5.1 建立证书授权中心
8.5.2 创建服务器的证书签名请求和密钥
8.5.3 配置Docker 守护进程
8.5.4 创建客户端证书和秘钥
8.5.5 配置Docker 客户端开启认证功能
8.6 小结

第9 章 获得帮助和对Docker进行改进 
9.1 获得帮助 
9.1.1 Docker 用户和开发邮件列表 
9.1.2 IRC 上的Docker  
9.1.3 GitHub 上的Docker  
9.2 报告Docker 的问题 
9.3 搭建构建环境 
9.3.1 安装Docker 
9.3.2 安装源代码和构建工具 
9.3.3 检出源代码 
9.3.4 贡献文档 
9.3.5 构建开发环境 
9.3.6 运行测试 
9.3.7 在开发环境中使用Docker 
9.3.8 发起pull request  
9.3.9 批准合并和维护者 
9.4 小结