07-Eventing及实践

news2024/12/23 14:31:26

1 Knative Eventing的相关组件

  • Knative Eventing具有四个最基本的组件:Sources、Brokers、Triggers 和 Sinks
    • 事件会从Source发送至Sink
    • Sink是能够接收传入的事件可寻址(Addressable)或可调用(Callable)资源
      • Knative Service、Channel和Broker都可用作Sink
  • Knative Eventing的关键术语
    • Event Source
      • Knative Eventing中的事件源主要就是指事件的生产者
      • 事件将被发往Sink或Subscriber
    • Channel和Subscription
      • 事件管道模型,负责在Channel及其各Subscription之间格式化和路由事件
    • Broker和Trigger
      • 事件网格(mesh)模型,Producer把事件发往Broker,再由Broker统一经Trigger发往各Consumer
      • 各Consumer利用Trigger向Broker订阅其感兴趣的事件
    • Event Registry
      • Knative Eventing使用EventType来帮助Consumer从Broker上发现其能够消费的事件类型
      • Event Registry即为存储着EventType的集合,这些EventType含有Consumer创建Trigger的所有必要信息

2 Event 处理示意图

  • Event Source:事件源,即生产者抽象,负责从真正的事件源导入事件至Eventing拓扑中
  • Event Type:事件类型,它们定义于Event Registry中
  • Flow:事件处理流,可简单地手工定义流,也可使用专用的API进行定义
  • Event Sinks:能接收Event的可寻址(Addressable)或可调用(Callable)资源,例如KService等

在这里插入图片描述

3 Knative的事件传递模式

  • Knative Eventing中的Sink的用例主要有Knative service、channel、Broker三种

  • Knative Eventing支持的事件传递模式

    • Sources to Sink

      • 单一Sink模式,事件接收过程中不存在排队和过滤等操作
      • Event Source的职责仅是传递消息,且无需等待Sink响应
      • fire and forget

      在这里插入图片描述

    • Channels and Subscriptions

      • Event Source将事件发往Channel
      • Channel可以有一到多个Subscription(即Sink)
      • Channel中的每个事件都被格式化Cloud Event并发送至各Subscription
      • 不支持消息过滤机制

      在这里插入图片描述

    • Brokers and Triggers

      • 功能类似于Channel和Subscription模式,但支持消息过滤机制
      • 事件过滤机制允许Subscription使用基于事件属性的条件表达式(Trigger)筛选感兴趣的事件
      • Trigger负责订阅Broker,并对Broker上的消息进行过滤
      • Trigger将消息传递给感兴趣的Subscription之前,还需要负责完成消息的格式化
      • 这是在生产中推荐使用的消息投递模式

      在这里插入图片描述

4 CloudEvents示例

  • 最为简单的Event发送示例

    • Source:curl命令,基于HTTP消息映射规范手动编制消息及事件内容
    • Sink: 基于能够接收、解析事件,并将其存入日志的event_display应用为例来模拟事件处理
      • event_display可运行为Kubernetes Service,或者Knative Service
  • 步骤

    • 将event_display运行为Kservice。

      kn service create event-display --image ikubernetes/event_display --port 8080 --scale-min 1
      

      在这里插入图片描述

    • 启动一个client的pod,发起请求测试

      kubectl run client --image=ikubernetes/admin-box:v1.2 --restart=Never --rm -it --command -- /bin/bash
      

      发起请求测试命令:

      curl -v "http://event-display.default.svc.cluster.local" \
      -X POST \
      -H "Ce-Id: say-hello" \
      -H "Ce-Specversion: 1.0" \
      -H "Ce-Type: com.icloud2native.sayhievent" \
      -H "Ce-Time: 2023-12-01T11:35:56.7181741Z" \
      -H "Ce-Source: sendoff" \
      -H "Content-Type: application/json" \
      -d '{"msg":"Hello littlyboy Knative!"}'
      

      在这里插入图片描述

    • 查看event_display中的log是否收到事件

      kubectl logs -f event-display-00001-deployment-5ddb97ff7-mfhhq
      

      在这里插入图片描述

5 Eventing的逻辑组件

  • Eventing API群组及相应的CRD

    • sources.knative.dev # 声明式配置Event Source的API,提供了四个开箱即用的Source;

      • ApiServerSource:监听Kubernetes API事件
      • ContainerSource:在特定的容器中发出针对Sink的事件
      • PingSource:以周期性任务(cron)的方式生具有固定负载的事件
      • SinkBinding:链接任何可寻址的Kubernetes资源,以接收来自可能产生事件的任何其他Kubernetes资源

      在这里插入图片描述

    • eventing.knative.dev # 声明式配置“事件网格模型”的API

      • Broker
      • EventType
      • Trigger
    • messaging.knative.dev # 声明式配置“事件管道模型”的API

      • Channel
      • Subscription
    • flows.knative.dev # 事件流模型,即事件是以并行还是串行的被多个函数处理

      • Parallel
      • Sequence

6 事件与Knative Eventing

在这里插入图片描述

  • Knative Eventing
    • 负责为事件的生产和消费提供基础设施,可将事件从生产者路由到目标消费者,从而让开发人员能够使用事件驱动架构
    • 各资源者是松散耦合关系,可分别独立开发和部署
    • 遵循CloudEvents规范

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

二维码智慧门牌管理系统升级解决方案:房屋管理

文章目录 前言一、一站式服务二、全方位管理三、未来展望四、智慧解决方案 前言 科技带来智慧生活 随着科技的不断发展,智能化已经成为我们生活的重要组成部分。二维码智慧门牌管理系统是这一趋势中的关键工具之一。除了提供标准地址服务外,该系统还为房…

全栈开发中的安全注意事项:最佳实践和工具

安全性是当今数字环境中最重要的问题,而在全栈开发中这一点尤为重要。当企业努力创建强大且动态的应用程序时,他们必须应对复杂的安全威胁领域。在本文中,我们将探讨开发人员可以用来确保安全的全栈开发环境的最佳实践和工具。 1.1 全栈开发的…

电脑软件:推荐一款非常实用的屏幕截图软件

目录 一、功能介绍 二、软件特色 三、常用快捷键 四、软件总结 五、软件下载 FastStone Capture是一款功能强大的屏幕截图软件,它可以帮助用户轻松地捕获屏幕上的任何区域,并将其保存为各种格式的图像文件。以下是关于FastStone Capture软件的一些详…

小信砍柴的题解

目录 原题描述: 时间:1s 空间:256M 题目描述: 输入格式: 输出格式: 样例1输入: 题目大意: 主要思路: 注意事项: 总代码: 原题描述&#…

59. 螺旋矩阵 II(java实现,史上最详细教程,想学会的进!!!)

今天来分享一下螺旋矩阵的解题思路及代码的实现。 题目描述如下: 首先拿到这道题,首先不要慌张,我们来仔细分析一下会发现并没有那么难。 首先看下边界的元素是1、2、3递增的,那么我们也许可以根据这一点先把边界的元素一个一个给…

上下界取min/max的线段树问题:P8518 [IOI2021] 分糖果

https://www.luogu.com.cn/problem/P8518 没有要求在线,显然离线(。维护时间戳,上线段树。 好了,我们现在知道一个人的曲线变化了。怎么做呢? 前面所有碰上下界的都是没用的!我们只需要找最后一段的时间…

TrustZone之顶层软件架构

在处理器中的TrustZone和系统架构中,我们探讨了硬件中的TrustZone支持,包括Arm处理器和更广泛的内存系统。本主题关注TrustZone系统中发现的软件架构。 一、顶层软件架构 下图显示了启用TrustZone的系统的典型软件栈: 【注意】:为简单起见,该图不包括管理程序,尽管它们可…

【C语言】鹏哥C语言刷题训练营——第5节内容笔记(含代码全面分析和改进,讲解)

系列文章目录 身躯已然冰封,灵魂仍旧火热 本文由睡觉待开机原创,未经允许不得转载。 本内容在csdn网站首发 欢迎各位点赞—评论—收藏 如果存在不足之处请评论留言,共同进步! 文章目录 系列文章目录前言题目链接(有需要…

计算机组成原理——数制与编码

1.在以下编码中,零的表示唯一的是(C) A.反码 B.原码 C.补码 D.原码和移码 2.假设某数的真值为-100 1010B,在计算机内部表示为1011 0110B,该数采用的编码为(D) A.移码 B.原码 C.反码 D.补码 3.…

Linux shell编程学习笔记36:read命令

目录 0 前言1 read命令的功能、格式、返回值和注意 1.1 命令功能1.2 命令格式1.3 返回值1.4 注意事项2 命令应用实例 2.1 一次读入多个变量值2.2 不指定变量名2.3 测试read命令的返回值2.3 指定输入时限并进行相应处理2.4 -t 指定结束符2.5 -n 指定输入字符个数2.6 -N 指定输入…

分类预测 | Matlab实现AOA-SVM算术优化支持向量机的数据分类预测【23年新算法】

分类预测 | Matlab实现AOA-SVM算术优化支持向量机的数据分类预测【23年新算法】 目录 分类预测 | Matlab实现AOA-SVM算术优化支持向量机的数据分类预测【23年新算法】分类效果基本描述程序设计参考资料 分类效果 基本描述 1.Matlab实现AOA-SVM算术优化支持向量机的数据分类预测…

css的filter全属性介绍

原图: 模糊(blur) 单位可为px或rem,值越大,越模糊 filter:blur(3px) filter:blur(0.3rem) 亮度(brightness) 值可为数字或百分数,小于1时,亮度更暗;等于1时,无变化&am…

微信支付怎么申请0.2费率

作为移动支付的主流方式,微信收款和支付宝为商家带来了便利的同时,每笔交易都要收取的0.6%收款手续费也成为商家的负担。现在使用现金支付的人少之又少,为了给顾客带来便捷的购物体验,所以即便是要付出手续费&#xff…

十四、YARN核心架构

1、目标 (1)掌握YARN的运行角色和角色之间的关系 (2)理解使用容器做资源分配和隔离 2、核心架构 (1)和HDFS架构的对比 HDFS架构: YARN架构:(主从模式) &…

visual stdio code运行vue3

npm init vuelatest 该命令初始化vue项目 使用visual stdio code创建vue项目 ,这边是vue-project文件夹 vs code打开项目 vscode操作vue项目 vscode操作vue项目

【Leetcode】旋转矩阵

题目链接:https://leetcode.cn/problems/rotate-matrix-lcci/description/ 题目描述 给你一幅由 N N 矩阵表示的图像,其中每个像素的大小为 4 字节。请你设计一种算法,将图像旋转 90 度。 不占用额外内存空间能否做到? 示例 …

找出一个二维数组中的鞍点

找出一个二维数组中的鞍点&#xff0c;即该位置上的元素在该行上的最大、在该列上最小。也有可能没有鞍点。 #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> int main() {int a[10][10] { 0 };int n 0, m 0;int i 0, j 0;printf("请输入这个数组有n行m列…

算法学习——栈与队列

栈与队列 栈与队列理论基础用栈实现队列思路代码 用队列实现栈思路代码 删除字符串中的所有相邻重复项思路代码 有效的括号思路代码 逆波兰表达式求值思路代码 滑动窗口最大值思路代码未完待续 前 K 个高频元素思路代码拓展 总结栈在系统中的应用括号匹配问题字符串去重问题逆波…

FPGA时序分析与时序约束(二)——时钟约束

目录 一、时序约束的步骤 二、时序网表和路径 2.1 时序网表 2.2 时序路径 三、时序约束的方式 三、时钟约束 3.1 主时钟约束 3.2 虚拟时钟约束 3.3 衍生时钟约束 3.4 时钟组约束 3.5 时钟特性约束 3.6 时钟延时约束 一、时序约束的步骤 上一章了解了时序分析和约束…

LinuxCNC的使用

先进行程序设置 点击“开始”,选择“创建新的配置” 设置好机床名称和单位 关键是需要设置并口地址 查看并口使用命令:lscpi -v 将使用的并口填入: 这里是设置页面