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

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
简介: 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 的基本产品能力,即可以实现快速部署一个在线魔方应用,并借助阿里云容器服务成熟的产品生态,实现在线应用的企业级监控,提升应用稳定性。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
目录
相关文章
|
3天前
|
存储 弹性计算 运维
阿里云容器服务Kubernetes版(ACK)部署与管理体验评测
阿里云容器服务Kubernetes版(ACK)是一个功能全面的托管Kubernetes服务,它为企业提供了快速、灵活的云上应用管理能力。
67 1
|
9天前
|
Kubernetes 应用服务中间件 nginx
K8s高可用集群二进制部署-V1.20
2.4 部署Etcd集群 以下在节点1上操作,为简化操作,待会将节点1生成的所有文件拷贝到节点2和节点3. 1. 创建工作目录并解压二进制包 mkdir /opt/etcd/{bin,cfg,ssl} -p tar zxvf etcd-v3.4.9-linux-amd64.tar.gz mv etcd-v3.4.9-linux-amd64/{etcd,etcdctl} /opt/etcd/bin/
|
7天前
|
消息中间件 Kubernetes Android开发
消息队列 MQ产品使用合集之如何在kubernetes环境里面部署
消息队列(MQ)是一种用于异步通信和解耦的应用程序间消息传递的服务,广泛应用于分布式系统中。针对不同的MQ产品,如阿里云的RocketMQ、RabbitMQ等,它们在实现上述场景时可能会有不同的特性和优势,比如RocketMQ强调高吞吐量、低延迟和高可用性,适合大规模分布式系统;而RabbitMQ则以其灵活的路由规则和丰富的协议支持受到青睐。下面是一些常见的消息队列MQ产品的使用场景合集,这些场景涵盖了多种行业和业务需求。
|
9天前
|
Kubernetes 监控 Java
阿里云云效产品使用问题之进行Kubernetes分批发布时应用名被更改,是什么导致的
云效作为一款全面覆盖研发全生命周期管理的云端效能平台,致力于帮助企业实现高效协同、敏捷研发和持续交付。本合集收集整理了用户在使用云效过程中遇到的常见问题,问题涉及项目创建与管理、需求规划与迭代、代码托管与版本控制、自动化测试、持续集成与发布等方面。
|
9天前
|
前端开发 Devops 测试技术
阿里云云效产品使用问题之更换所部署的环境关联的ACK集群该如何实现
云效作为一款全面覆盖研发全生命周期管理的云端效能平台,致力于帮助企业实现高效协同、敏捷研发和持续交付。本合集收集整理了用户在使用云效过程中遇到的常见问题,问题涉及项目创建与管理、需求规划与迭代、代码托管与版本控制、自动化测试、持续集成与发布等方面。
|
10天前
|
Prometheus 监控 Kubernetes
一篇文章讲明白Kubernetes(k8s)部署Promehteus监控
一篇文章讲明白Kubernetes(k8s)部署Promehteus监控
18 0
|
10天前
|
Prometheus 监控 Kubernetes
一篇文章讲明白Kubernetes(k8s)部署Promehteus监控
一篇文章讲明白Kubernetes(k8s)部署Promehteus监控
21 0
|
存储 设计模式 运维
YAML 管理 Kubernetes 应用
YAML 管理 Kubernetes 应用
285 1
|
存储 设计模式 运维
如何不编写 YAML 管理 Kubernetes 应用?
Kubernetes 将自身边界内的事物都抽象为资源。其中的主要部分,是以 Deployment、StatefulSet 为代表的 workload 工作负载控制器,其他各类资源都围绕这些主要的资源工作。这些资源合并起来,可以为 IT 技术工作者展现出一个以 workload 为中心的模型。Kubernetes 中所有的资源,都通过声明式配置文件来编辑描述,一条条的 Yaml 字段定义,给了 IT 技术人员最大的自由度的同时,也对技术人员的能力提出了极高的要求。
|
Kubernetes Shell 开发工具
使用 Kustomize 帮你管理 kubernetes 应用(二): Kustomize 的使用方法
本篇为系列文章第二篇,手把手教你使用 Kustomize 的两种方式。
4492 0