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