写点什么

Kubernetes 服务类型浅析:从概念到实践

  • 2020-11-06
  • 本文字数:2307 字

    阅读完需:约 8 分钟

Kubernetes服务类型浅析:从概念到实践


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



来源:

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=”run=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.Now we can check the replicaset and pods that the deployment created.$ kubectl get deployments hello-worldNAME          DESIRED   CURRENT   UP-TO-DATE   AVAILABLE       AGEhello-world    3          3            3        3              76s
复制代码


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


  • 为服务创建一个 YAML manifest 并应用它,或

  • 使用 kubectl expose 命令,这是一个更为简单的选项。因为这一命令可以无需创建 YAML 文件即可创建一个服务。


$ kubectl expose deployment hello-world --type=ClusterIP --name=example-serviceservice "example-service" exposed
复制代码


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


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


run “kubectl get service example-service” to get our port number.
复制代码


然后,我们需要执行 port-forward 命令。因为我们的服务类型是 ClusterIP,所以只能在集群内访问,因此我们必须通过转发端口到集群中的本地端口才能访问我们的应用程序。


我们可以使用其他类型,如 LoadBalancer,这将在 AWS 或 GCP 中创建一个 LB,然后我们可以使用给 LB 的 DNS 地址和我们端口号来访问应用程序。


$ kubectl get service example-service
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGEexample-service ClusterIP 100.20.167.76 <none> 8080/TCP 1h
$ kubectl port-forward service/example-service 8080:8080Forwarding from 127.0.0.1:8080 -> 8080
复制代码


现在我们可以从工作站浏览 http://localhost:8080,并且我们应该会看到:


Hello Kubernetes!
复制代码

Kubernetes 服务 NodePort YAML 示例

此示例 YAML 创建了可用于外部网络请求的服务。在这里,我们提到了带 Value 的 NodePort,因此服务被映射到集群中每个节点上的端口。



下面是一个 yaml 的例子,它将展示我们如何在 Kubernetes 中使用 NodePort 服务类型。


kind: Service apiVersion: v1 metadata:  name: hostname-service spec:  # Expose the service on a static port on each node  # so that we can access the service from outside the cluster   type: NodePort# When the node receives a request on the static port (30163)  # "select pods with the label 'app' set to 'echo-hostname'"  # and forward the request to one of them  selector:    app: echo-hostnameports:    # Three types of ports for a service    # nodePort - a static port assigned on each the node    # port - port exposed internally in the cluster    # targetPort - the container port to send requests to    - nodePort: 30163      port: 8080       targetPort: 80
复制代码


原文链接:

https://medium.com/avmconsulting-blog/service-types-in-kubernetes-24a1587677d6


本文转载自公众号 RancherLabs(ID:RancherLabs)。


原文链接


Kubernetes服务类型浅析:从概念到实践


2020-11-06 10:112607

评论

发布
暂无评论
发现更多内容

fil挖矿gas费怎么看?fil挖矿需要质押多少?

fil挖矿需要质押多少 fil挖矿gas费怎么看

kubebuilder 构建控制器说明点

Geek_f24c45

Kubernetes kubebuilder kube-controller

财经大课:如何看待规模化与差异化竞争

石云升

财经思维 9月日更

国产接口管理工具ApiPost中的COOKIE管理器

Proud lion

大前端 后端 Postman 开发工具 Cookie

AJAX获取的日期相差8小时

hasWhere

直播访谈-数据产品修炼之路

第519区

数据产品经理

网络攻防学习笔记 Day124

穿过生命散发芬芳

9月日更 互联网安全

InfoQ 引航计划正式启动!全网最优质技术内容,拿来吧你!

InfoQ写作社区官方

引航计划 技术专题合集 热门活动

“人类先锋”点亮物联网灯塔

脑极体

数据结构和算法在流程画布中的实际应用

GrowingIO技术专栏

数据结构 G6 图可视化引擎 流程画布

7个非常有前景的C++专业就业方向

hanaper

《转》什么是跨域?如何解决跨域问题?

hasWhere

鸿蒙轻内核的得力助手:带你掌握4种内存调试方法

华为云开发者联盟

鸿蒙

OCR加持白描App,让AI成为视障者的眼睛

百度开发者中心

人工智能 最佳实践 方法论 前沿技术

洞穿性能测试痛点,PerfDog以提升应用和游戏的品质为使命

WeTest

🐦【Mybatis开发指南】如何清晰的解决出现「多对一模型」和「一对多模型」的问题

码界西柚

Java mybatis mybatis配置 9月日更

Paxos理论介绍(4): 动态成员变更

OpenIM

重磅!博睿数据通过CMMI5级评估,国内APM领域首家

博睿数据

企业有运维人员,还有必要买运维管理系统吗?

行云管家

企业运维 运维审计 运维系统

看云起云动 览开源盛世 | 亚马逊云科技中国峰会Dev Day线上来袭!

亚马逊云科技 (Amazon Web Services)

MySQL 获取表的信息

玄兴梦影

MySQL 数据库表 查询语句

【HTML5游戏】从敲打空格键开始

devpoint

HTML5游戏 9月日更

北鲲云超算平台如何帮助现代生物制药发展?

北鲲云

数据安全法真的来了,这6个“雷区”千万别踩!

腾讯安全云鼎实验室

数据安全 数据安全法

fil挖矿机靠谱吗?fil挖矿哪家靠谱?

fil挖矿哪家靠谱 fil挖矿机靠谱吗

揭秘版权保护下的视频隐形水印算法(下篇)

拍乐云Pano

音视频 RTC 拍乐云 隐形水印

【虚拟机专栏】Rust智能合约的应用

趣链科技

区块链 智能合约 虚拟机

AISWare AntDB 亚信数据库在多省份计费系统应用案例

亚信AntDB数据库

案例分享 #数据库 9月日更

数字人民币最新技术成果将亮相2021年服贸会

CECBC

以两军问题为背景来演绎BasicPaxos

OpenIM

2021年广播电视网络安全等级保护定级流程

行云管家

运维 等保测评 企业运维 广播电视

Kubernetes服务类型浅析:从概念到实践_服务革新_Rancher_InfoQ精选文章