如何进行Kubernetes服务类型的浅析

  

这篇文章将为大家详细讲解有关如何进行Kubernetes服务类型的浅析,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

如何进行Kubernetes服务类型的浅析

在Kubernetes中,服务总是能使其网络访问到一个或一组Pod上。服务将会根据标签选择Pod并且当对这些服务建立网络时,它会选择集群中所有与服务的selector相匹配的Pod,并选择其中的一个,然后将网络请求转发给它。

如何进行Kubernetes服务类型的浅析

Kubernetes 服务vs Deployment

在K8S中我们应该如何区分Deployment和服务呢?

  • Deployment主要负责让一组pod在集群中保持运行

  • 服务主要负责在集群中启用对一组pod的网络访问

我们可以使用deployment而不使用服务,所以我们可以保持几个相同的Pod在K8S集群中运行。此外,Deployment的规模可以扩大和缩小,pod也可以复制。在Kubernetes中,单个pod可以直接通过网络请求单独访问,因此要跟踪pod会有些困难。

我们也可以使用一个服务类型而不需要deployment。如果我们这样做,将创建一个单一的pod,而不是像我们在deployment中那样一起创建所有pod。不过,我们还有另一种替代方案,即我们的服务能够根据分配给它们的标签进行选择,从而将网络请求路由到这些Pod。

我们如何发现Kubernetes服务呢?

在Kubernetes中,有两种方式可以发现服务:

  • DNS类型。DNS server被添加到集群中,以便观察Kubernetes API为每个新服务创建DNS record set。当整个集群启用DNS后,所有的Pod都应该能够自动进行服务名称解析。

  • ENV变量。在这一发现方法中,一个pod运行在一个节点上,所以 kubelet为每个active服务添加环境变量。

ClusterIP、NodePort和LoadBalancer是什么?

服务规范中的类型属性决定了服务如何暴露在网络中。比如,ClusterIP、NodePort和LoadBalancer。

  • ClusterIP—默认值。该服务只能从Kubernetes集群内访问。

  • NodePort—这使得服务可以通过集群中每个节点上的静态端口访问。

  • LoadBalancer—服务通过云提供商的负载均衡器功能可以从外部访问。阿里云、AWS、Azure都提供了这一功能。

如何创建一个服务

通过deployment kind的帮助,以“Hello World” App形式的简单示例将会帮助你更好地理解如何创建服务。

我们的操作流程是,当我们看到应用程序已经部署完成并且以up状态运行的时候,我们将创建服务(Cluster IP)来访问Kubernetes中的应用程序。

现在,让我们创建一个正在运行的deployment

“kubectl run hello-world –replicas=3 –labels=眗un=load-balancer-example” –image=gcr.io/google-samples/node-hello:1.0 –port=8080”.

这里,这个命令在Kubernetes中创建了一个有两个应用程序副本的deployment。

接下来,

run "kubectl get deployment hello-world" so see that the deployment is running.
  你还要check 我方表示歉意,replicaset 以及pods  that 从而deployment 创建。
  美元,kubectl  get  deployments  hello world
  NAME ,,,,,,,,,,,, DESIRED  CURRENT ,, UP-TO-DATE ,, AVAILABLE ,,,,,,的年龄
  hello-world ,,, 3,,,,,,,,,, 3,,,,,,,,,,,, 3,,,,,,,, 3,,,,,,,,,,,,,, 76年代以前 

应用程序现在正在运行,如果你想要访问新创建的应用程序,我们需要创建ClusterIP类型的服务:

<李>

为服务创建一个YAML清单并应用它,或

<李>

使用<代码> kubectl公开代码> <>之前,美元kubectl  expose  deployment  hello-world  - type=ClusterIP  - name=示例服务   service “example-service",暴露

在这里,我们将创建一个名为示例服务的服务,类型为ClusterIP。

那么,现在我们将访问我们的应用程序:

 run “kubectl  get  service 示例服务”,用get  our  port 数字。

如何进行Kubernetes服务类型的浅析