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>

如果出现这样的情况,就是成功了。

20160812-140843.png

文献引用

以下是在中国的本土化中所进行的释义:

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 项目的示例代码,其中有关于留言板应用的示例。

广告
将在 10 秒后关闭
bannerAds