# 快速上手
目前,Kubenetes 支持在多种环境下的安装,包括本地主机(Fedora)、云服务(Google GAE、AWS 等)。然而最快速体验 Kubernetes 的方式显然是本地通过 Docker 的方式来启动相关进程。
下图展示了在单节点使用 Docker 快速部署一套 Kubernetes 的拓扑。
![](https://box.kancloud.cn/2015-12-16_5671229935902.png)
Kubernetes 依赖 Etcd 服务来维护所有主节点的状态。
## 启动 Etcd 服务。
```
<pre class="prettyprint"><ol class="linenums"><li class="l"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln">docker run </span><span class="pun">--</span><span class="pln">net</span><span class="pun">=</span><span class="pln">host </span><span class="pun">-</span><span class="pln">d gcr</span><span class="pun">.</span><span class="pln">io</span><span class="pun">/</span><span class="pln">google_containers</span><span class="pun">/</span><span class="pln">etcd</span><span class="pun">:</span><span class="lit">2.0</span><span class="pun">.</span><span class="lit">9</span><span class="pln"> </span><span class="pun">/</span><span class="pln">usr</span><span class="pun">/</span><span class="kwd">local</span><span class="pun">/</span><span class="pln">bin</span><span class="pun">/</span><span class="pln">etcd </span><span class="pun">--</span><span class="pln">addr</span><span class="pun">=</span><span class="lit">127.0</span><span class="pun">.</span><span class="lit">0.1</span><span class="pun">:</span><span class="lit">4001</span><span class="pln"> </span><span class="pun">--</span><span class="pln">bind</span><span class="pun">-</span><span class="pln">addr</span><span class="pun">=</span><span class="lit">0.0</span><span class="pun">.</span><span class="lit">0.0</span><span class="pun">:</span><span class="lit">4001</span><span class="pln"> </span><span class="pun">--</span><span class="pln">data</span><span class="pun">-</span><span class="pln">dir</span><span class="pun">=/</span><span class="pln">var</span><span class="pun">/</span><span class="pln">etcd</span><span class="pun">/</span><span class="pln">data</span></code></li></ol>
```
## 启动主节点
启动 kubelet。
```
<pre class="prettyprint"><ol class="linenums"><li class="l"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln">docker run </span><span class="pun">--</span><span class="pln">net</span><span class="pun">=</span><span class="pln">host </span><span class="pun">-</span><span class="pln">d </span><span class="pun">-</span><span class="pln">v </span><span class="pun">/</span><span class="pln">var</span><span class="pun">/</span><span class="pln">run</span><span class="pun">/</span><span class="pln">docker</span><span class="pun">.</span><span class="pln">sock</span><span class="pun">:/</span><span class="pln">var</span><span class="pun">/</span><span class="pln">run</span><span class="pun">/</span><span class="pln">docker</span><span class="pun">.</span><span class="pln">sock gcr</span><span class="pun">.</span><span class="pln">io</span><span class="pun">/</span><span class="pln">google_containers</span><span class="pun">/</span><span class="pln">hyperkube</span><span class="pun">:</span><span class="pln">v0</span><span class="pun">.</span><span class="lit">17.0</span><span class="pln"> </span><span class="pun">/</span><span class="pln">hyperkube kubelet </span><span class="pun">--</span><span class="pln">api_servers</span><span class="pun">=</span><span class="pln">http</span><span class="pun">://</span><span class="pln">localhost</span><span class="pun">:</span><span class="lit">8080</span><span class="pln"> </span><span class="pun">--</span><span class="pln">v</span><span class="pun">=</span><span class="lit">2</span><span class="pln"> </span><span class="pun">--</span><span class="pln">address</span><span class="pun">=</span><span class="lit">0.0</span><span class="pun">.</span><span class="lit">0.0</span><span class="pln"> </span><span class="pun">--</span><span class="pln">enable_server </span><span class="pun">--</span><span class="pln">hostname_override</span><span class="pun">=</span><span class="lit">127.0</span><span class="pun">.</span><span class="lit">0.1</span><span class="pln"> </span><span class="pun">--</span><span class="pln">config</span><span class="pun">=/</span><span class="pln">etc</span><span class="pun">/</span><span class="pln">kubernetes</span><span class="pun">/</span><span class="pln">manifests</span></code></li></ol>
```
## 启动服务代理
```
<pre class="prettyprint"><ol class="linenums"><li class="l"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln">docker run </span><span class="pun">-</span><span class="pln">d </span><span class="pun">--</span><span class="pln">net</span><span class="pun">=</span><span class="pln">host </span><span class="pun">--</span><span class="pln">privileged gcr</span><span class="pun">.</span><span class="pln">io</span><span class="pun">/</span><span class="pln">google_containers</span><span class="pun">/</span><span class="pln">hyperkube</span><span class="pun">:</span><span class="pln">v0</span><span class="pun">.</span><span class="lit">17.0</span><span class="pln"> </span><span class="pun">/</span><span class="pln">hyperkube proxy </span><span class="pun">--</span><span class="pln">master</span><span class="pun">=</span><span class="pln">http</span><span class="pun">://</span><span class="lit">127.0</span><span class="pun">.</span><span class="lit">0.1</span><span class="pun">:</span><span class="lit">8080</span><span class="pln"> </span><span class="pun">--</span><span class="pln">v</span><span class="pun">=</span><span class="lit">2</span></code></li></ol>
```
## 测试状态
在本地访问 `8080` 端口,可以获取到如下的结果:
```
<pre class="prettyprint"><ol class="linenums"><li class="l"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln">$ curl </span><span class="lit">127.0</span><span class="pun">.</span><span class="lit">0.1</span><span class="pun">:</span><span class="lit">8080</span></code></li>
<li class="l1"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pun">{</span></code></li>
<li class="l"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln"> </span><span class="str">"paths"</span><span class="pun">:</span><span class="pln"> </span><span class="pun">[</span></code></li>
<li class="l1"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln"> </span><span class="str">"/api"</span><span class="pun">,</span></code></li>
<li class="l"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln"> </span><span class="str">"/api/v1beta1"</span><span class="pun">,</span></code></li>
<li class="l1"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln"> </span><span class="str">"/api/v1beta2"</span><span class="pun">,</span></code></li>
<li class="l"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln"> </span><span class="str">"/api/v1beta3"</span><span class="pun">,</span></code></li>
<li class="l1"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln"> </span><span class="str">"/healthz"</span><span class="pun">,</span></code></li>
<li class="l"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln"> </span><span class="str">"/healthz/ping"</span><span class="pun">,</span></code></li>
<li class="l1"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln"> </span><span class="str">"/logs/"</span><span class="pun">,</span></code></li>
<li class="l"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln"> </span><span class="str">"/metrics"</span><span class="pun">,</span></code></li>
<li class="l1"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln"> </span><span class="str">"/static/"</span><span class="pun">,</span></code></li>
<li class="l"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln"> </span><span class="str">"/swagger-ui/"</span><span class="pun">,</span></code></li>
<li class="l1"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln"> </span><span class="str">"/swaggerapi/"</span><span class="pun">,</span></code></li>
<li class="l"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln"> </span><span class="str">"/validate"</span><span class="pun">,</span></code></li>
<li class="l1"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln"> </span><span class="str">"/version"</span></code></li>
<li class="l"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln"> </span><span class="pun">]</span></code></li>
<li class="l1"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pun">}</span></code></li>
</ol>
```
## 查看服务
所有服务启动后,查看本地实际运行的 Docker 容器,有如下几个。
```
<pre class="prettyprint"><ol class="linenums"><li class="l"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln">CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES</span></code></li>
<li class="l1"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln">ee054db2516c gcr</span><span class="pun">.</span><span class="pln">io</span><span class="pun">/</span><span class="pln">google_containers</span><span class="pun">/</span><span class="pln">hyperkube</span><span class="pun">:</span><span class="pln">v0</span><span class="pun">.</span><span class="lit">17.0</span><span class="pln"> </span><span class="str">"/hyperkube schedule 2 days ago Up 1 days k8s_scheduler.509f29c9_k8s-master-127.0.0.1_default_9941e5170b4365bd4aa91f122ba0c061_e97037f5</span></code></li>
<li class="l"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="str">3b0f28de07a2 gcr.io/google_containers/hyperkube:v0.17.0 "</span><span class="pun">/</span><span class="pln">hyperkube apiserve </span><span class="lit">2</span><span class="pln"> days ago </span><span class="typ">Up</span><span class="pln"> </span><span class="lit">1</span><span class="pln"> days k8s_apiserver</span><span class="pun">.</span><span class="lit">245e44fa</span><span class="pln">_k8s</span><span class="pun">-</span><span class="pln">master</span><span class="pun">-</span><span class="lit">127.0</span><span class="pun">.</span><span class="lit">0.1</span><span class="pln">_default_9941e5170b4365bd4aa91f122ba0c061_6ab5c23d</span></code></li>
<li class="l1"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="lit">2eaa44ecdd8e</span><span class="pln"> gcr</span><span class="pun">.</span><span class="pln">io</span><span class="pun">/</span><span class="pln">google_containers</span><span class="pun">/</span><span class="pln">hyperkube</span><span class="pun">:</span><span class="pln">v0</span><span class="pun">.</span><span class="lit">17.0</span><span class="pln"> </span><span class="str">"/hyperkube controll 2 days ago Up 1 days k8s_controller-manager.33f83d43_k8s-master-127.0.0.1_default_9941e5170b4365bd4aa91f122ba0c061_1a60106f</span></code></li>
<li class="l"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="str">30aa7163cbef gcr.io/google_containers/hyperkube:v0.17.0 "</span><span class="pun">/</span><span class="pln">hyperkube proxy </span><span class="pun">--</span><span class="pln"> </span><span class="lit">2</span><span class="pln"> days ago </span><span class="typ">Up</span><span class="pln"> </span><span class="lit">1</span><span class="pln"> days jolly_davinci</span></code></li>
<li class="l1"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln">a2f282976d91 gcr</span><span class="pun">.</span><span class="pln">io</span><span class="pun">/</span><span class="pln">google_containers</span><span class="pun">/</span><span class="pln">pause</span><span class="pun">:</span><span class="lit">0.8</span><span class="pun">.</span><span class="lit">0</span><span class="pln"> </span><span class="str">"/pause"</span><span class="pln"> </span><span class="lit">2</span><span class="pln"> days ago </span><span class="typ">Up</span><span class="pln"> </span><span class="lit">2</span><span class="pln"> days k8s_POD</span><span class="pun">.</span><span class="pln">e4cc795_k8s</span><span class="pun">-</span><span class="pln">master</span><span class="pun">-</span><span class="lit">127.0</span><span class="pun">.</span><span class="lit">0.1</span><span class="pln">_default_9941e5170b4365bd4aa91f122ba0c061_e8085b1f</span></code></li>
<li class="l"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="pln">c060c52acc36 gcr</span><span class="pun">.</span><span class="pln">io</span><span class="pun">/</span><span class="pln">google_containers</span><span class="pun">/</span><span class="pln">hyperkube</span><span class="pun">:</span><span class="pln">v0</span><span class="pun">.</span><span class="lit">17.0</span><span class="pln"> </span><span class="str">"/hyperkube kubelet 2 days ago Up 1 days serene_nobel</span></code></li>
<li class="l1"><code class="pcalibre10 pcalibre11 pcalibre9"><span class="str">cc3cd263c581 gcr.io/google_containers/etcd:2.0.9 "</span><span class="pun">/</span><span class="pln">usr</span><span class="pun">/</span><span class="kwd">local</span><span class="pun">/</span><span class="pln">bin</span><span class="pun">/</span><span class="pln">etcd </span><span class="lit">2</span><span class="pln"> days ago </span><span class="typ">Up</span><span class="pln"> </span><span class="lit">1</span><span class="pln"> days happy_turing</span></code></li>
</ol>
```
这些服务大概分为三类:主节点服务、工作节点服务和其它服务。
### 主节点服务
- `apiserver` 是整个系统的对外接口,提供 RESTful 方式供客户端和其它组件调用;
- `scheduler` 负责对资源进行调度,分配某个 pod 到某个节点上;
- `controller-manager` 负责管理控制器,包括 endpoint-controller(刷新服务和 pod 的关联信息)和 replication-controller(维护某个 pod 的复制为配置的数值)。
### 工作节点服务
- `kubelet` 是工作节点执行操作的 agent,负责具体的容器生命周期管理,根据从数据库中获取的信息来管理容器,并上报 pod 运行状态等;
- `proxy` 为 pod 上的服务提供访问的代理。
### 其它服务
- Etcd 是所有状态的存储数据库;
- `gcr.io/google_containers/pause:0.8.0` 是 Kubernetes 启动后自动 pull 下来的测试镜像。
- 致谢
- 目录
- 01. 前言
- 02. 修订记录
- 03. 如何贡献
- 04. Docker 简介
- 什么是 Docker
- 为什么要用 Docker
- 05. 基本概念
- 镜像
- 容器
- 仓库
- 06. 安装 Docker
- Ubuntu
- Debian
- CentOS
- Raspberry Pi
- macOS
- Windows PC
- 镜像加速器
- 07.使用镜像
- 获取镜像
- 列出镜像
- 删除本地镜像
- 利用 commit 理解镜像构成
- 使用 Dockerfile 定制镜像
- Dockerfile 指令详解
- COPY 复制文件
- ADD 更高级的复制文件
- CMD 容器启动命令
- ENTRYPOINT 入口点
- ENV 设置环境变量
- ARG 构建参数
- VOLUME 定义匿名卷
- EXPOSE 暴露端口
- WORKDIR 指定工作目录
- USER 指定当前用户
- HEALTHCHECK 健康检查
- ONBUILD 为他人作嫁衣裳
- 参考文档
- Dockerfile 多阶段构建
- 其它制作镜像的方式
- 实现原理
- 08. 操作容器
- 启动
- 守护态运行
- 终止
- 进入容器
- 导出和导入
- 删除
- 09. 访问仓库
- Docker Hub
- 私有仓库
- 私有仓库高级配置
- 10. 数据管理
- 数据卷
- 监听主机目录
- 11. 使用网络
- 外部访问容器
- 容器互联
- 配置 DNS
- 12. 高级网络配置
- 快速配置指南
- 容器访问控制
- 配置 docker0 网桥
- 自定义网桥
- 工具和示例
- 编辑网络配置文件
- 实例:创建一个点到点连接
- 映射容器端口到宿主主机的实现
- 13. Docker 三剑客之 Compose 项目
- 简介
- 安装与卸载
- 使用
- 命令说明
- Compose 模板文件
- 实战 Django
- 实战 Rails
- 实战 WordPress
- 14. Docker 三剑客之 Machine 项目
- 安装
- 使用
- 15. Docker 三剑客之 Docker Swarm
- 16. Swarm mode
- 基本概念
- 创建 Swarm 集群
- 部署服务
- 使用 compose 文件
- 管理敏感数据
- 管理配置信息
- 17. 安全
- 内核命名空间
- 控制组
- 服务端防护
- 内核能力机制
- 其它安全特性
- 总结
- 18. 底层实现
- 基本架构
- 命名空间
- 控制组
- 联合文件系统
- 容器格式
- 网络
- 19. Etcd 项目
- 简介
- 安装
- 集群
- 使用 etcdctl
- 使用 etcdctl v2
- 20. CoreOS 项目
- 简介
- 工具
- 快速搭建 CoreOS 集群
- 21. Kubernetes 项目
- 简介
- 快速上手
- 基本概念
- kubectl 使用
- 架构设计
- 22. Mesos - 优秀的集群资源调度平台
- Mesos 简介
- 安装与使用
- 原理与架构
- Mesos 配置项解析
- 日志与监控
- 常见应用框架
- 本章小结
- 23. 容器与云计算
- 简介
- 亚马逊云
- 腾讯云
- 阿里云
- 小结
- 24. 实战案例-操作系统
- Busybox
- Alpine
- Debian Ubuntu
- CentOS Fedora
- 本章小结
- 25. 实战案例-CI-CD
- Drone
- 26. Docker 开源项目
- LinuxKit
- 27. 附录
- 附录一:常见问题总结
- 附录二:热门镜像介绍
- Ubuntu
- CentOS
- MySQL
- MongoDB
- Redis
- Nginx
- WordPress
- Node.js
- 附录三:Docker 命令查询
- 附录四:Dockerfile 最佳实践
- 附录五:资源链接
- 附录六:Docker 中文资源