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
目录
相关文章
|
19天前
|
Kubernetes 开发者 Docker
构建高效微服务架构:Docker与Kubernetes的协同应用
【5月更文挑战第30天】 在当今软件开发领域,微服务架构已成为实现系统模块化、提升可维护性及扩展性的关键策略。本文深入探讨了如何通过Docker容器化技术和Kubernetes集群管理,共同构建一个既高效又可靠的后端微服务环境。我们将剖析Docker和Kubernetes的核心功能,以及它们如何相辅相成,支撑起现代化的云原生应用程序部署和管理。文章还将提供具体实践案例,帮助开发者理解将理论应用于实际开发过程中的步骤和考虑因素。
|
21天前
|
Kubernetes 开发工具 Docker
微服务实践k8s与dapr开发部署实验(2)状态管理
微服务实践k8s与dapr开发部署实验(2)状态管理
52 3
微服务实践k8s与dapr开发部署实验(2)状态管理
|
2天前
|
SQL Kubernetes 数据处理
实时计算 Flink版产品使用问题之在 flink-conf.yaml 中定义的配置在某些情况下未被正确应用到 K8s 上运行的任务管理器(JobManager)和任务管理节点(TaskManager),是什么导致的
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
8天前
|
Kubernetes 数据处理 调度
天呐!部署 Kubernetes 模式的 Havenask 集群太震撼了!
【6月更文挑战第11天】Kubernetes 与 Havenask 集群结合,打造高效智能的数据处理解决方案。Kubernetes 如指挥家精准调度资源,Havenask 快速响应查询,简化复杂任务,优化资源管理。通过搭建 Kubernetes 环境并配置 Havenask,实现高可扩展性和容错性,保障服务连续性。开发者因此能专注业务逻辑,享受自动化基础设施管理带来的便利。这项创新技术组合引领未来,开启数据处理新篇章。拥抱技术新时代!
|
8天前
|
Kubernetes 前端开发 Serverless
Serverless 应用引擎产品使用合集之如何调用Kubernetes集群内服务
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
|
15天前
|
Kubernetes 容器 Perl
k8s部署seata 报错 没有提供足够的身份验证信息 [ http-nio-7091-exec-2] [ty.JwtAuthenticationEntryPoint] [ commence] [] : Responding with unauthorized error. Message - Full authentication is required to access this resource
Kubernetes pod 在16:12时出现两次错误,错误信息显示需要完整认证才能访问资源。尽管有此错误,但页面可正常访问。附有yaml配置文件的图片。
31 2
|
18天前
|
Kubernetes 负载均衡 应用服务中间件
k8s 二进制安装 优化架构之 部署负载均衡,加入master02
k8s 二进制安装 优化架构之 部署负载均衡,加入master02
|
19天前
|
Kubernetes Cloud Native 开发者
构建高效云原生应用:Kubernetes与微服务架构的融合
【5月更文挑战第31天】 在数字化转型和技术迭代的大潮中,企业对于敏捷、可扩展的IT基础设施需求日益增长。云原生技术以其独特的优势成为推动这一进程的关键力量。本文深入探讨了如何通过结合Kubernetes容器编排和微服务架构来构建和维护高效、可靠的云原生应用。我们将剖析这种技术整合的必要性,揭示其背后的原理,并讨论在实际部署过程中可能遇到的挑战及解决方案。通过案例分析和最佳实践的分享,旨在为开发者和架构师提供一套行之有效的云原生应用构建指南。
|
20天前
|
机器学习/深度学习 存储 监控
Kubernetes 集群的持续监控与性能优化策略深度学习在图像识别中的应用与挑战
【5月更文挑战第29天】 在当今微服务架构和容器化部署的大背景下,Kubernetes 已成为众多企业的首选平台。然而,随着集群规模的扩大和业务复杂性的增加,如何确保系统的高可用性和性能稳定性成为一个挑战。本文将探讨针对 Kubernetes 集群实施的持续监控方案以及针对性能瓶颈的优化策略,旨在帮助运维人员有效管理和提升其服务的质量。
|
6天前
|
Kubernetes Cloud Native 微服务
微服务实践之使用 kube-vip 搭建高可用 Kubernetes 集群
微服务实践之使用 kube-vip 搭建高可用 Kubernetes 集群
181 3