k8s pod部署到不同node_k8s部署nginx(Pod、Deployment、Service)
一、Podpod 是 kubernetes 中最小的编排单位,通常由一个容器组成 (有时候会有多个容器组成)nginx-pod.yaml将配置apply到k8skubectl apply -f nginx.yaml校验部署状态,此时 STATUS 为 Running 表明部署成功获取 Pod 部署的状态,特别是 IP , -o wide 列出IP/Node等更多信息kubectl get pods
一、Pod
pod 是 kubernetes 中最小的编排单位,通常由一个容器组成 (有时候会有多个容器组成)
nginx-pod.yaml
data:image/s3,"s3://crabby-images/8efd8/8efd88b3769d1abb6f62201f71b02498228cb78d" alt="f1c197c36a12d462897865d48c066860.png"
将配置apply到k8s
kubectl apply -f nginx.yaml
data:image/s3,"s3://crabby-images/c9161/c91611cef40bc31c5ff2cfaa1ef3b602cf1ec1f0" alt="91f721f86bf8918018018ab6bacff97f.png"
校验部署状态,此时 STATUS 为 Running 表明部署成功
获取 Pod 部署的状态,特别是 IP , -o wide 列出IP/Node等更多信息
kubectl get pods nginx -o wide
data:image/s3,"s3://crabby-images/f498a/f498a2c351e3cf2130918a5dca6c1e0d3fef670e" alt="f5b93d116d2e31467ac33d58fbe74a92.png"
获取更加详细的信息
kubectl describe pod nginx
data:image/s3,"s3://crabby-images/41323/41323c620c7058332abf96fb7f0f0ed061b8738f" alt="bc20afcfab52021c0edcf0adddda7d88.png"
使用 kubectl exec 进入 Pod 的内部容器。如果 Pod 中有多个容器,使用 kubectl exec -c 指定容器
kubectl exec -it nginx sh
在 Pod 容器中执行命令,校验其中的 socket 情况以及 nginx 服务
data:image/s3,"s3://crabby-images/a335d/a335d5c0db6f0fca1a9f8810be3d30aedaa9e852" alt="33de9294229204e5dd763af701534b72.png"
netstat -tan
wget -q -O - localhost
二、Deployment
在 k8s 中编排应用可以更好地做弹性扩容,负载均衡。既然要均衡,一个 Pod 肯定不能均衡,自然要部署多个 Pod
docker-compose 可以简单地通过 docker-compose scale 来扩容,现在用k8s扩容
在k8s中管理 Pod 的称作 Controller,我们可以使用 Deployment 这种 Controller 来为 Pod 进行扩容,当然它还可以滚动升级,回滚,金丝雀等等关于部署的事情
我们编写一个 Deployment 的资源配置文件
- spec.template: 指定要部署的 Pod
- spec.replicas: 指定要部署的个数
- spec.selector: 定位需要管理的 Pod
data:image/s3,"s3://crabby-images/017d3/017d3fa0a26bddf93a6fdcc92d8929b2e0894688" alt="a5c97e2254d91b4540e55eecd8961bfc.png"
我们使用 kubectl apply 部署生效后查看 Pod 以及 Deployment 状态
kubectl get pods -o wide -l 'app=nginx'
data:image/s3,"s3://crabby-images/ac239/ac2396b235dbe9d0ab80c00d9be823a6fd7e224d" alt="443848bad114552e70824f6b877059ee.png"
三、Service
Service 做服务发现 指定 Deployment 或者特定集合 Pod 的网络层抽象
- spec.selector: 指定如何选择 Pod
- spec.ports: 指定如何暴露端口
data:image/s3,"s3://crabby-images/61ccc/61ccc730f72edb897be0d5ea5701e63711dff5ca" alt="7562d093d2f1e3b6bb3aec3ece5d7de1.png"
创建NodePort service时,用户可以指定范围为30000-32767的端口,对该端口的访问就能通过 kube-proxy 代理到service后端的pod中
我们使用 kubectl apply 部署生效后查看 Service 状态
kubectl get svc nginx-service -o wide
data:image/s3,"s3://crabby-images/d4dfa/d4dfa488390fc24a182b811efce18a221ba704a7" alt="f2ac777d384e1961ea98e5b0ac48bad7.png"
curl http://127.0.0.1:31871
data:image/s3,"s3://crabby-images/accbe/accbee16d66637805af0220281e6bf676d85407b" alt="3c3ff2577bd3c0947ef7d8a497029aa4.png"
截图中源码文件地址:https://gitee.com/pingfanrenbiji/study/blob/master/k8s/nginx/%E4%B8%80%E4%B8%AApod%E5%8D%95%E4%B8%AA%E5%AE%B9%E5%99%A8/
参考文章:https://juejin.im/post/5db8c2b46fb9a020256692dc
更多推荐
所有评论(0)