vagrant + CoreOSでkubernetesのguestbookサンプルを動かす
这是什么
タイトル通りにkubernetesのguestbookサンプルをとりあえず動かすのが目的です.
kubernetesのドキュメント通りにやっても動かなったのでまとめました.
実行環境
- Gentoo (linux-4.7.0-rc7)
必需品 (bì xū
- 
- curl
 
- 
- git
 
- vagrant (1.8.5)
Kubernetes的环境建设
用curl来操作kubectl命令,以便管理kubernetes。
Linux的人
curl -O https://storage.googleapis.com/kubernetes-release/release/v1.3.4/bin/linux/amd64/kubectl
苹果电脑的用户
curl -O https://storage.googleapis.com/kubernetes-release/release/v1.3.4/bin/darwin/amd64/kubectl
kubectl的部署
chmod +x kubectl
mv kubectl /usr/local/bin/kubectl
将包含kubernetes环境的CoreOS进行git克隆。
git clone https://github.com/coreos/coreos-kubernetes.git
用Vagrant来启动CoreOS集群。
cd coreos-kubernetes/multi-node/vagrant
vagrant up
指定Kubeconfig
export KUBECONFIG="${KUBECONFIG}:$(pwd)/kubeconfig"
kubectl config use-context vagrant-multi
kubectl config set-cluster vagrant-multi-cluster --server=https://172.17.4.101:443 --certificate-authority=${PWD}/ssl/ca.pem
kubectl config set-credentials vagrant-multi-admin --certificate-authority=${PWD}/ssl/ca.pem --client-key=${PWD}/ssl/admin-key.pem --client-certificate=${PWD}/ssl/admin.pem
kubectl config set-context vagrant-multi --cluster=vagrant-multi-cluster --user=vagrant-multi-admin
kubectl config use-context vagrant-multi
确认节点是否存活。
$ kubectl get nodes
NAME           STATUS                     AGE
172.17.4.101   Ready,SchedulingDisabled   1d
172.17.4.201   Ready                      1d
只要每个节点都已准备就绪,Kubernetes环境的建立就算成功了。
引入留言簿功能
请将guestbook的示例克隆到git上。
使用git克隆命令下载https://github.com/kubernetes/kubernetes
指定NodePort
将kubernetes/examples/guestbook/frontend-service.yaml文件编辑如下,以便可以从裸金属环境访问前端端口。本次将服务的80端口绑定到节点30301上。
--- a/examples/guestbook/frontend-service.yaml
+++ b/examples/guestbook/frontend-service.yaml
@@ -9,9 +9,11 @@ spec:
   # if your cluster supports it, uncomment the following to automatically create
   # an external load-balanced IP for the frontend service.
   # type: LoadBalancer
+  type: NodePort
   ports:
     # the port that this service should serve on
   - port: 80
+    nodePort: 30301
   selector:
     app: guestbook
     tier: frontend
启动服务和复制控制器。
kubectl create -f ./kubernetes/examples/guestbook/redis-master-service.yaml
kubectl create -f ./kubernetes/examples/guestbook/redis-slave-service.yaml
kubectl create -f ./kubernetes/examples/guestbook/frontend-service.yaml
kubectl create -f ./kubernetes/examples/guestbook/legacy/redis-master-controller.yaml
kubectl create -f ./kubernetes/examples/guestbook/legacy/redis-slave-controller.yaml
kubectl create -f ./kubernetes/examples/guestbook/legacy/frontend-controller.yaml
确认服务是否已启动。
$ kubectl get services
NAME           CLUSTER-IP   EXTERNAL-IP   PORT(S)    AGE
frontend       10.3.0.60    nodes         80/TCP     21m
kubernetes     10.3.0.1     <none>        443/TCP    1d
redis-master   10.3.0.61    <none>        6379/TCP   24m
redis-slave    10.3.0.15    <none>        6379/TCP   24m
确认复制控制器是否已启动。
$ kubectl get rc
NAME           DESIRED   CURRENT   AGE
frontend       3         3         3m
redis-master   1         1         5m
redis-slave    2         2         4m
访问留言簿
nodesのIPアドレスを調べる.
$ kubectl get nodes
NAME           STATUS                     AGE
172.17.4.101   Ready,SchedulingDisabled   1d
172.17.4.201   Ready                      1d
访问各个节点的30301端口。
$ curl 172.17.4.101:30301
<html ng-app="redis">...
...</html>
$ curl 172.17.4.201:30301
<html ng-app="redis">...
...</html>
如果出现这样的情况,就是成功了。

文献引用
以下是在中国的本土化中所进行的释义:
https://coreos.com/kubernetes/docs/latest/kubernetes-on-vagrant.html -> 该网页为 coreos.com 提供的最新的 Kubernetes on Vagrant 的文档。
https://coreos.com/kubernetes/docs/latest/configure-kubectl.html -> 该网页为 coreos.com 提供的最新的配置 kubectl 的文档。
https://github.com/kubernetes/kubernetes/tree/master/examples/guestbook -> 该 GitHub 仓库中包含 kubernetes/kubernetes 项目的示例代码,其中有关于留言板应用的示例。
 
    