Service和Endpoints

devtools/2024/12/23 4:24:28/

在 Kubernetes 中,ServiceEndpoints 是两个非常重要的资源对象,它们共同用于定义和管理集群内部的服务发现和网络通信。下面详细介绍这两个资源对象的功能及其相互关系。

Service

Service 是 Kubernetes 中用于定义抽象逻辑服务的资源对象。它提供了稳定不变的网络标识符,即使后端的实际服务实例发生变更,Service 的 IP 地址和 DNS 名称仍然保持不变。Service 可以用于定义如何访问一组后端 Pod,通常通过标签选择器(label selector)来指定这些 Pod。

Service 的作用
  1. 服务发现:提供一个固定的 IP 地址和 DNS 名称来访问一组后端 Pod。
  2. 负载均衡:自动将流量分发到后端 Pod 上。
  3. 健康检查:支持健康检查机制,确保流量只分发到健康的后端实例。
  4. 端口映射:定义后端 Pod 的端口映射规则。
Service 的类型
  1. ClusterIP:默认类型,创建一个集群内部的虚拟 IP 地址,只能在集群内部访问。
  2. NodePort:为 Service 分配一个集群节点上的端口,使得外部可以通过 <节点IP>:<节点端口> 访问 Service
  3. LoadBalancer:为 Service 创建一个外部负载均衡器,并分配一个外部 IP 地址。
  4. ExternalName:将 Service 映射到一个 DNS 名称,而不是一组后端 Pod。
Service 示例

以下是一个简单的 Service 配置示例,用于定义一个集群内部的服务:

 

Yaml

深色版本

apiVersion: v1
kind: Service
metadata:name: my-service
spec:selector:app: MyApp # 标签选择器ports:- protocol: TCPport: 80targetPort: 9376type: ClusterIP

在这个示例中,my-service 将流量分发到带有 app=MyApp 标签的所有 Pod,并将这些 Pod 的端口 9376 映射到 Service 的端口 80。

Endpoints

Endpoints 是 Kubernetes 中用于定义 Service 后端 Pod 实际 IP 地址和端口的资源对象。当 Pod 的 IP 地址发生变化时,Endpoints 会自动更新,以确保 Service 始终指向正确的后端 Pod。

Endpoints 的作用
  1. 动态更新:当后端 Pod 的 IP 地址发生变化时,Endpoints 会自动更新。
  2. 负载均衡Endpoints 用于存储 Service 后端 Pod 的实际 IP 地址和端口,以实现负载均衡。
Endpoints 示例

以下是一个简单的 Endpoints 配置示例,用于定义 Service 后端 Pod 的实际 IP 地址和端口:

 

Yaml

深色版本

apiVersion: v1
kind: Endpoints
metadata:name: my-service-endpoints
subsets:
- addresses:- ip: 10.2.3.4- ip: 10.2.3.5ports:- port: 9376

在这个示例中,my-service-endpoints 定义了 Service 后端 Pod 的实际 IP 地址为 10.2.3.410.2.3.5,端口为 9376。

Service 和 Endpoints 的关系

ServiceEndpoints 通常配合使用,以实现服务发现和负载均衡。Service 定义了如何访问一组后端 Pod,而 Endpoints 存储了这些后端 Pod 的实际 IP 地址和端口。

Service 被创建时,Kubernetes 控制器会自动生成相应的 Endpoints 对象,将带有相同标签选择器的 Pod 的 IP 地址和端口添加到 Endpoints 中。

综合示例

以下是一个综合示例,展示了如何定义 Service 并自动创建 Endpoints

 

Yaml

深色版本

# service.yaml
apiVersion: v1
kind: Service
metadata:name: my-service
spec:selector:app: MyAppports:- protocol: TCPport: 80targetPort: 9376type: ClusterIP

当创建 Service 时,Kubernetes 控制器会自动创建相应的 Endpoints 对象,将带有 app=MyApp 标签的 Pod 的 IP 地址和端口添加到 Endpoints 中。

总结

  • Service:用于定义逻辑服务的抽象,提供稳定不变的网络标识符。
  • Endpoints:用于存储 Service 后端 Pod 的实际 IP 地址和端口。

通过 ServiceEndpoints 的配合使用,可以实现服务发现、负载均衡和健康检查等功能,确保集群内部的服务通信的高效和稳定性。


http://www.ppmy.cn/devtools/120437.html

相关文章

【SQL】未订购的客户

目录 语法 需求 示例 分析 代码 语法 SELECT columns FROM table1 LEFT JOIN table2 ON table1.common_field table2.common_field; LEFT JOIN&#xff08;或称为左外连接&#xff09;是SQL中的一种连接类型&#xff0c;它用于从两个或多个表中基于连接条件返回左表…

影响 Linux、Unix 系统的 CUPS 漏洞可导致 RCE

在经过大量炒作和第三方过早泄露信息之后&#xff0c;安全研究员 Simone Margaritelli 公布了有关通用 UNIX 打印系统 (CUPS) 中的四个零日漏洞的详细信息。 这些漏洞可被远程、未经身份验证的攻击者滥用&#xff0c;在易受攻击的 Linux 和类 Unix 系统上实现代码执行。 CUPS…

Python绘图库----turtle(海龟)

Python库 python程序的集合&#xff0c;这些程序都有不同的功能。Python库就相当于一个工具箱&#xff0c;里面有各种工具&#xff0c;工具的功能都有所不同。 Python绘图库 Python绘图库----turtle&#xff08;海龟&#xff09;&#xff0c;turtle 具有绘画功能&#xff0c…

MacOS配置python环境

下载 Python 前往网站下载对应芯片和python版本的 installer。 配置环境变量 sudo vim ~/.bash_profile添加一下内容&#xff0c;注意修改文件名。 export PATH"/Library/Frameworks/Python.framework/Versions/3.11/bin:${PATH}" alias python"/Library/Fr…

Java Web应用升级故障案例解析

在一次Java Web应用程序的优化升级过程中&#xff0c;从Tomcat 7.0.109版本升级至8.5.93版本后&#xff0c;尽管在预发布环境中验证无误&#xff0c;但在灰度环境中却发现了一个令人困惑的问题&#xff1a;新日志记录神秘“失踪”。本文深入探讨了这一问题的排查与解决过程&…

Android常用C++特性之std::unique

声明&#xff1a;本文内容生成自ChatGPT&#xff0c;目的是为方便大家了解学习作为引用到作者的其他文章中。 std::unique 是 C 标准库中的一个算法函数&#xff0c;用于移除相邻的重复元素&#xff0c;使每个相邻的元素在容器中保持唯一。它不会真正移除元素&#xff0c;而是通…

计算机网络:计算机网络概述:网络、互联网与因特网的区别

文章目录 网络、互联网与因特网的区别网络分类 互联网因特网基于 ISP 的多层次结构的互连网络因特网的标准化工作因特网管理机构因特网的组成 网络、互联网与因特网的区别 若干节点和链路互连形成网络&#xff0c;若干网络通过路由器互连形成互联网 互联网是全球范围内的网络…

微信小程序攻略:如何验证Token是否即将失效并自动刷新

在微信小程序的开发中&#xff0c;我们通常使用Token来管理用户的登录状态。Token具有一定的有效期&#xff0c;一旦失效&#xff0c;用户将需要重新登录。为了提升用户体验&#xff0c;我们可以在Token快要失效时提前刷新Token&#xff0c;避免用户在操作过程中突然退出。以下…