`
lykops
  • 浏览: 86311 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
文章分类
社区版块
存档分类
最新评论

kubernetes资源对象--Service

 
阅读更多

为了适应快速的业务需求,微服务架构已经逐渐成为主流,微服务架构的应用需要有非常好的服务编排支持。K8S中的核心要素Service便提供了一套简化的服务代理和发现机制,天然适应微服务架构。

概念

Service是一种抽象概念,定义了一个Pod逻辑集合以及访问它们的策略。目标是提供一个代理服务器,作为Pod的访问入口,它会为访问者提供一个固定访问地址,用于在访问时重定向到相应的后端pod。K8S默认分配给Service的一个固定IP,称为Cluster IP。

在K8S中,Pod IP会随着pod的变化(重建等)而变化的,这对于Pod的访问者来说是不可接受的,而Service会及时更新。对于访问者来说,通过Service进行访问,无需直接感知Pod。

默认的负载均衡策略是轮训或者随机(有kube-proxy的模式决定)。同时,Service上通过yaml文件设置sessionAffinity=ClientIP,来实现基于源IP地址的会话保持。

需要注意,默认情况下。Cluster IP是一个虚拟IP,并不是一个真实的IP,在外部是无法寻址的。如果需要外部访问service 的Cluster IP,这需要额外配置。

service的端口

port

service暴露在cluster ip上的端口,cluster ip:port 是提供给集群内部客户访问service的入口。

nodePort

nodePort是K8S提供给集群外部客户访问service入口的一种方式,node IP:nodePort 是提供给集群外部客户访问service的入口。

targetPort

targetPort是pod上的端口,从port和nodePort上到来的数据最终经过kube-proxy流入到后端pod的targetPort上进入容器。

port、nodePort总结

总的来说,port和nodePort都是service的端口,前者暴露给集群内客户访问服务,后者暴露给集群外客户访问服务。从这两个端口到来的数据都需要经过反向代理kube-proxy流入后端pod的targetPod,从而到达pod上的容器内。

外部访问service的四种方法

但有些服务又需要被外部访问到,例如web前段。这时候就需要加一层网络转发,即外网到内网的转发。K8S提供了四种方案让外部访问service

ClusterIP:提供一个集群内部的虚拟IP以供Pod访问,如果外部访问的话,需要配置kube-proxy为userspace模式。

NodePort:在每个Node上打开一个端口以供外部访问。

LoadBalancer:通过外部的负载均衡器来访问,该模式需要底层云平台(例如GCE)支持。。

Ingress:具体请见http://blog.csdn.net/liyingke112/article/details/76022267

代理外部服务

Service不仅可以代理Pod,还可以代理任意其他后端,比如运行在K8S外部MySQL、Oracle等。这是通过定义两个同名的service和endPoints来实现的。

具体请见http://blog.csdn.net/liyingke112/article/details/76204038

服务发现

K8S主要支持两种服务发现机制:环境变量和DNS。

环境变量方式

K8S创建Pod时会自动添加所有可用的service环境变量到该Pod中。需要注意的是,环境变量的注入只发送在Pod创建时,且不会被自动更新。这个特点暗含了service和访问该service的Pod的创建时间的先后顺序,即任何想要访问service的pod都需要在service已经存在后创建,否则与service相关的环境变量就无法注入该Pod的容器中,这样先创建的容器就无法发现后创建的service。

K8S官方提供的SkyDNS

在kubernetes1.2之前,采用skydns+kube2dns+etcd的方式来部署dns。而从1.3开始,则部署方式有了一点儿变化,将skydns和kube2dns封装到了一个容器镜像中,放弃了etcd,而将dns解析直接放入到了内存之中,同时引入了dnsmasq,进一步利用其缓存。

http://blog.csdn.net/liyingke112/article/details/77776648

分享到:
评论

相关推荐

    kubernetes-server-linux-amd64.tar

    1. **kube-apiserver**:作为Kubernetes的前端,提供RESTful API接口,允许客户端(如kubectl)与集群进行交互,执行各种操作,如创建、更新和删除资源对象。 2. **kube-controller-manager**:包含多个控制循环,...

    kubernetes-client-linux-amd64.tar.gz

    Kubernetes客户端Linux AMD64资源包,`kubernetes-client-linux-amd64.tar.gz`,是专为基于Linux的AMD64(也称为x86_64)架构设计的Kubernetes命令行接口(CLI)工具集。这个压缩包包含了一系列用于与Kubernetes集群...

    kubernetes-client-windows-amd64 (v1.10.11).tar.gz

    - `kubectl get`:用于查看Kubernetes集群中的资源对象,如Pod、Service、Deployment等。 - `kubectl create`:用于创建资源对象,例如创建一个新的Deployment或Service。 - `kubectl apply`:根据指定的YAML或JSON...

    kubernetes-client-darwin-amd64.tar.gz-v1.14.1二进制下载

    它们可以附加到任何对象(如Pod、Service、Deployment等),并用于过滤和选择符合特定条件的资源。 在实际使用中,你可能会遇到需要配置kubeconfig文件的情况,这个文件包含了连接到Kubernetes集群所需的信息,包括...

    kubernetes-server-linux-amd64.tar.gz

    1. **API服务器**:它是集群的中央数据存储和通信中心,处理所有资源对象的增删改查操作,并通过etcd存储集群状态。 2. **控制器管理器**:负责运行一系列协调控制器,如ReplicaSet控制器保证Pod副本数量的正确性,...

    kubernetes-server-linux-amd64.tar 二进制安装包

    5. **Deployments, StatefulSets, DaemonSets** 等:这些是资源对象,定义了如何创建、更新和管理Pods的策略。 对于Linux平台的AMD64架构,安装Kubernetes通常涉及以下步骤: 1. **环境准备**:确保系统满足最低...

    kubernetes-dashboard-v1.8.3 yaml文件

    在 Kubernetes 中,YAML 文件是用于定义资源对象的配置文件,如 Pods、Services、Deployments 等。`kubectl` 是 Kubernetes 的命令行工具,用于与集群进行交互。`kubectl create` 命令用来根据指定的 YAML 文件创建...

    kubernetes-server-linux-amd64-v1.15.5.tar.gz

    5. **部署应用**:一旦集群就绪,你可以通过kubectl创建Deployment、Service等资源对象来部署应用程序。 在实际操作中,你需要熟悉Kubernetes的基本概念,如Pod、Service、Deployment、ReplicaSet等,以便更好地...

    K8S安装包之kubernetes-clinet-linux-amd64

    它允许用户创建、更新、删除Pod(Kubernetes的基本执行单元)、Service(为Pod提供稳定网络访问的抽象)、Deployment(定义应用的副本数量和更新策略)等资源对象。例如,你可以使用`kubectl get pods`命令来查看...

    kubernetes-assertions-2.2.85.zip

    Kubernetes 断言库(kubernetes-assertions)是 Kubernetes 客户端库的一部分,它提供了丰富的断言方法,用于在测试环境中验证 Kubernetes 资源(如 Pod、Service、Deployment 等)的属性。例如,开发者可以使用这些...

    kubernetes-client-linux-amd64.tar.gz资源包,可使用

    `kubectl` 是Kubernetes的核心命令行工具,它允许用户从命令行执行各种操作,如创建、更新、删除资源对象(如Pods、Services、Deployments、ReplicaSets等),查看集群状态,以及执行其他管理和调试任务。...

    kubernetes-handbook-jimmysong-v1.3

    - **资源对象与基本概念**:包括Pod、Deployment、StatefulSet等资源对象的详细介绍和使用场景。 - **Pod状态与生命周期管理**:涵盖Pod的生命周期事件和管理策略,如Pod Hook、Preset、PDB(Pod中断预算)等。 ###...

    kubernetes-basico-master.rar

    学习源码的同时,你将了解到如何创建YAML配置文件来定义Kubernetes对象,如创建Deployment以启动应用实例,设置Service以暴露服务,以及配置网络策略和存储卷。 6. **监控与日志**: K8s提供了丰富的监控和日志...

Global site tag (gtag.js) - Google Analytics