minikube可以运行一个本地单节点的kubernetes集群,可以非常容易地在本地部署kubernetes。虽然只支持单节点的kubernetes集群,但是能支持很多kubernetes特性,包括:
- DNS
- NodePorts
- ConfigMaps and Secrets
- Dashboards
- Container Runtime: Docker, CRI-O, and containerd
- Enabling CNI (Container Network Interface)
- Ingress
- Installa
还没有安装好minikube,可以阅读我的上篇文章《centos安装kubectl和minikube工具》。
本文以安装rabbitmq为例,使用minikube来部署一个kubernete节点
1.启动minikube,使用上一篇文章的启动命令
代码语言:javascript复制minikube start --image-repository='registry.cn-hangzhou.aliyuncs.com/google_containers' --vm-driver=none
2.下面使用已经存在的镜像rabbitmq部署kubernete
代码语言:javascript复制kubectl create deployment rabbitmq-minikube --image=docker.io/rabbitmq:3.8.2-management
注意:为了方便管理,建议命令最后指定版本号,如果不指定,默认是latest
status=running说明服务已经起来了
3.将rabbitmq暴露一个service端口
代码语言:javascript复制kubectl expose deployment rabbitmq-minikube --type=NodePort --port=15672
4.查看service对外暴露的url详情
代码语言:javascript复制minikube service rabbitmq-minikube --url
这个地址就是我们访问rabbitmq的地址,在浏览器输入这个地址,进入rabbitmq页面,
5.打开Dashboard
代码语言:javascript复制minikube dashboard
提示如下:
1)在浏览器输入失败,如下图:
代码语言:javascript复制http://127.0.0.1:43584/api/v1/namespaces/kubernetes-dashboard/services/http:kubernetes-dashboard:/proxy/
查看所有pod,发现没有Dashboard
代码语言:javascript复制kubectl get pods --namespace kube-system
2)创建Dashboard节点,按照官方的方法:
代码语言:javascript复制kubectl apply -f https://raw.githubusercontent.com/kubernetes/dashboard/v1.10.1/src/deploy/recommended/kubernetes-dashboard.yaml
3)查看pod状态是ImagePullBackOff,镜像拉取失败。只能从阿里云pull镜像了,如下命令:
代码语言:javascript复制docker pull mirrorgooglecontainers/kubernetes-dashboard-amd64:v1.10.1
docker tag mirrorgooglecontainers/kubernetes-dashboard-amd64:v1.10.1 k8s.gcr.io/kubernetes-dashboard-amd64:v1.10.1
上面命令执行成功后,再执行2)中的命令。查看pod状态:
代码语言:javascript复制kubectl get pods --all-namespaces
查看pod日志:
代码语言:javascript复制kubectl logs -f pods/kubernetes-dashboard-7c54d59f66-7tswd -n kube-system
参考网上的一些资料,这个错误是kube dns反复重启,需要重启ip规则,如下命令:
代码语言:javascript复制systemctl stop kubelet
systemctl stop docker
iptables --flush
iptables -tnat --flush
systemctl start kubelet
systemctl start docker
之后再查看pod状态,发现启动成功了。
在虚机浏览器输入下面网址,可以看到kubernete dashboard页面
代码语言:javascript复制http://127.0.0.1:39780/api/v1/namespaces/kubernetes-dashboard/services/http:kubernetes-dashboard:/proxy/
6.常用命令
代码语言:javascript复制#查看kubernete集群下的pod
kubectl get pod
#查看集群下所有pod和namespace信息
kubectl get pods --all-namespaces
#删除一个pod -n后跟namespace
kubectl delete deployment dashboard-metrics-scraper -n kubernetes-dashboard
#删除service
kubectl delete services rabbitmq-minikube
#停止minikube集群
minikube stop
#删除minikube集群
minikube delete
#查看service对外暴露详情
minikube service rabbitmq-minikube
这个命令会使用默认l浏览器打开这个地址
#查看pod状态
kubectl describe -n kube-system pod/kubernetes-dashboard-65c76f6c97-htfxt
#查看pod启动日志
kubectl logs -f pods/kubernetes-dashboard-65c76f6c97-htfxt -n kube-system
minikube logs
#为rabbitmq-minikube deployment创建service,并通过Service的80端口转发至容器的8000端口上。
kubectl expose deployment rabbitmq-minikube --port=80 --target-port=8000
参考文档:
代码语言:javascript复制https://kubernetes.io/docs/setup/learning-environment/minikube/
https://blog.csdn.net/shida_csdn/article/details/80028905?utm_source=blogxgwz1