Kubernetes详解(七)——Service对象部署和应用

简介: Kubernetes详解(七)——Service对象部署和应用

今天继续给大家介绍Linux运维相关知识,本文主要内容是Service对象部署和应用。

一、Service资源作用
在前文Kubernetes详解(六)——Pod对象部署和应用中,我们详细介绍了Pod对象的创建和使用。在创建Pod对象后,在Kubernetes集群内部我们能够通过访问该Pod对象的IP地址实现对该Pod对象的访问。但是,Pod对象在删除后,虽然会被恢复,但是其IP地址会被改变,因此这时对原来的Pod对象的访问就会失效。如下所示:

我们希望能够找到一种对该Pod对象的稳定访问,即不管Pod对象如何删除——创建,都能够通过一个固定的IP地址来访问。此外,Pod的IP为Kubernetes集群内部IP地址,我们还希望能够使得Kubernetes外部能够访问该Pod对象。这些的实现,都需要我们的Service对象。

二、Cluster IP类型Service资源创建
Cluster IP类型的Service资源创建可以执行命令:

kubectl expose deployment 【镜像名】 --name=【Service名】 --port=【Service对外暴露的端口】 --target-pod=【Pod容器的端口】 --protocol=【流量转发协议】
1
例如,我们要为上文中的pod-test对象创建一个Service,可以执行命令:

kubectl expose deployment pod-test --name=svc-test --port=80 --target-port=80 --protocol=TCP
1
该命令执行结果如下:

在上图中,我们执行了一个Service查看的命令,该命令格式为:

kubectl get svc
1
执行该命令,即可查看Service的基本信息。
我们执行该命令即可查看该Service暴露的IP地址,之后,我们就可以访问该Service的IP地址,对该Service的IP地址的访问等同于对Pod的IP地址的访问。
访问结果如下:

这样,就实现了对Pod资源的固定IP访问。

三、NodePort类型Service资源创建
接下来,我们尝试创建NodePort类型的Service资源,并实现Kubernetes外部客户端对Pod资源的访问。
NodePort类型的Service资源创建与Cluster IP类型的Service类型的创建命令格式相同,但是需要在命令中加入–type="NodePort"的参数。
例如,执行命令:

kubectl expose deployment/pod-test --type="NodePort" --port=80 --name=svcnode-test
1
该命令执行结果如下:

从上图中可以看出,新创建的Service类型为NodePort,该类型的Service其实也有一个内部IP地址,在Kubernetes集群内部我们也可以通过该Service的内部IP地址实现对Pod资源的访问。同时,该Service也实现了对本地30344端口和Pod的80端口的绑定,如下所示:

这样,我们对该设备IP地址,30344端口的访问就相当于对Pod资源的访问。访问结果如下:

此外,由于Kubernetes集群的特性,我们对该Kubernetes集群任意一个节点的30334节点访问的结果是相同的,如下所示:

四、Service资源删除
最后,我们来介绍以下Kubernetes集群中Service资源的删除。
执行命令:

kubectl delete svc 【Service名】
1
即可实现Service资源的删除,该命令执行结果如下所示:

原创不易,转载请说明出处:https://blog.csdn.net/weixin_40228200
————————————————

                        版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

原文链接:https://blog.csdn.net/weixin_40228200/article/details/124285161

相关实践学习
容器服务Serverless版ACK Serverless 快速入门:在线魔方应用部署和监控
通过本实验,您将了解到容器服务Serverless版ACK Serverless 的基本产品能力,即可以实现快速部署一个在线魔方应用,并借助阿里云容器服务成熟的产品生态,实现在线应用的企业级监控,提升应用稳定性。
云原生实践公开课
课程大纲 开篇:如何学习并实践云原生技术 基础篇: 5 步上手 Kubernetes 进阶篇:生产环境下的 K8s 实践 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
目录
相关文章
|
1天前
|
Kubernetes 网络协议 应用服务中间件
Kubernetes详解(十七)——Pod存活性探针应用实战
Kubernetes详解(十七)——Pod存活性探针应用实战
11 4
|
2天前
|
Kubernetes 网络协议 应用服务中间件
Kubernetes详解(十七)——Pod存活性探针应用实战
Kubernetes详解(十七)——Pod存活性探针应用实战
14 3
|
3天前
|
存储 Kubernetes API
使用Kubernetes管理容器化应用的深度解析
【5月更文挑战第20天】本文深度解析Kubernetes在管理容器化应用中的作用。Kubernetes是一个开源平台,用于自动化部署、扩展和管理容器,提供API对象描述应用资源并维持其期望状态。核心组件包括负责集群控制的Master节点(含API Server、Scheduler、Controller Manager和Etcd)和运行Pod的工作节点Node(含Kubelet、Kube-Proxy和容器运行时环境)。
|
3天前
|
Kubernetes API 调度
Kubernetes详解(十五)——Pod对象创建过程
Kubernetes详解(十五)——Pod对象创建过程
21 5
|
3天前
|
Kubernetes API 调度
Kubernetes详解(十四)——Pod对象生命周期
Kubernetes详解(十四)——Pod对象生命周期
11 2
|
6天前
|
Kubernetes API 调度
Kubernetes详解(十五)——Pod对象创建过程
Kubernetes详解(十五)——Pod对象创建过程
16 4
|
6天前
|
Kubernetes API 调度
Kubernetes详解(十四)——Pod对象生命周期
Kubernetes详解(十四)——Pod对象生命周期
12 3
|
7天前
|
Kubernetes 前端开发 容器
k8s部署模板
k8s部署模板
|
7天前
|
运维 Kubernetes Linux
Kubernetes详解(十)——Pod对象高级控制命令
Kubernetes详解(十)——Pod对象高级控制命令
15 0
|
8天前
|
Kubernetes Cloud Native 持续交付
构建高效稳定的云原生应用:容器编排与微服务治理实践
【5月更文挑战第14天】 随着企业数字化转型的深入,云原生技术以其弹性、敏捷和可扩展的特性成为现代应用开发的首选模式。本文将探讨如何通过容器编排工具如Kubernetes以及微服务架构的有效治理,构建和维护高效且稳定的云原生应用。我们将分析容器化技术的优势,并结合案例讨论在多云环境下实现持续集成、持续部署(CI/CD)的最佳实践,同时解决微服务带来的分布式复杂性问题。通过本文的阐述,读者将获得一套提升系统可靠性和业务连续性的策略框架。
12 0

推荐镜像

更多