Kubernetes中Ingress的原理和配置

news/2025/1/20 12:15:26/文章来源:https://www.cnblogs.com/MarkGuo/p/18431522

image

Ingress的概念和作用

Ingress是Kubernetes集群中的一个对象,用于将外部流量路由到集群内部的服务。它充当了进入Kubernetes集群的API网关,负责接收外部请求,并将其转发到正确的目标服务上。

Ingress通常通过HTTP和HTTPS提供对服务的访问,并支持基于主机名、路径以及其他HTTP请求属性的路由。通过在集群内部运行Ingress控制器,可以根据Ingress规则配置和管理路由规则,从而实现流量的负载均衡、SSL终止、安全认证等功能。

Ingress的7层路由机制的实现

Ingress的7层路由机制是通过Ingress控制器实现的,其基本工作原理如下:

  1. 首先,Ingress控制器会监视Kubernetes集群中的Ingress对象。
  2. 当新的Ingress对象被创建或更新时,Ingress控制器会读取相应的规则配置。
  3. Ingress控制器将解析这些规则,并将其映射到负载均衡器或代理服务器上。
  4. 通过负载均衡器或代理服务器,Ingress控制器将外部流量转发到集群内部的服务。这个过程通常基于主机名、路径和其他HTTP请求属性进行路由。
  5. 接收到流量的服务会根据规则设置,处理请求并返回响应。

具体实现7层路由的方式取决于使用的Ingress控制器。一种常见的实现方式是通过反向代理服务器,如Nginx、Traefik或HAProxy,将外部流量转发到正确的服务上。这些反向代理服务器会基于Ingress规则进行配置,根据请求的属性进行路由。负载均衡器也可以用于在多个服务之间平衡流量。

在Kubernetes中配置Ingress的规则和路由可以通过以下步骤和配置方式完成:

  1. 安装Ingress Controller:首先需要安装Ingress Controller,例如使用Nginx Ingress Controller。可以通过部署相关的Ingress Controller来完成,例如使用Helm进行安装。
  2. 创建Ingress资源:创建一个Ingress资源来定义规则和路由。可以使用yaml文件来定义并创建Ingress资源。
  3. 配置规则和路由:在Ingress资源的规则部分,可以定义多条路由规则来指定转发请求的目标。可以按需求创建不同的路径和服务的映射关系。

下面是一个示例,演示如何在Kubernetes中配置Ingress的规则和路由:

代码语言:yaml

复制

apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  name: my-ingress
spec:
  rules:
  - http:
      paths:
      - path: /app1
        pathType: Prefix
        backend:
          service:
            name: app1-service
            port:
              number80
      - path: /app2
        pathType: Prefix
        backend:
          service:
            name: app2-service
            port:
              number80

上述示例中,我们定义了一个Ingress资源,并配置了两条路由规则。其中,/app1请求会被转发到名为app1-service的Service的80端口,/app2请求会被转发到名为app2-service的Service的80端口。

备注:这只是一个简单的示例,实际使用中可以根据需要进行更复杂的规则和路由配置。具体的Ingress规则和路由配置可以参考相关的文档和资源。

Ingress与Service之间的关系

  • Ingress是Kubernetes中的一种资源对象,用于将外部流量路由到集群中的Service。
  • Service是Kubernetes中的另一种资源对象,用于暴露Pods的网络服务。

Ingress通过定义规则将外部流量路由到集群内的Service。它可以通过不同的方式(如域名、路径、端口等)对流量进行分发,并支持TLS终止和负载均衡。Ingress本身并不处理流量,而是通过与实际提供服务的Service对象进行协作,将流量转发到对应的Service。

应用访问控制方面的区别和共同点

  • 区别:

    • Ingress主要用于L7(应用层)流量的路由。它可以根据域名、路径等规则对流量进行分发,实现了灵活的路由和负载均衡功能。
    • Service主要用于L4(传输层)流量的暴露。它定义了一组Pod的访问入口,可以通过Cluster IP、NodePort、LoadBalancer等方式将流量引入到集群内部。
  • 共同点:

    • Ingress和Service都是Kubernetes中用于应用访问控制的重要组件。
    • 它们都可以帮助管理员管理流量,并提供一种方式将外部请求引入到集群内部。
    • 在实际使用中,Ingress和Service常常结合起来使用,通过Ingress将流量路由到对应的Service,实现灵活的应用访问控制。

在使用Ingress进行应用访问控制时,可以通过以下步骤实现基于域名的路由和流量分发:

  1. 创建Ingress资源:首先,需要创建一个Ingress资源,该资源定义了路由规则和流量分发配置。可以使用以下示例来创建一个基于域名的Ingress资源:

代码语言:yaml

复制

apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  name: my-ingress
spec:
  rules:
    - host: yifan-online.com.com
      http:
        paths:
          - pathType: Prefix
            path: "/"
            backend:
              service:
                name: my-app
                port:
                  number: 80

在这个示例中,规定了当域名为yifan-online.com时,所有的HTTP请求都会被路由到名为my-app的后端服务上。

  1. 配置DNS解析:接下来,需要将域名解析到Ingress控制器的IP地址上。可以通过修改域名的DNS记录来实现,将域名解析到Ingress控制器的IP地址上。
  2. 配置Ingress控制器:需要确保已经部署了Ingress控制器,以便于处理Ingress资源的路由规则和流量分发配置。例如,可以使用Nginx Ingress控制器或Traefik Ingress控制器。
  3. 验证路由和流量分发:验证配置是否生效,可以通过访问域名来触发Ingress控制器的路由和流量分发功能。例如,在上述示例中,访问http://yifan-online.com将会被路由到名为my-app的后端服务。

这样就实现了基于域名的路由和流量分发。可以根据实际需求配置多个Ingress资源,并为每个Ingress资源指定不同的域名和后端服务,实现灵活的路由控制和流量分发配置。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/803514.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

《如 何 速 通 一 套 题》4.0

A sprial 找规律。直接做。 #include <bits/stdc++.h> #define int long long using namespace std;int t, n;int sqrtll(int n) {int l = 1, r = 1000000, ans = 0;for(; l <= r; ) {int mid = (l + r) >> 1;if(mid * mid >= n) {ans = mid, r = mid - 1;}e…

自定义表格样式

HTML:<div class="table-container"><table style="width: 90%; margin-left: 5%"><tr class="table-title"><th style="width: 33%">科室名称</th><th style="width: 33%">当日登录次…

Bash脚本基本语法

一、Bash脚本以及相关介绍Bash脚本是一种在Unix或Linux操作系统中广泛使用的脚本语言,它允许用户编写一系列命令,这些命令将被Bash(Bourne-Again SHell)解释器执行。Bash脚本可以用于自动化各种任务,比如文件管理、程序执行、系统维护等。 编写Bash脚本的基本步骤包括:创…

【vulhub】Discuz-任意文件删除

【vulhub】Discuz-任意文件删除 0x00漏洞介绍 通过配置个人信息的属性值,导致文件删除。 影响版本Discuz <= 3.40x01 搭建环境 数据库服务器填写db(必须db,不然安装失败),数据库名为discuz,数据库账号密码均为root,管理员密码任意。填写联系方式页面直接点击跳过本步…

2024年开源API工具盘点,覆盖API全生命周期

2024年经济持续低迷,本文整理一些免费的开源工具,旨在帮助企业组织降低工具的支出成本,能用免费的何必用付费的呢(狗头)? 如何高效地管理API的全生命周期——从设计、开发、测试、部署到监控和优化,已经成为每个开发者和技术团队关注的重点。以下工具清单,无论你是刚刚…

Day4 与用户交互 + 格式化运算符 + 基本运算符

今天首先对昨天学的进行了复习,由这个复习可以看出昨天的我是多么的水*-*,今天的话倒是学的挺充实的,因为没有像上节课的jupyter notebook那样的东西(这节课看下来还是挺牛的,但也没到非用不可的时候,继续放着吧)。今天主要学习了三大部分,与用户的交互,格式化占位符,…

ACCESS 关于MSCOMCT2.OCX和MSCOMCTL.OCX报错的解决方案

我在ACCESS中添加了TreeView插件,结果电脑A上打开没问题,电脑B打开时就报MSCOMCT2.OCX和MSCOMCTL.OCX有错. B电脑之前是可以正常使用的,但是加了TreeView插件之后报错,说明是插件引用的问题. 在网上下载了这两个文件,复制到C:\WINDOWS\SYSTEM32目录下. 重新注册了这两个文件: 以…

74hc595

74htc595 功能 8位串行输入 8位串行或并行输出 带3态输出的存储 寄存器带直接清零的移位寄存器100 MHZ(典型) 移出频率 ESD保护H BM ELAJESD22-A114-A超过2000VMM EIAJESD23-A115-A超过200 V说明 74HC/HCT595是高速硅栅CMOS器件, 与低功率肖特基TTLLSTTL引脚兼容。 它们是根…

直接调拨单的酶活总量换算不正确

物料单位换算中的换算类型需要设置为浮动, 原来的是固定.

9月25日小学加减法的编程

根据问题要求来写程序,程序编写难度不高,交互更加友好 需要关注几个点 1加上目前是第几道题的说明 2如果输入错误要有提示第一第几道题是根据循坏的i来决定的但是要注意有些进入了循环但是没有进行答题的要写上i--; 第二要进行hasNextInt()的判断,防止错误输入导致的程序停…

Git - 初识版本库

版本库也叫仓库,英文名 repository。版本库也叫仓库,英文名 repository。 ‍ 创建版本库 之前我们说了版本库的概念:存储版本的地方(存放各个版本之间差异的地方),通常称为版本库。通常版本库是以文件(夹)的形式存放在磁盘上:Git 是用一个目录来存储各个版本和差异的文…

关于QT6.5.3版本安装、更新/添加组件的一些心得

目录引言 一、如何下载和卸载QT1.下载QT 2.卸载QT二、镜像引言 本文主要记录一下关于Visual Studio 2022和Qt Creator 14.0.1 (Community)的安装🛠️和配置⚙️ 起因是第一次下载QT时看着众多的组件不知如何选择,上网搜索攻略🔗看的头晕眼花(本来好简单的一件事🤣) 然…