Skip to content

Commit 03b1d1f

Browse files
committed
Add the kubernetes quickstart
1 parent eb6683f commit 03b1d1f

File tree

4 files changed

+80
-4
lines changed

4 files changed

+80
-4
lines changed

_images/k8s-singlenode-docker.png

31.1 KB
Loading

kubernetes/design.md

+3-3
Original file line numberDiff line numberDiff line change
@@ -5,8 +5,8 @@
55
## 架构设计
66
![](../_images/kubernetes_design.jpg)
77

8-
* [节点](#nodes)一个节点是一个运行Kubernetes中的主机
9-
* [容器组](#pods)一个Pod对应于由若干容器组成的一个容器组,同个组内的容器共享一个存储卷(volume)。
8+
* [节点](#nodes)一个节点是一个运行 Kubernetes 中的主机
9+
* [容器组](#pods)一个 Pod 对应于由若干容器组成的一个容器组,同个组内的容器共享一个存储卷(volume)。
1010
* [容器组生命周期](#pos-states):包含所有容器状态集合,包括容器组状态类型,容器组生命周期,事件,重启策略,以及replication controllers。
1111
* [Replication Controllers](#replication-controllers):主要负责指定数量的pod在同一时间一起运行。
1212
* [服务](#services):一个Kubernetes服务是容器组逻辑的高级抽象,同时也对外提供访问容器组的策略。
@@ -190,4 +190,4 @@ Kubernetes校验节点可用依赖于id。在当前的版本中,有两个接
190190
<h3 id="labels">标签</h3>
191191
<h3 id="accessing_the_api">接口权限</h3>
192192
<h3 id="ux">web界面</h3>
193-
<h3 id="cli">命令行操作</h3>
193+
<h3 id="cli">命令行操作</h3>

kubernetes/intro.md

+1-1
Original file line numberDiff line numberDiff line change
@@ -16,4 +16,4 @@ Kubernets 目前在[github.com/GoogleCloudPlatform/kubernetes](https://github.co
1616

1717
### Kubernetes 能够运行在任何地方!
1818

19-
虽然Kubernets最初是为GCE定制的,但是在后续版本中陆续增加了其他云平台的支持,以及本地数据中心的支持。
19+
虽然Kubernets最初是为GCE定制的,但是在后续版本中陆续增加了其他云平台的支持,以及本地数据中心的支持。

kubernetes/quickstart.md

+76
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,76 @@
1+
# 快速上手
2+
3+
目前,Kubenetes 支持在多种环境下的安装,包括本地主机(Fedora)、云服务(Google GAE、AWS 等)。然而最快速体验 Kubernetes 的方式显然是本地通过 Docker 的方式来启动相关进程。
4+
5+
下图展示了在单节点使用 Docker 快速部署一套 Kubernetes 的拓扑。
6+
7+
![在 Docker 中启动 Kubernetes](../../_images/k8s-singlenode-docker.png)
8+
9+
Kubernetes 依赖 Etcd 服务来维护所有主节点的状态。
10+
11+
## 启动 Etcd 服务。
12+
```sh
13+
docker run --net=host -d gcr.io/google_containers/etcd:2.0.9 /usr/local/bin/etcd --addr=127.0.0.1:4001 --bind-addr=0.0.0.0:4001 --data-dir=/var/etcd/data
14+
```
15+
16+
## 启动主节点
17+
启动 kubelet。
18+
```sh
19+
docker run --net=host -d -v /var/run/docker.sock:/var/run/docker.sock gcr.io/google_containers/hyperkube:v0.17.0 /hyperkube kubelet --api_servers=http://localhost:8080 --v=2 --address=0.0.0.0 --enable_server --hostname_override=127.0.0.1 --config=/etc/kubernetes/manifests
20+
```
21+
22+
## 启动服务代理
23+
```sh
24+
docker run -d --net=host --privileged gcr.io/google_containers/hyperkube:v0.17.0 /hyperkube proxy --master=http://127.0.0.1:8080 --v=2
25+
```
26+
27+
## 测试状态
28+
在本地访问 8080 端口,应该获取到类似如下的结果:
29+
```sh
30+
$ curl 127.0.0.1:8080
31+
{
32+
"paths": [
33+
"/api",
34+
"/api/v1beta1",
35+
"/api/v1beta2",
36+
"/api/v1beta3",
37+
"/healthz",
38+
"/healthz/ping",
39+
"/logs/",
40+
"/metrics",
41+
"/static/",
42+
"/swagger-ui/",
43+
"/swaggerapi/",
44+
"/validate",
45+
"/version"
46+
]
47+
}
48+
```
49+
50+
## 查看服务
51+
所有服务启动后过一会,查看本地实际运行的 Docker 容器,应该有如下几个。
52+
```sh
53+
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
54+
ee054db2516c gcr.io/google_containers/hyperkube:v0.17.0 "/hyperkube schedule 2 days ago Up 1 days k8s_scheduler.509f29c9_k8s-master-127.0.0.1_default_9941e5170b4365bd4aa91f122ba0c061_e97037f5
55+
3b0f28de07a2 gcr.io/google_containers/hyperkube:v0.17.0 "/hyperkube apiserve 2 days ago Up 1 days k8s_apiserver.245e44fa_k8s-master-127.0.0.1_default_9941e5170b4365bd4aa91f122ba0c061_6ab5c23d
56+
2eaa44ecdd8e gcr.io/google_containers/hyperkube:v0.17.0 "/hyperkube controll 2 days ago Up 1 days k8s_controller-manager.33f83d43_k8s-master-127.0.0.1_default_9941e5170b4365bd4aa91f122ba0c061_1a60106f
57+
30aa7163cbef gcr.io/google_containers/hyperkube:v0.17.0 "/hyperkube proxy -- 2 days ago Up 1 days jolly_davinci
58+
a2f282976d91 gcr.io/google_containers/pause:0.8.0 "/pause" 2 days ago Up 2 days k8s_POD.e4cc795_k8s-master-127.0.0.1_default_9941e5170b4365bd4aa91f122ba0c061_e8085b1f
59+
c060c52acc36 gcr.io/google_containers/hyperkube:v0.17.0 "/hyperkube kubelet 2 days ago Up 1 days serene_nobel
60+
cc3cd263c581 gcr.io/google_containers/etcd:2.0.9 "/usr/local/bin/etcd 2 days ago Up 1 days happy_turing
61+
```
62+
63+
这些服务大概分为三类:主节点服务、工作节点服务和其它服务。
64+
65+
### 主节点服务
66+
* apiserver 是整个系统的对外接口,提供 RESTful 方式供客户端和其它组件调用;
67+
* scheduler 负责对资源进行调度,分配某个 pod 到某个节点上;
68+
* controller-manager 负责管理控制器,包括 endpoint-controller(刷新服务和 pod 的关联信息)和 replication-controller(维护某个 pod 的复制为配置的数值)。
69+
70+
### 工作节点服务
71+
* kubelet 是工作节点执行操作的 agent,负责具体的容器生命周期管理,根据从数据库中获取的信息来管理容器,并上报 pod 运行状态等;
72+
* proxy 为 pod 上的服务提供访问的代理。
73+
74+
### 其它服务
75+
* etcd 是所有状态的存储数据库;
76+
* `gcr.io/google_containers/pause:0.8.0` 是 Kubernetes 启动后自动 pull 下来的测试镜像。

0 commit comments

Comments
 (0)