当前位置: 首页 > news >正文

【Kubernetes】Service 概念与实战

Service 概念与实战

  • 1.通过 Service 向外部暴露 Pod
  • 2.Service 的多端口设置
  • 3.集群内部的 DNS 服务
  • 4.无头 Service

在 Kubernetes 中部署的应用可能对应一个或者多个 Pod,而每个 Pod 又具有独立的 IP 地址。Service(服务)能够为一组功能相同的 Pod 提供统一不变的访问地址,使得集群具有稳定的 IP 地址(即 Cluster IP 地址),从而使在集群内部能够通过该 Cluster IP 地址将客户端请求路由到集群中的一个 Pod 上,从而实现客户端与 Pod 的通信。

Service 是 Kubernetes 中非常重要的组成部分,它主要为集群提供 请求的负载均衡Pod 的自动发现 功能。

Service 主要有以下两个作用:

  • Pod 的自动发现:通过标签 Label 与 Pod 关联,实现与 Pod 的通信。
  • 请求的负载均衡:提供不同的访问策略,以实现访问 Pod 请求的负载均衡。

1.通过 Service 向外部暴露 Pod

创建 Service 与创建应用的 Pod,可以被定义在同一个 YAML 文件中,也可以将它们在不同 YAML 文件中分开定义。下面通过使用两个 YAML 文件来分别定义 Service 和 Pod。

使用 Deployment 控制器来部署应用,创建文件 service-demo1.yaml,并在其中输入以下内容。

apiVersion: apps/v1
kind: Deployment
metadata:labels:app: nginx name: nginx
spec:replicas: 3 selector:matchLabels:app: nginxtemplate:metadata:labels:app: nginxspec:containers:- image: nginxname: nginximagePullPolicy: IfNotPresent

使用 kubectl apply 命令部署应用。

kubectl apply -f service-demo1.yaml

查看 Pod 的信息。

kubectl get pod -o wide

输出的信息如下:

在这里插入图片描述

创建 Service:编辑文件 service-demo2.yaml,在其中输入以下内容。

apiVersion: v1
kind: Service
metadata:name: service-demo2namespace: default
spec:# 这里使用 NodePort 类型的 Service 将应用程序暴露给外部type: NodePort ports:- name: httpport: 80protocol: TCPtargetPort: 80# 定义标签选择器,将服务 Service 与匹配便签的一组 Pod 关联起来selector:     app: nginx

使用 kubectl apply 命令创建 Service。

kubectl apply -f service-demo2.yaml

查看 Pod、Service 和 Endpoint 的信息。

kubectl get pods,service,endpoints -o wide
kubectl get pods,svc,ep -o wide

输出的信息如下:

在这里插入图片描述

从输出的信息可以看出,在创建 Service 时会自动创建应用的接入点 Endpoint,并将每个 Pod 的 IP 地址自动加入 Endpoint 中。Endpoint 也会自动感知后端 Pod 的 IP 地址,从而实现动态的负载均衡。

🚀 Kubernetes Endpoint 是一个 Kubernetes API 对象,‌它表示一个 Service 的后端集合,用于将流量从 Service 引导到实际运行应用程序的 Pod。‌这个对象包含一组 IP 地址和端口号的列表,‌这些 IP 地址和端口号对应于 Service 后端 Pod 的网络终点。‌当创建一个 Service 时,‌Kubernetes 会自动创建与之关联的 Endpoints 对象,‌并将 Service 的后端 Pod 的 IP 地址和端口号添加到 Endpoints 对象中。‌Endpoints 对象会根据 Service 的选择器自动选择与之关联的 Pod。‌当 Pod 的 IP 地址或端口号发生变化时,‌Kubernetes 会自动更新 Endpoints 对象,‌确保 Service 能够正确路由到后端 Pod。‌通过访问 Service 的 Cluster IP,‌可以从集群内部访问 Service,‌而通过访问 Service 的 Endpoints,‌可以直接访问 Service 的后端 Pod。‌

在这里插入图片描述
🚀 简单来说,‌Kubernetes Endpoint 是 Kubernetes 系统中用于描述 Service 后端 Pod 的网络终点信息的对象,‌它确保了 Service 能够高效地路由到正确的后端 Pod,‌从而实现服务的可用性和可扩展性。‌

在这里插入图片描述

访问任意节点的 31767 端口都可以访问应用。

在这里插入图片描述
在这里插入图片描述

2.Service 的多端口设置

service-demo2.yaml 文件中定义的 Service 只暴露了一个端口,但在很多情况下需要 Service 暴露多个端口,例如同时暴露 HTTP 端口和 HTTPS 端口。Kubernetes 允许在定义 Service 时指定多个端口,但每个端口必须指定一个唯一的名称,以避免产生歧义。

下面是 Kubernetes 官方提供的一个示例。

apiVersion: v1
kind: Service
metadata:name: my-service
spec:selector:app: MyAppports:- name: httpprotocol: TCPport: 80targetPort: 9376- name: httpsprotocol: TCPport: 443targetPort: 9377

3.集群内部的 DNS 服务

Service 在实现请求代理和负载均衡时,默认采用的是 Cluster IP 地址。但是 Cluster IP 地址不是永远不变的,因此建议在应用中不要使用 Cluster IP 地址,而使用 Service 的名称。Kubernetes 集群提供的 DNS 服务可以将 Service 的名称解析为 Cluster IP 地址。

下面对 Kubernetes 集群内部的 DNS 服务 进行一个简单的验证。

查看系统命名空间中的 Pod。

kubectl get pods -n kube-system | grep dns

输出的信息如下:

在这里插入图片描述

🚀 在 kube-system 的命名空间中自动启动了 Pod 来运行 DNS 服务。

创建 Service。

kubectl apply -f service-demo2.yaml

输出的信息如下:

在这里插入图片描述

使用 busybox1.28.4 版本创建一个 Pod,并进入 Pod 的内部。

kubectl run -it --image=busybox:1.28.4 --rm --restart=Never sh

busybox 的 Pod 中查找 service-demo2 服务,集群内部的 DNS 服务将返回 Service 的域名信息。

nslookup service-demo2

在这里插入图片描述

这里的 10.100.69.136 就是 Service service-demo2 对应的 Cluster IP。

🚀 nslookup 命令可以从 本地 DNS 服务器 中查看所有的 IP 地址和域名 信息(它就像一本互联网电话簿)。

4.无头 Service

每一个 Service 都会有一个 Service 名称,并最终由 DNS 解析成 Cluster IP 地址。连接到 Service 的客户端最终通过 Cluster IP 地址被转发到后端一个随机选择的 Pod 上。因此,这时客户端并不清楚后端 Pod 的 IP 地址。但是对于一些有状态的客户端来说,需要清楚地知道后端每个 Pod 的 IP 地址才能与其直接进行通信。这时就需要使用无头 Service(Headless Service)。

在这里插入图片描述
无头 Service 的运行机制核心是:去掉了 DNS 解析 Cluster IP 地址这个过程,直接返回后端 Pod 的 IP 地址。

创建部署描述文件 headless-service.yaml,并在其中输入以下内容。

apiVersion: v1
kind: Service
metadata:name: headless-service
spec:selector:name: busybox# 设置为无头服务 Service	clusterIP: Noneports:- name: demo port: 1234targetPort: 1234
---
apiVersion: v1
kind: Pod
metadata:name: headless-service-pod-1labels:name: busybox
spec:hostname: headless-service-pod-1containers:- image: busyboxcommand:- sleep- "3600"name: busybox
---
apiVersion: v1
kind: Pod
metadata:name: headless-service-pod-2labels:name: busybox
spec:hostname: headless-service-pod-2containers:- image: busyboxcommand:- sleep- "3600"name: busybox

执行 kubectl apply -f 命令。

kubectl apply -f headless-service.yaml

在这里插入图片描述

查看 Service 和 Pod 的信息。

kubectl get svc,pod -o wide

输出的信息如下:

在这里插入图片描述

🚀 可以看到,service/headless-service 的 Cluster IP 的值是 None(即这是一个无头 Service),在它的后面有两个 Pod,以及每个 Pod 实际的 IP 地址。

使用 kubectl exec 命令进入其中一个 Pod 内部。

kubectl exec pod/headless-service-pod-1 -it /bin/sh

在 Pod 内部查看所使用的 DNS 服务器信息(也可以用 nslookup headless-service 查询)。

more /etc/resolv.conf

输出的信息如下:

在这里插入图片描述

在这里可以看到,使用的 DNS 服务器的 IP 地址是 10.96.0.10

  • search:配置的是集群的域名后缀。
  • nameserver:配置的是 kube-dns 服务的 IP 地址。

那么,这些配置从哪里来的呢?kubelet 的启动的配置文件 --config=/var/lib/kubelet/config.yaml 中有两个参数,分别用于指定域名服务的 IP 和集群域名。kubelet 在创建容器时才可以将这些配置传入进去。

在这里插入图片描述

在宿主机上使用 dig 命令访问无头 Service。

dig @10.96.0.10 headless-service.default.svc.cluster.local

输出的信息如下:

在这里插入图片描述

可以看到,在 ANSWER SECTION 中直接返回了后端两个 Pod 的 IP 地址。

相关文章:

【Kubernetes】Service 概念与实战

Service 概念与实战 1.通过 Service 向外部暴露 Pod2.Service 的多端口设置3.集群内部的 DNS 服务4.无头 Service 在 Kubernetes 中部署的应用可能对应一个或者多个 Pod,而每个 Pod 又具有独立的 IP 地址。Service(服务)能够为一组功能相同的…...

RTSP|RTMP流如何指定坐标位置和分辨率获取RGB数据实时渲染和算法分析

接上一篇blog:同一路RTSP|RTMP流如何同时回调YUV和RGB数据实现渲染和算法分析-CSDN博客 我们知道,由于解码后的YUV或RGB数据size比较大,如果想把转换后的RGB数据传给比如python算法的话,数据量还是挺大,为此&#xff…...

基于ssm+vue+uniapp的英语学习交流平台小程序

开发语言:Java框架:ssmuniappJDK版本:JDK1.8服务器:tomcat7数据库:mysql 5.7(一定要5.7版本)数据库工具:Navicat11开发软件:eclipse/myeclipse/ideaMaven包:M…...

如何判断一个TimerTask是否已经完成

如何判断一个TimerTask是否已经完成 判断TimerTask是否已经完成并不是TimerTask或Timer类直接提供的功能,因为TimerTask一旦被提交给Timer执行,它就在一个独立的线程中运行,而Timer类并不直接提供方法来查询或控制任务的执行状态。 然而&am…...

Android常用面试题

1、如何理解Java的多态?其中,重载和重写有什么区别? 2、谈一下JVM内存区域划分?哪部分是线程公有的,哪部分是私有的? 3、final关键字的用法? 4、死锁是怎么导致的?如何定位死锁 5、数…...

JSON与Jsoncpp库:数据交换的灵活选择

目录 引言 一.JSON简介 二. Jsoncpp库概述 三. Jsoncpp核心类介绍 3.1 Json::Value类 3.2 序列化与反序列化类 四. 实现序列化 五. 实现反序列化 结语 引言 在现代软件开发中,数据交换格式扮演着至关重要的角色。JSON(JavaScript Object Notati…...

salesforce rich text 字段支持html中内嵌JavaScript吗

Salesforce 的富文本字段(Rich Text Field)不支持在 HTML 中内嵌 JavaScript。为了安全,Salesforce 会自动移除或过滤用户输入中的任何 JavaScript 代码。这是为了防止跨站点脚本(XSS)攻击,从而保护 Salesf…...

Ubuntu24.04、22.04或20.04安装Golang方法教程

在Ubuntu Linux(例如 Ubuntu 24.04、22.04 或 20.04)上安装Go(Golang)是一个简单的过程。我们可以使用默认系统存储库使用本教程中给出的命令下载开源 Go 编程语言,轻松构建简单、可靠和高效的软件。 Go语言由Google…...

学习记录第二十二天

time函数与localtime函数 在Linux环境下使用C语言处理时间&#xff0c;通常会涉及到几个重要的头文件和函数。主要的头文件是 <time.h>&#xff0c;它包含了处理时间的各种函数和数据结构。 1. 数据结构 1.time_t: 一个类型定义&#xff0c;用于存储时间值&#xff0c…...

红酒与艺术展览:品味艺术与风味的双重盛宴

当艺术的魅力与红酒的醇香交织在一起&#xff0c;一场别开生面的盛宴便悄然展开。今天&#xff0c;让我们一同走进这场红酒与艺术展览的邂逅&#xff0c;品味艺术与风味的双重盛宴。 一、艺术展览的瑰丽世界 艺术展览&#xff0c;如同一座瑰丽的宝库&#xff0c;汇聚了无数艺…...

1Panel配置

1. 脚本安装 curl -sSL https://resource.fit2cloud.com/1panel/package/quick_start.sh -o quick_start.sh && sh quick_start.sh2. 配置镜像加速 在容器-> 配置中设置&#xff0c;否则安装软件会失败。 https://docker.211678.top https://docker.1panel.live …...

场外期权是如何定价的?场外期权定价的基本原理是什么?

场外期权的定价通常基于多种复杂的因素&#xff0c;以下是一些场外期权主要的影响因素和常见的定价方法&#xff1a; 影响场外期权定价的因素&#xff1a; 标的资产价格&#xff1a;标的资产当前的市场价格是定价的基础。标的资产价格波动率&#xff1a;波动率反映了标的资产价…...

vue中数据持久化

在Vue中&#xff0c;数据持久化通常指的是将Vue组件或应用中的数据保存到用户的浏览器或设备的存储中&#xff0c;以便在用户的会话&#xff08;session&#xff09;或跨会话&#xff08;如重新加载页面或重新打开浏览器&#xff09;中保持这些数据。Vue本身并不直接提供数据持…...

小白零基础学数学建模系列-Day3-线性回归模型的构建与评估

文章目录 1 线性回归基础1.1 线性回归概念与应用1.2 数学原理与推导1.3 线性回归的实现 2 案例分析&#xff1a;房价预测2.1 加载数据2.2 数据预处理2.3 探索性数据分析2.4 观察选择特征2.5 准备训练模型的数据2.6 将数据拆分为训练集和测试集2.7 训练和测试模型2.8 模型评估 3…...

Flutter中的 extended_nested_scroll_view 库:介绍与使用指南

在开发Flutter应用时&#xff0c;处理复杂的滚动效果是一项常见的任务。Flutter提供了NestedScrollView来实现可折叠的应用栏与滚动列表的结合&#xff0c;但在某些情况下&#xff0c;NestedScrollView可能不够强大。为了解决这些问题&#xff0c;我们可以使用extended_nested_…...

Elasticsearch 综合搜索案例解析

Elasticsearch 是一个功能强大的搜索引擎&#xff0c;它不仅支持全文搜索&#xff0c;还提供了排序、分页、高亮显示等多种搜索结果处理功能。通过综合使用这些功能&#xff0c;我们可以构建出丰富而高效的搜索应用。本文将通过一个具体的案例&#xff0c;介绍如何在 Elasticse…...

Web存储革命:揭秘JavaScript的会话存储(sessionStorage)

标题&#xff1a;Web存储革命&#xff1a;揭秘JavaScript的会话存储&#xff08;sessionStorage&#xff09; 在当今的Web开发中&#xff0c;状态管理和数据持久化是构建交互式应用的关键。JavaScript提供了多种客户端存储解决方案&#xff0c;其中会话存储&#xff08;sessio…...

基于python的百度迁徙迁入、迁出数据分析(九)

副标题&#xff1a;从百度迁徙数据看——人口虹吸效应 人口虹吸效应&#xff1a;人口虹吸效应是指大城市或中心城市因其经济、文化、教育、医疗等资源的优势&#xff0c;吸引周边地区的人口、资本和其他资源向其集中的一种现象。这种效应在城市化进程中尤其明显&#xff0c;通…...

2025上海礼品展 华东礼品工艺品展览会

2025第25届上海国际礼品及家居用品展 在璀璨繁华的上海&#xff0c;一场盛大的礼品盛宴即将拉开帷幕。2025年上海国际礼品及 家居用品展览会(简称“华礼展”)&#xff0c;作为华东地区乃至全国范围内备受瞩目的礼 品行业盛会&#xff0c;将于2025年6月29日至7月1日在上海新国…...

Flink开发(一):概述与基础

目录 1. Flink概述 1.1 什么是Flink&#xff1f; 1.2 Flink的主要特点 2. Flink的核心组件 2.1 Flink架构 2.2 数据流模型 3. Flink的基础应用 3.1 开发环境配置 3.3 数据源和数据接收器 4. Flink的高级功能 4.1 状态管理与容错 4.2 窗口操作 5. Flink的应用场景 …...

YOLO X Layout部署教程:CentOS 7离线环境安装ONNX Runtime 1.16兼容包

YOLO X Layout部署教程&#xff1a;CentOS 7离线环境安装ONNX Runtime 1.16兼容包 1. 引言 如果你正在CentOS 7服务器上部署YOLO X Layout文档理解模型&#xff0c;可能会遇到一个常见问题&#xff1a;系统自带的ONNX Runtime版本太旧&#xff0c;而YOLO X Layout需要1.16或更…...

【Epic认证级适配流程】:UE6.5.0–6.5.3全版本C++27支持矩阵,含3大禁用扩展、2个ABI断裂风险点与1份可审计迁移Checklist

第一章&#xff1a;Epic认证级C27适配的合规性基准与目标定义Epic Games官方于2024年Q3发布的《Unreal Engine 5.5 C Language Compliance Framework》首次将C27草案核心特性纳入引擎构建工具链的强制验证范围。本章确立的合规性基准并非仅面向语法兼容&#xff0c;而是聚焦于A…...

Youtu-Parsing快速部署指南:一键启动Web服务,5分钟开始解析文档

Youtu-Parsing快速部署指南&#xff1a;一键启动Web服务&#xff0c;5分钟开始解析文档 1. 引言&#xff1a;为什么选择Youtu-Parsing 在日常工作中&#xff0c;我们经常需要处理各种文档——合同、报告、表格、发票等。传统的手动录入方式不仅效率低下&#xff0c;还容易出错…...

FreeCAD钣金实战:从零到一,用SheetMetal工作台搞定Z型固定片设计与展开

1. 钣金设计与FreeCAD SheetMetal工作台入门 钣金件在机械设计中无处不在&#xff0c;从机箱外壳到支架固定片&#xff0c;几乎每个DIY项目都会用到。传统手工绘制展开图既耗时又容易出错&#xff0c;而FreeCAD的SheetMetal工作台让这个过程变得直观高效。最近我在改造工作室铝…...

从IDEA到K8s:飞算JavaAI如何打通微服务开发的“最后一公里”

云原生时代的一站式开发革命&#xff1a;当JavaAI遇上Kubernetes 在数字化转型的浪潮中&#xff0c;微服务架构已成为企业技术栈的标配&#xff0c;但随之而来的开发复杂度却让许多团队陷入"最后一公里"困境。传统开发流程中&#xff0c;从本地编码到云端部署需要跨…...

终极指南:Windows游戏控制器虚拟驱动ViGEmBus完全掌握

终极指南&#xff1a;Windows游戏控制器虚拟驱动ViGEmBus完全掌握 【免费下载链接】ViGEmBus Windows kernel-mode driver emulating well-known USB game controllers. 项目地址: https://gitcode.com/gh_mirrors/vi/ViGEmBus ViGEmBus是一款强大的Windows内核模式驱动…...

第198章 万物编译(秀秀)

弦光研究院物质科学中心的环形实验室内&#xff0c;空气仿佛凝固成了某种可见的期待&#xff0c;每一立方厘米都承载着对技术突破的深切盼望。秀秀独自站立在主控制台前&#xff0c;目光穿透层层防护屏障&#xff0c;聚焦在那个被超导磁体环绕的圆柱形真空腔内。腔内&#xff0…...

PyTorch 3.0静态图训练突然降速37%?紧急排查清单:CUDA Graph复用失效、TensorPipe通道泄漏、以及被隐藏的TORCH_COMPILE_DEBUG=1黄金日志开关

第一章&#xff1a;PyTorch 3.0静态图分布式训练性能骤降的典型现象与影响评估近期多个生产级训练集群反馈&#xff0c;在升级至尚未正式发布的 PyTorch 3.0 预览版&#xff08;基于 TorchDynamo AOTAutograd 的全静态图编译路径&#xff09;后&#xff0c;使用 torch.distrib…...

大学生论文降重技巧:用AI辅助,重复率轻松降到10%以下

2026年AI学术辅助工具已进入“精准合规改写、核心语义完整保留”的全新发展阶段&#xff0c;彻底解决了大学生论文降重“耗时长、改写生硬、易踩学术红线”的普遍难题。据中国高校图书馆协会2026年调研数据显示&#xff0c;超7成大学生在论文写作过程中会遇到重复率超标的问题&…...

Flutter鸿蒙化适配中遇到的问题

Flutter 环境搭建避坑指南Flutter 作为跨平台开发的热门框架&#xff0c;凭借一套代码多端运行的优势&#xff0c;深受开发者喜爱&#xff0c;但环境搭建与适配却是新手入门的第一道拦路虎。我在初次配置 Flutter 开发环境时&#xff0c;接连踩中环境变量、模拟器版本、第三方工…...