对k8s service的一些理解

Posted 三木燕

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了对k8s service的一些理解相关的知识,希望对你有一定的参考价值。

  • service是一个抽象概念,定义了一个服务的多个pod逻辑合集和访问pod的策略,一般把service称为微服务

举个例子一个a服务运行3个pod,b服务怎么访问a服务的pod,pod的ip都不是持久化的重启之后就会有变化。
这时候b服务可以访问跟a服务绑定的service,service信息是固定的提前告诉b就行了,service通过Label Selector跟a服务的pod绑定,无论a的pod如何变化对b来说都是透明的

kind: Service
apiVersion: v1
metadata:
  name: my-service
spec:
  selector:
    app: MyApp
  ports:
  - protocol: TCP
    port: 80
    targetPort: 9376
targetPort 端口是service对外暴露的端口,任何人访问9376端口都会被service映射到后端pod的80端口
  • k8s群集中的每个节点都运行一个kube-proxy的组件,kube-proxy其实是一个代理层负责实现service

代理模式有两种

  1. userspace 

以上是关于对k8s service的一些理解的主要内容,如果未能解决你的问题,请参考以下文章

关于K8s中Headless Service的一些笔记整理

关于K8s中Headless Service的一些笔记整理

K8s——Service详解

[转帖]理解k8s 的 Ingress

K8s暴露内部服务的多种方式

如何理解这段代码片段中的两对括号?