在Kubernetes中,port-forwardServiceNodePortIngress都是用于将外部流量引入集群内部的方法,但它们在使用场景、实现方式和功能上有所不同。

  1. port-forward:

    • 使用场景:主要用于开发、测试和调试。它允许开发者在本地机器上访问集群内部的Pod,而无需将服务公开到外部网络。
    • 实现方式:通过kubectl命令行工具实现。开发者在本地机器上运行kubectl port-forward命令,指定要转发的Pod和端口号。该命令会创建一个从本地机器到Pod的端口转发连接。
    • 功能:临时性的、针对个人的端口转发。它不支持负载均衡和高可用性,只能用于单个Pod的访问。
  2. Service的NodePort:
    • 使用场景:适用于需要从集群外部访问集群内部服务,并且服务需要对多个用户或系统可用的情况。
    • 实现方式:通过Kubernetes的Service资源实现。在Service的定义中指定type: NodePort,并为Service分配一个NodePort。Kubernetes会在每个节点上打开该NodePort,并将流量转发到Service后端的Pod。
    • 功能:提供集群外部访问集群内部服务的能力。支持负载均衡(通过kube-proxy实现),但仅限于同一节点上的Pod之间的负载均衡。不具备高级路由功能。
  3. Ingress:
    • 使用场景:适用于需要从集群外部访问集群内部多个服务,并且需要基于HTTP/HTTPS进行路由的情况。Ingress可以提供更细粒度的访问控制、负载均衡和SSL/TLS终止等功能。
    • 实现方式:通过Kubernetes的Ingress资源实现。Ingress资源定义了外部访问的规则和路由信息。用户需要创建一个Ingress控制器(如Nginx Ingress Controller、Traefik等)来实际处理Ingress资源定义的规则。
    • 功能:提供集群外部访问集群内部多个服务的能力,并支持基于HTTP/HTTPS的路由、负载均衡、SSL/TLS终止等高级功能。Ingress控制器可以实现更复杂的路由规则、流量控制和安全策略。

总结来说,port-forward主要用于开发、测试和调试场景下的临时访问;Service的NodePort适用于需要从外部访问单个Service的情况,支持基本的负载均衡;而Ingress则适用于需要更复杂的路由和负载均衡规则的场景,特别是基于HTTP/HTTPS的访问控制。在选择使用哪种方式时,应根据具体的需求和场景进行权衡和选择。

k8s中port-forward 、service的nodeport与ingress区别的更多相关文章

  1. k8s的port、targetport、nodeport之间的区别

    先看举例: k8s集群中跑着一个tomcat服务,tomcat容器expose的端口为8080 apiVersion: v1 kind: Service metadata: name: tomcat- ...

  2. 详解k8s中的liveness和readiness的原理和区别

    liveness与readiness的探针工作方式源码解析 liveness和readiness作为k8s的探针,可以对应用进行健康探测. 二者支持的探测方式相同.主要的探测方式支持http探测,执行 ...

  3. k8s 中的 service 如何找到绑定的 Pod 以及如何实现 Pod 负载均衡

    k8s 中的 service 如何找到绑定的 Pod 以及如何实现 Pod 负载均衡 前言 endpoint kube-proxy userspace 模式 iptables ipvs kernels ...

  4. [转帖]k8s 中的服务如何沟通

    k8s 中的服务如何沟通 https://www.jianshu.com/p/9fae09876eb7 本文将介绍 k8s 中的服务如何相互访问,例如后端服务访问数据库,不同类型的服务间的相互访问.并 ...

  5. k8s中的网络(较详细汇总)

    目录 一.网络前提条件-网络模型 二.需要解决的网络问题 1.容器和容器之间的网络 2.pod与pod之间的网络 同一台node节点上pod和pod通信 不同node节点上pod和pod通信 3.po ...

  6. K8S中Service

    Service 的概念Kubernetes  Service  定义了这样一种抽象:一个  Pod  的逻辑分组,一种可以访问它们的策略 —— 通常称为微服务. 这一组  Pod  能够被  Serv ...

  7. k8s 辨析 port、NodePort、targetPort、containerPort 区别

    刚接触 k8s 涉及到端口到内容较多,容易混淆,这里整理如下: 目录 nodePort port targetPort containerPort 参考文章 nodePort nodePort 提供了 ...

  8. k8s中几个基本概念的理解,pod,service,deployment,ingress的使用场景

    k8s 总体概览 前言 Pod 副本控制器(Replication Controller,RC) 副本集(Replica Set,RS) 部署(Deployment) 服务(Service) ingr ...

  9. k8s中ingress,service,depoyment,pod如何关联

    k8s中pod通过label标签名称来识别关联,它们的label  name一定是一样的.ingress,service,depoyment通过selector 中app:name来关联 1.查询发布 ...

  10. 在k8s中的基本概念

    在k8s中的基本概念 一.Pod1. podk8s下最重要也最基本的概念,由一个根容器Pause和许多用户业务容器组成,是容器的载体. 2. pod的yaml定义格式及字段 apiVersion: v ...

随机推荐

  1. 1.10 内存ShellCode注入与格式化

    ShellCode 的格式化与注入功能在实战应用中也尤为重要,格式化Shellcode是指将其转换为可执行的二进制格式,使其能够在内存中运行.注入Shellcode是指将格式化的Shellcode注入 ...

  2. 解决github无法进入问题,DNS加速

    1.电脑的hosts文件在下面这个地址,找到hosts文件 C:\Windows\System32\Drivers\etc 2.进入文件夹目录etc 找到hosts文件,使用记事本编辑 3.进入这个网 ...

  3. Git企业开发控制理论和实操-从入门到深入(四)|Git的远程操作|Gitee

    前言 那么这里博主先安利一些干货满满的专栏了! 首先是博主的高质量博客的汇总,这个专栏里面的博客,都是博主最最用心写的一部分,干货满满,希望对大家有帮助. 高质量博客汇总 然后就是博主最近最花时间的一 ...

  4. 【链表】双向链表的介绍和基本操作(C语言实现)【保姆级别详细教学】

    双向链表 文章目录 前言 双向链表的基本介绍 一些链表的分类 带头双向循环链表的基本结构 双向链表的实现 结点的定义.头指针的创建 开辟结点接口 初始化头结点接口 打印接口 尾插接口 尾删接口 头插接 ...

  5. java线程池实现多任务并发执行

    Java线程池实现多任务并发执行 1️⃣ 创建一些任务来落地多任务并发执行 每一个数组里面的数据可以看成任务,或者是需要并发的业务接口, 数组与数组之间,可以看作为他们之间有血缘关系,简单来说就是: ...

  6. Linux-解决jps查看正在运行的Java进程时显示:process information unavailable 问题

    背景:jps全称为Java Virtual Machine Process Status Tool,是Java提供的一个查看当前用户有权访问的主机的Java进程情况的工具. 因为每一个Java程序都会 ...

  7. offline 2 online | 重要性采样,把 offline + online 数据化为 on-policy samples

    论文标题:Offline-to-Online Reinforcement Learning via Balanced Replay and Pessimistic Q-Ensemble CoRL 20 ...

  8. 《Boosting Document-Level Relation Extraction by Mining and Injecting Logical Rules》论文阅读笔记

    代码 原文地址 摘要 文档级关系抽取(DocRE)旨在从文档中抽取出所有实体对的关系.DocRE 面临的一个主要难题是实体对关系之间的复杂依赖性.与大部分隐式地学习强大表示的现有方法不同,最新的 Lo ...

  9. JS Leetcode 179. 最大数 题解分析,sort a-b与b-a的区别,sort排序原理解析

    壹 ❀ 引 今天的题目来自LeetCode179. 最大数,题目描述如下: 给定一组非负整数 nums,重新排列每个数的顺序(每个数不可拆分)使之组成一个最大的整数. 注意:输出结果可能非常大,所以你 ...

  10. postgresql备份和恢复操作

    1.介绍 最近项目上用了postgresql数据库,部署的时候需要备份数据库并在现场进行恢复操作,特此记录.我是在windows上安装的pgadmin4,此处用cmd下操作的: 备份命令:pg_dum ...