本文共 1307 字,大约阅读时间需要 4 分钟。
原创文章,欢迎转载。转载请注明:转载自,谢谢!
原文链接地址:k8s里面非常重要的一个概念pod,首先简单的介绍是pod是k8s最小的调度单位,一个pod里面可以包含一个或者多个container,一个pod共享一个namespace,它们之前可以通过localhost来进行通信。源码:
k8s api里面的格式
apiVersion: v1kind: Podmetadata: name: nginx labels: app: nginxspec: containers: - name: nginx image: nginx ports: - containerPort: 80
确认k8s通过minikube单节点没有问题
kubectl version#创建podkubectl create -f pod_nginx.yml#查看pod状态kubectl get pods#查看pod状态ip状态kubectl get pods -o wide
进入minikube 查看docker ps,内部其实就是docker
minikube startdocker psdocker exec -it nginxIdexit
查看pod nginx的网络
docker network ls#查看到nginx的ip是172.17.0.4docker network inspect bridgeexitkubectl get pods -o wide
上边这种是不是感觉很麻烦,如果想进入容器,还需要想进入虚拟机然后docker ps 找到id,最后docker exec的方式。其实不用那么复杂。
#进入nginx的容器kubectl exec -it nginx sh#了解下进入容器的所有的命令kubectl exec -it -h
# nginx这个pods的所有详细信息kubectl describe pods nginx
通过ip的方式,看看nginx启动起来没?
minikube sshping 172.17.0.4curl 172.17.0.4
老铁 现在你最想的是什么?我最想的是:在本机可以访问到nginx的服务,而不是在内部。在原来学docker的时候可以进行-p 端口映射的方式。在k8s的kubectl 同样可以看命令。
kubectl port-forward nginx 8080:80
PS:最后把容器内的nginx暴露出来了可以在外部访问了,是不是觉得美滋滋,这次主要讲了如果pod的方式创建容器,由k8s进行管理,获取到nginx的ip地址,映射容器内的端口,其实我感觉有点类似docker-swarm,但是这个好像比docker-swarm灵活点。也留个小问题,现在是用的port-forward它得一直开着,如果关闭了,直接就访问不了了,这种该如何解决。下次我来说!
转载于:https://blog.51cto.com/12040702/2288351