【从问题中去学习k8s】k8s中的常见面试题(夯实理论基础)(十九)

本站以分享各种运维经验和运维所需要的技能为主

《python零基础入门》:python零基础入门学习

《python运维脚本》: python运维脚本实践

《shell》:shell学习

《terraform》持续更新中:terraform_Aws学习零基础入门到最佳实战

《k8》从问题中去学习k8s

《docker学习》暂未更新

《ceph学习》ceph日常问题解决分享

《日志收集》ELK+各种中间件

《运维日常》运维日常

《linux》运维面试100问

《DBA》db的介绍使用(mysql、redis、mongodb...)

思考一下问题:

87、 k8s是怎么进行服务注册的及其原理机制?

参考答案:

复制代码
答:Pod启动后会加载当前环境所有Service信息,以便不同Pod根据Service名进行通信。

详解:
Kubernetes (k8s) 中的服务注册主要是通过 Service 资源来实现的。Service 是一种定义如何访问一组特定 Pod 的方法,它为 Pod 组提供一个统一的访问接口,并且负责将请求负载均衡到后端的各个 Pod。以下是 Kubernetes 中服务注册的基本工作机制和步骤:

### 1. **Pod 标签和选择器(Labels and Selectors)**

服务注册的核心是通过标签(Labels)和选择器(Selectors)来关联 Service 和 Pod。Pod 配置中包含标签,而 Service 配置中包含选择器。Service 的选择器会匹配具有相应标签的 Pod,从而确定哪些 Pod 属于该 Service。

### 示例

假设有一些 Pod,它们的配置中包含了标签 `app: MyApp`:

```yaml
apiVersion: v1
kind: Pod
metadata:
  name: myapp-pod
  labels:
    app: MyApp
spec:
  containers:
    - name: myapp-container
      image: myapp:latest
```

接着,创建一个 Service 来选择这些 Pod:

```yaml
apiVersion: v1
kind: Service
metadata:
  name: my-service
spec:
  selector:
    app: MyApp
  ports:
    - protocol: TCP
      port: 80
      targetPort: 9376
```

在这个例子中,Service `my-service` 通过选择器 `app: MyApp` 找到所有带有相同标签的 Pod,并将它们注册为后端。

### 2. **服务发现**

一旦 Service 被创建,Kubernetes 的 DNS 服务(通常是 CoreDNS)会自动为该 Service 创建一个 DNS 记录。这允许集群中的其他 Pod 通过 Service 的名称来解析和访问 Service,实现服务发现。

例如,如果你的 Service 名称为 `my-service` 并且在 `default` 命名空间,那么它的完整 DNS 名称将是 `my-service.default.svc.cluster.local`。集群中的任何 Pod 都可以使用这个 DNS 名称来访问这个 Service。

### 3. **负载均衡**

当 Service 接收到请求时,它会根据定义的策略(如轮询)将请求分发到后端的多个 Pod 中。这个过程是自动的,确保了负载的均衡分配,提高了应用的可用性和扩展性。

### 总结

Kubernetes 中的服务注册和服务发现机制是自动化的,依赖于 Service 对象和 Pod 标签/选择器的定义。这种设计不仅简化了服务管理,还增强了服务的可扩展性和灵活性。通过 Service,Kubernetes 能够有效地管理大规模的应用部署,确保应用的高可用性和网络的优化。
相关推荐
ZH15455891311 小时前
Flutter for OpenHarmony Python学习助手实战:GUI桌面应用开发的实现
python·学习·flutter
编程小白20262 小时前
从 C++ 基础到效率翻倍:Qt 开发环境搭建与Windows 神级快捷键指南
开发语言·c++·windows·qt·学习
学历真的很重要2 小时前
【系统架构师】第二章 操作系统知识 - 第二部分:进程与线程(补充版)
学习·职场和发展·系统架构·系统架构师
深蓝海拓2 小时前
PySide6,QCoreApplication::aboutToQuit与QtQore.qAddPostRoutine:退出前后的清理工作
笔记·python·qt·学习·pyqt
酒鼎2 小时前
学习笔记(3)HTML5新特性(第2章)
笔记·学习·html5
L***一2 小时前
2026届大专跨境电商专业毕业生就业能力提升路径探析
学习
MonkeyKing_sunyuhua2 小时前
docker compose up -d --build 完全使用新代码打包的方法
docker·容器·eureka
.小墨迹2 小时前
apollo学习之借道超车的速度规划
linux·c++·学习·算法·ubuntu
ZH15455891313 小时前
Flutter for OpenHarmony Python学习助手实战:模块与包管理的实现
python·学习·flutter
Gain_chance3 小时前
33-学习笔记尚硅谷数仓搭建-DWS层交易域用户粒度订单表分析及设计代码
数据库·数据仓库·hive·笔记·学习·datagrip