kubernetes集群发布 Pod 端口
发表于:2024-11-26 作者:千家信息网编辑
千家信息网最后更新 2024年11月26日,kubernetes集群发布Pod 端口创建测试环境vi nginx.yamlapiVersion: apps/v1kind: Deploymentmetadata: name: my-nginxs
千家信息网最后更新 2024年11月26日kubernetes集群发布 Pod 端口
kubernetes集群发布Pod 端口
创建测试环境
vi nginx.yamlapiVersion: apps/v1kind: Deploymentmetadata: name: my-nginxspec: selector: matchLabels: run: my-nginx replicas: 2 template: metadata: labels: run: my-nginx spec: containers: - name: my-nginx image: nginx ports: - containerPort: 80
验证服务启动
[root@kubm-02 ~]# kubectl get podsNAME READY STATUS RESTARTS AGEmy-nginx-756fb87568-jwgp8 1/1 Running 0 64smy-nginx-756fb87568-vshxc 1/1 Running 0 64s[root@kubm-02 ~]#
[root@kubm-02 ~]# kubectl get pods -l run=my-nginx -o wideNAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATESmy-nginx-756fb87568-jwgp8 1/1 Running 0 2m12s 10.244.3.101 kubnode-01 my-nginx-756fb87568-vshxc 1/1 Running 0 2m12s 10.244.4.123 kubnode-02
检查 Pod 的 IP 地址:
[root@kubm-02 ~]# kubectl get pods -l run=my-nginx -o yaml | grep podIP podIP: 10.244.3.101 podIP: 10.244.4.123
创建 Service
Kubernetes Service 从逻辑上定义了运行在集群中的一组 Pod,这些 Pod 提供了相同的功能。 当每个 Service 创建时,会被分配一个唯一的 IP 地址(也称为 clusterIP)。 这个 IP 地址与一个 Service 的生命周期绑定在一起,当 Service 存在的时候它也不会改变。 可以配置 Pod 使它与 Service 进行通信,Pod 知道与 Service 通信将被自动地负载均衡到该 Service 中的某些 Pod 上。
创建nginx 服务
kubectl expose 命令为 2个 Nginx 副本创建一个 Service:
[root@kubm-02 ~]# kubectl expose deployment/my-nginxservice/my-nginx exposed
验证服务启动
[root@kubm-02 ~]# kubectl get svcNAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGEmy-nginx ClusterIP 10.245.206.203 80/TCP 2m36s
查看详细信息
[root@kubm-02 ~]# kubectl describe svc my-nginx Name: my-nginxNamespace: defaultLabels: Annotations: Selector: run=my-nginxType: ClusterIPIP: 10.245.206.203Port: 80/TCPTargetPort: 80/TCPEndpoints: 10.244.3.101:80,10.244.4.123:80Session Affinity: NoneEvents:
kubectl describe po my-nginx # 查看my-nginx pod的详细状态kubectl describe rs my-nginx # 查看my-nginx replica set的详细状态kubectl describe deployment my-nginx # 查看my-nginx deployment的详细状态
访问 Service
Kubernetes 支持两种主要的服务发现模式 -- 环境变量和 DNS。前者在单个节点上可用使用,然而后者必须使用 kube-dns 集群插件。
[root@kubm-02 ~]# kubectl get podsNAME READY STATUS RESTARTS AGEmy-nginx-756fb87568-jwgp8 1/1 Running 0 23mmy-nginx-756fb87568-vshxc 1/1 Running 0 23m[root@kubm-02 ~]# kubectl exec my-nginx-756fb87568-jwgp8 -- printenv | grep SERVICE KUBERNETES_SERVICE_HOST=10.245.0.1KUBERNETES_SERVICE_PORT=443KUBERNETES_SERVICE_PORT_HTTPS=443
DNS 解析测试
Kubernetes 提供 DNS ,如果它在集群中处于运行状态,可以通过如下命令来检查:
[root@kubm-02 ~]# kubectl get services kube-dns --namespace=kube-systemNAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGEkube-dns ClusterIP 10.245.0.10 53/UDP,53/TCP,9153/TCP 11d
验证服务解析
启动一个安装有curl 的镜像
[root@kubm-02 ~]# kubectl run curl --image=radial/busyboxplus:curl -i --tty
测试解析 my-nginx
[ root@curl-6bf6db5c4f-96nhg:/ ]$ nslookup my-nginxServer: 10.245.0.10 《==== dns 服务器Address 1: 10.245.0.10 kube-dns.kube-system.svc.cluster.localName: my-nginxAddress 1: 10.245.206.203 my-nginx.default.svc.cluster.local 《==== my-nginx服务的集群IP地址[ root@curl-6bf6db5c4f-96nhg:/ ]$
curl 测试
[ root@curl-6bf6db5c4f-96nhg:/ ]$ curl my-nginx ........Welcome to nginx!
.........
[ root@curl-6bf6db5c4f-96nhg:/ ]$ curl 10.245.206.203........Welcome to nginx!
......
服务资源扩容
收缩服务[root@kubm-02 ~]# kubectl scale deployment my-nginx --replicas=0验证[root@kubm-02 ~]# kubectl get pods -o wide
No resources found.
扩容服务至2节点[root@kubm-02 ~]# kubectl scale deployment my-nginx --replicas=2deployment.extensions/my-nginx scaled验证[root@kubm-02 ~]# kubectl get pods -o wide NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATESmy-nginx-756fb87568-gmgfq 0/1 ContainerCreating 0 1s kubnode-02 my-nginx-756fb87568-gvhbm 0/1 ContainerCreating 0 1s kubnode-01
清理服务
#直接使用配置文件删除[root@kubm-02 ~]# kubectl delete -f nginx.yaml deployment.apps "my-nginx" deleted#删除服务[root@kubm-02 ~]# kubectl get svcNAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGEkubernetes ClusterIP 10.245.0.1 443/TCP 11dmy-nginx ClusterIP 10.245.206.203 80/TCP 48m[root@kubm-02 ~]# kubectl delete svc my-nginx service "my-nginx" deleted[root@kubm-02 ~]# kubectl get svc NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGEkubernetes ClusterIP 10.245.0.1 443/TCP 11d
服务
集群
验证
地址
状态
测试
命令
环境
节点
检查
运行
通信
配置
端口
相同
均衡
信息
副本
功能
单个
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全设备检测师
上人服务器
四川项目软件开发报价
对数据库系统的认识800字
日照联想服务器代理多少钱
如何一个数据库做多个网站
启帆网络技术工作室综合素质
好了杭州互联网科技有限公司
网络电视数据库已满怎么清理
布鲁姆公司 Ct0S服务器机房
济南浪潮服务器哪个厂家质量好
政府网络安全和信息化办公室
上海微信软件开发团队
网络安全法 落实 金融
南京蜂之都互联网科技有限公司
文档中如何快速计算数据库
湖北服务器电源都有哪些
mysql数据库管理系统
八五一科研院所软件开发忙吗
华为服务器与巨杉数据库
软件开发公司哪个职务薪酬高
精讲解读国家网络安全法意义感想
软件开发实际税负
夏天小游戏服务器
更新编录服务器
2021两会数据库
怎么在数据库输入中文
软件开发3层结构
软件开发工程师发展
数据库sql统计成绩总和