当前位置: 首页 > news >正文

Flink之水印(watermark)的补充理解

水印(Watermark)‌:用于事件时间处理,标记数据流的进度,解决乱序和延迟问题,触发窗口计算‌

一、Flink 水印的作用

  • 处理乱序事件‌
    水印(Watermark)是 Flink 用于处理事件时间(Event Time)乱序数据的核心机制。水印表示“在该时间戳之前的数据已全部到达”,允许系统在不确定数据顺序的情况下推进计算进度‌。‌
  • 触发窗口计算‌
    当水印时间超过窗口的结束时间时,触发窗口计算并关闭窗口,确保窗口内的数据完整性‌。
  • 容忍数据延迟‌
    通过设置允许延迟时间(如 BoundedOutOfOrderness),水印可等待一定范围内的迟到数据,避免因短暂乱序导致数据丢失‌。

二、水印判定数据迟到的逻辑

水印通过以下机制判定迟到数据:

  • 基准定义‌
    • 水印时间T表示事件时间≤T的数据应已到达系统‌。
    • 任何事件时间≤T但晚于水印到达的数据视为迟到‌。
  • 窗口触发与迟到处理‌
    • 窗口触发条件:水印时间 ≥ 窗口结束时间‌。
    • 窗口关闭后,事件时间属于该窗口的数据将被丢弃或通过侧输出(Side Output)处理‌。
    • 允许延迟(Allowed Lateness):窗口可额外等待一段时间(如3秒),延迟期内到达的数据仍可被处理‌。

‌策略选择原则‌:根据数据乱序程度选择固定延迟或单调递增策略,极端乱序场景需结合侧输出(Side Output)处理异常事件‌。
高乱序场景优先采用事件时间窗口+水印机制。

三、水印的初次生成原理

‌1. 初始触发条件‌
水印的初次生成依赖于第一条到达的事件数据。系统提取其事件时间戳,结合允许延迟时间计算初始水印‌。

  • 公式‌:初始水印时间 = 第一条数据的事件时间 - 允许延迟时间
  • 示例:若第一条数据的事件时间为 10:00,允许延迟为 5分钟,则初始水印为09:55‌

2‌. 动态更新机制‌
后续水印根据新到达数据的事件时间动态更新,始终以当前最大事件时间为基准‌。

四、水印的生成策略‌

  1. 固定延迟策略‌(BoundedOutOfOrderness)
    显式指定允许的最大延迟时间,适用于数据存在可控乱序的场景。
WatermarkStrategy.forBoundedOutOfOrderness(Duration.ofMinutes(5))

该策略生成的水印时间 = 当前最大事件时间 - 允许延迟时间‌。

  1. 单调递增策略‌(forMonotonousTimestamps)
    假设数据严格有序,允许延迟时间设为 0,水印时间等于当前最大事件时间。适用于数据源本身有序的场景‌。
  2. 自定义生成策略‌
    通过实现 WatermarkGenerator 接口,根据业务逻辑动态调整水印生成规则(如根据事件特征或外部系统状态)‌。

五、数据乱序时事件时间窗口 vs. 处理时间窗口

‌对比维度基于事件时间的窗口‌基于处理时间的窗口
‌时间基准数据自带的事件时间戳‌系统处理时间(无需水印)‌
‌水印作用解决乱序问题,动态控制窗口关闭时机‌无关联,窗口直接按系统时间划分‌
乱序处理能力通过水印延迟窗口关闭,允许迟到数据进入窗口‌无法处理乱序,窗口按固定时间触发‌
典型配置需指定 TimestampAssigner 和 WatermarkStrategy‌仅需定义窗口大小和滑动间隔‌

核心差异说明

  • 事件时间窗口‌:依赖水印动态调整窗口关闭时间,水印生成与数据事件时间强相关。例如,若数据时间戳跳跃式增长,水印会快速推进,可能导致中间窗口提前关闭‌。
  • 处理时间窗口‌:完全基于系统时钟,窗口触发与数据实际到达顺序无关,无法感知事件时间的乱序问题‌。

六、风险对系统的影响及应对策略

1‌. 潜在风险‌

  • 窗口提前关闭‌:若事件时间突然大幅推进(如从10:00跳跃到12:00),可能导致中间窗口(如10:00-11:00)因水印跨越而提前关闭,后续数据无法进入这些窗口‌。
  • 数据倾斜‌:时间戳异常事件可能导致水印频繁推进,增加窗口计算频率和资源消耗‌。

2‌. 优化配置‌

  • 限制水印推进速度‌:通过BoundedOutOfOrderness策略设置最大允许延迟时间,避免因偶发大时间戳事件导致水印异常推进‌。
    示例代码:
WatermarkStrategy.forBoundedOutOfOrderness(Duration.ofMinutes(5))
  • 侧输出异常事件‌:对时间戳显著偏离当前窗口范围的事件,通过侧输出(Side Output)单独处理‌
    示例:
OutputTag<Event> anomalousTag = new OutputTag<>("anomalous"){};
stream.process(new ProcessFunction<Event, Event>() {@Overridepublic void processElement(Event event, Context ctx, Collector<Event> out) {if (event.getTimestamp() > ctx.timerService().currentWatermark() + MAX_SKEW) {ctx.output(anomalousTag, event);} else {out.collect(event);}}
});

七、典型场景示例

假如第一个事件事件是10:00,基于事件时间滚动窗口为5分钟,
那么第一个窗口范围是多少?
如果允许迟到2分钟,第一个水印时间是多少?
触动第一个窗口关闭的水印时间是多少?
那么10:06的事件会被分到第几个窗口呢?

第一个窗口范围

当第一个事件的事件时间为 10:00,基于事件时间的滚动窗口为5分钟时,‌第一个窗口的范围是 [10:00, 10:05)‌,第二个窗口:[10:05, 10:10),以此类推。

滚动窗口将事件时间划分为固定长度且不重叠的区间,每个窗口的起始时间为事件时间的整数倍‌12。例如,事件时间 10:00 会被分配到 10:00-10:05 的窗口‌。

允许迟到2分钟时的第一个水印时间

若允许迟到时间为2分钟,‌第一个水印时间为 9:58‌。

水印时间计算公式为:水印时间 = 当前最大事件时间 - 允许延迟时间‌。
当第一个事件到达时,当前最大事件时间为 10:00,允许延迟为2分钟,因此水印初始值为 10:00 - 2分钟 = 9:58‌。

触发第一个窗口关闭的水印时间

‌触发第一个窗口关闭的水印时间为 10:07‌。

窗口关闭条件:当水印时间超过窗口结束时间(10:05)时,窗口关闭并触发计算‌。
允许迟到2分钟时,窗口会在原结束时间基础上额外等待2分钟。因此,实际触发关闭的水印时间为 10:05 + 2分钟 = 10:07‌。

事件时间 10:06 的窗口分配

  • 当事件时间为 10:06 时,基于事件时间的滚动窗口(窗口大小5分钟),事件时间 10:06 落在 10:05 ≤ 时间戳 < 10:10 区间内,因此会将其分配到 ‌第二个窗口‌,即窗口范围为 [10:05, 10:10)‌。
  • 允许迟到时间(如2分钟)仅影响窗口关闭的触发时机(窗口会在原结束时间后等待2分钟),‌不改变事件所属窗口的分配逻辑‌。例如:
    • 窗口 [10:00, 10:05) 的关闭水印时间为 10:07(原结束时间 10:05 + 允许迟到2分钟)‌。
    • 事件时间 10:06 即使迟到,仍属于窗口 [10:05, 10:10),与允许迟到时间无关‌。

相关文章:

Flink之水印(watermark)的补充理解

水印&#xff08;Watermark&#xff09;‌&#xff1a;用于事件时间处理&#xff0c;标记数据流的进度&#xff0c;解决乱序和延迟问题&#xff0c;触发窗口计算‌ 一、Flink 水印的作用 处理乱序事件‌ 水印&#xff08;Watermark&#xff09;是 Flink 用于处理事件时间&…...

革新音频技术,引领智能录音新时代—广州唯创电子WT2605芯片深度解析

在万物互联的智能时代&#xff0c;音频处理技术作为人机交互的核心载体&#xff0c;正不断推动消费电子、物联网设备及行业工具的升级迭代。广州唯创电子凭借多年深耕音频芯片领域的经验&#xff0c;推出了一款集多功能、高集成度与灵活扩展性于一体的音频处理芯片——WT2605。…...

jumpserver 网络安全 网络安全 authenticity

1.1 计算机安全的概念 1.1.1 计算机安全最核心的三个关键目标(CIA)&#xff1a; 保密性(Confidentiality)--①数据保密性&#xff08;确保隐私或秘密不向非授权者泄密或使用&#xff09;&#xff1b; ②隐私性&#xff08;确保个人能够控制或确定其自身相关的信息&#xff09…...

文件上传漏洞(条件竞争)

[TCO]catalog 文件上传漏洞简介 文件上传漏洞是一种常见的 Web 安全漏洞&#xff0c;攻击者可以通过该漏洞上传恶意文件&#xff0c;如 WebShell、木马或其他恶意代码脚本&#xff0c;以实现远程控制服务器、窃取数据或发起进一步攻击。这类漏洞通常源于 Web 应用在文件上传功…...

向量数据库的选择与应用:AI工程实践

一、向量数据库&#xff1a;AI时代的核心基础设施 1.1 从关系型到向量型&#xff1a;数据库的技术演进 传统数据库与向量数据库的对比&#xff1a; 特性关系型数据库向量数据库数据模型结构化表格高维向量元数据核心操作CRUD相似性搜索典型场景交易系统推荐系统/图像检索性能…...

文件上传复现

1、什么是文件上传漏洞&#xff1f; 答&#xff1a;文件上传漏洞是指攻击者通过上传恶意文件到服务器、从而执行任意代码、获取系统权限或者破坏系统安全的漏洞、常见于允许用户上传文件的Web应用程序中。 2. 文件上传漏洞形成原因 未验证文件类型&#xff1a;未对上传文件的…...

数据结构全解析:从线性到非线性,优缺点与应用场景深度剖析

1. 线性数据结构 &#xff08;1&#xff09;数组&#xff08;Array&#xff09;&#xff08;适合静态数据&#xff09; 优点&#xff1a; 随机访问高效&#xff1a;通过索引可以直接访问元素&#xff0c;时间复杂度为 O(1)。 内存连续&#xff1a;数组在内存中是连续存储的&…...

JAVA面试_进阶部分_Ibatis与Hibernate的区别

一、 hibernate与ibatis之间的比较&#xff1a; hibernate 是当前最流行的o/r mapping框架&#xff0c;它出身于sf.NET&#xff0c;现在已经成为jboss的一部分了。 ibatis 是另外一种优秀的o/r mapping框架&#xff0c;目前属于apache的一个子项目了。 相对hibernate“o/r”而…...

页面刷新时 选择值或输入值不丢失

视图完整代码 <body><h1>查询员工信息</h1><form action"SearchForm" style"text-align: center;">所属部门&#xff1a;<select name"ddlDept" id"ddlDept"><option value"">--请选择…...

通用人工智能(AGI):定义、挑战与未来展望

文章目录 引言AGI的定义与特征实现AGI的挑战AGI与ASI的区别AGI的潜在影响结语 引言 通用人工智能&#xff08;Artificial General Intelligence, AGI&#xff09;是人工智能领域的终极目标&#xff0c;代表着一种能够执行人类所有智力任务的系统。与当前的任务导向型人工智能&…...

考研数学复习之定积分定义求解数列极限(超详细教程)

定积分求解数列极限是一种将数列极限问题转化为定积分问题进行求解的方法。这种方法通常适用于那些和式数列极限,其主要思路是将数列的项看作是某个函数在某一点或某一段区间上的取值或某种形式的和,然后利用定积分的性质和计算方法,来求解这类数列的极限。 定积分定义 设函数在…...

【redis】应用场景:共享会话和手机验证码

文章目录 共享会话实现思路 手机验证码实现思路伪代码实现生成验证码验证验证码 共享会话 实现思路 如果每个应用服务器&#xff0c;维护自己的会话数据&#xff0c;此时彼此之间胡共享&#xff0c;用户请求访问到不同的服务器上&#xff0c;就可能会出现一些不能正确处理的情…...

vscode带参数调试

转载&#xff1a;【深度学习环境】VSCode 调试python 带args参数的程序_vscode args-CSDN博客 ctrlshiftf全局搜索...

音视频软件工程师面试题

一、基础知识 编解码相关 H.264 和 H.265(HEVC)的主要区别是什么?视频编解码的基本流程是什么?关键技术有哪些?音频编解码(如 AAC、MP3、Opus)的区别和应用场景?什么是 B 帧、P 帧、I 帧?它们的作用是什么? 流媒体协议RTMP、HTTP-FLV、HLS、WebRTC 的区别和应用场景…...

mac用docker跑sql server

网上的各个文章跑下来都有一些问题&#xff0c;记录一下我成功跑起来的过程。 省略Docker安装 修改docker源&#xff1a; {"builder": {"gc": {"defaultKeepStorage": "20GB","enabled": true}},"experimental"…...

【技海登峰】Kafka漫谈系列(八)Controller:Zookeeper模式与KRaft模式

【技海登峰】Kafka漫谈系列(八)Controller:Zookeeper模式与KRaft模式 在上述学习过程中,我们知道完整的Kafka集群架构中包含了Broker、Topic、Partition、Replica、Producer、Consumer等众多组件,它们之间的关系又非常复杂:比如Topic由多个Partition组成、Partition又包含…...

c# txt文档的实时显示,用来查看发送接收指令

通讯历史按钮 private void uiButton1_Click(object sender, EventArgs e){try{logf new logF();logf.Show();}catch (Exception){throw;} }主页面关闭函数&#xff08;点击保存就为true true就不删除&#xff09; private void page1_FormClosed(object sender, FormClos…...

LabVIEW变频器谐波分析系统

随着工业自动化的发展&#xff0c;变频器在电力、机械等领域的应用日益广泛&#xff0c;但谐波问题直接影响系统效率与稳定性。传统谐波检测设备&#xff08;如Norma5000&#xff09;精度虽高&#xff0c;但价格昂贵且操作复杂&#xff0c;难以适应现场快速检测需求。本项目基于…...

搜广推校招面经四十三

快手主站推荐算法 一、因果推荐和偏差消除在推荐系统中的应用 1.1. 因果推荐 因果推荐&#xff08;Causal Recommendation&#xff09;是指利用因果推断的方法来理解和优化推荐系统的行为。不同于传统的基于关联分析的推荐方法&#xff0c;因果推荐旨在揭示用户行为背后的真…...

Android打造易用的 WiFi 工具类:WifiUtils 封装实践

Android在全局范围内使用WifiUtils工具类&#xff0c;我们可以将其设计为一个单例&#xff0c;并通过Application类进行初始化。这样可以确保在整个应用程序中只有一个WifiUtils实例&#xff0c;并且可以在任何地方访问它。以下是实现全局使用的步骤和代码示例&#xff1a; 记…...

010-Catch2

Catch2 一、框架简介 Catch2 是一个基于 C 的现代化单元测试框架&#xff0c;支持 TDD&#xff08;测试驱动开发&#xff09;和 BDD&#xff08;行为驱动开发&#xff09;模式。其核心优势在于&#xff1a; 单头文件设计&#xff1a;v2.x 版本仅需包含 catch.hpp 即可使用自然…...

Kubernetes Pod的生命周期概述

概述 在Kubernetes的世界中&#xff0c;Pod作为最基本的应用进程单元, 其生命周期也代表着应用进程的整个生命周期。了解其生命周期是掌握云计算中一个计算单元如何在Kubernetes世界周转的基石。 本期文章主要针对于Pod的生命周期的不同阶段进行介绍&#xff0c;让读者能够对…...

Linux服务器使用docker离线安装MySQL

今天记录一下&#xff0c;Linux的docker安装MySQL镜像的步骤&#xff0c;以后安装任何镜像都可以仿照本篇文章。 因为我有一台云服务器是联网的&#xff0c;所有我的步骤就是把需要的镜像都在云服务器下载好&#xff0c;再保存下来&#xff0c;传到本地的不联网服务器。 其实我…...

软件安全分析与应用之Web安全(二)

2.3 第 3 题 Web 安全 2.3.1 撰写安装报告 要求录屏 &#xff08;1&#xff09;Vmware&#xff1b; 首先找到.iso镜像 点击下一步我接受 下一步 下一步 下一步 下一步 点击升级等待完成安装 &#xff08;2&#xff09;kali-linux 克隆kali 等待安装 克隆成功 然后开始启…...

CEH与OSCP:网络安全认证对比分析

在网络安全领域&#xff0c;渗透测试被视为至关重要的一环&#xff0c;帮助企业检测和修复系统漏洞。为提升行业标准&#xff0c;许多认证应运而生&#xff0c;其中CEH和OSCP作为行业认可度较高的认证&#xff0c;广泛被网络安全从业者选择。尽管这两者都涉及渗透测试领域&…...

如何通过强化学习RL激励大型语言模型(LLMs)的搜索能力?R1-Searcher来了

R1-Searcher,这是一种使用 RL 增强 LLM 的 RAG 能力的新框架,通过两阶段强化学习(RL)实现LLM在推理过程中自主调用外部检索系统,突破模型固有知识限制。 为了通过探索外部检索环境来激励大语言模型的搜索能力,设计了一种基于结果的两阶段强化学习方法,通过定制的奖励设计…...

AI重构电商内容体系:企业如何突破生产、管理、分发三重门?

在电商内容需求激增的2025年&#xff0c;AI技术已成为破解内容生产低效、管理混乱、分发粗放的核心工具。特赞科技服务案例显示&#xff0c;企业通过AIGC数字资产管理方案可实现效率300%提升。 内容科技驱动电商新范式 电商内容已从"商品说明书"演变为体验经济载体…...

版本控制器Git(1)

文章目录 前言一、初识Git问题引入解决方案注意事项 二、Git安装三、Git配置与基本操作Git创建Git配置用户名称和地址认识工作区、暂存区、版本库添加文件到仓库添加文件到暂存区提交暂存区内容到本地仓库 查看提交历史 四、Git 暂存区、HEAD、对象库及文件Git内部结构概览查看…...

VMware安装Windows server 2016

1、新建虚拟机&#xff0c;选择自定义模式 2、选择兼容性 4、命名虚拟机 5、固件类型 EFI 虚拟磁盘类型&#xff0c;不同电脑推荐的类型不同&#xff0c;用默认的就行 删除声卡和打印机 检查网络配置 选择本地的Windows server 2016的系统镜像&#xff0c;系统镜像可以去Window…...

【编程向导】-JavaScript-基础语法-类型检测

类型检测 类型检测的方法&#xff1a; typeofinstanceofObject.prototype.toStringconstructor typeof typeof 操作符返回一个字符串&#xff0c;表示未经计算的操作数的类型。 typeof undefined; // "undefined" typeof null; // "object" typeof 10…...

Python并发编程实战:突破GIL限制的工程化解决方案

一、GIL的本质与影响范围 **全局解释器锁(Global Interpreter Lock,GIL)**是CPython解释器的核心机制,其本质是一个互斥锁,保证同一时刻只有一个线程执行Python字节码。这一设计使得: ✅ 简化内存管理:避免多线程竞争对象引用计数 ❌ 限制多核性能:CPU密集型多线程程序…...

FPGA学习篇——Verilog学习之全加器的实现

跟着野火的视频学习了一下全加器的实现~ 1 半加器和全加器原理 首先&#xff0c;解释一下为什么全加器的 公式还可以写成以下形式&#xff1a; &#xff08;1&#xff09;首先我们要明白&#xff1a; 因为由真值表来看&#xff0c;他们是不相同的&#xff08;当ab1时&#xff…...

嵌入式学习L6网络编程D4多进程并发

多线程 客户端 /*./client serv_ip serv_port */ #include "net.h"void usage (char *s) {printf ("\n%s serv_ip serv_port", s);printf ("\n\t serv_ip: server ip address");printf ("\n\t serv_port: server port(>5000)\n\n"…...

四层协议攻防手册:从SYN Flood到UDP反射的深度防御

一、四层协议攻击类型与特征 攻击类型协议层特征SYN FloodTCP大量半开连接&#xff0c;SYN_RECV状态堆积UDP反射放大UDP小请求包触发大响应&#xff08;如NTP、DNS响应&#xff09;TCP分片攻击TCP发送异常分片耗尽重组资源连接耗尽攻击TCP建立大量空闲连接占用端口资源 二、TC…...

hive开窗函数

进入hive [root@hadoop01 conf]# hive ... hive (default)> show databases; OK database_name default Time taken: 0.528 seconds, Fetched: 1 row(s)创建数据库 hive (default)> create database test; hive (default)> use test;创建表 字段名字段字段类型学号S…...

【技术白皮书】内功心法 | 第二部分 | Telnet远程登录的工作原理

远程登录的工作原理 背景介绍远程登录远程登录的服务模式远程登录服务的实现基础远程登录服务的运行模式Telnet服务为什么不被操作系统管理 Telnet协议的原理网络虚终端&#xff08;NVT&#xff09;结束标示NVT的原理NVT屏蔽差异 背景介绍 绝大多数计算机都是运行多用户操作系…...

AnyPlace助力Franka突破物体形状与配置多样性挑战

物体几何形状与放置配置多样性的挑战 在机器人操作领域&#xff0c;物体放置一直是一个复杂且富有挑战性的任务。由于物体的几何形状和放置配置的多样性&#xff0c;实现稳健且可推广的物体放置变得尤为困难。 传统的机器人放置方法往往依赖于大量的特定任务演示&#xff0c;…...

【工控】线扫相机小结 第五篇

背景介绍 线扫相机通过光栅尺的脉冲触发&#xff0c; 我在调试线扫过程中&#xff0c;发现图像被拉伸&#xff0c;预设调节分配器。图像正常后&#xff0c;我提高的相机的扫描速度&#xff08;Y轴动的更快了&#xff09;。 动的更快的发现&#xff0c;图像变短了&#xff08;以…...

【Prometheus】层层解析prometheus如何监控k8s核心组件

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全…...

泄露测试仪CTS的Sentinel I28使用

前言:本文档主要讨论CTS Sentinel I28的使用方法,设备图片如下: 具体文档可从下面链接下载: https://download.csdn.net/download/qq_34047402/90471262 泄露测试仪CTS的SentinelI28使用资源-CSDN文库 [注意] 调压方式,若选择机械式调压,那么测试的压力值只能有1个,…...

Python字典,集合

一.字典 在 Python 中&#xff0c;字典&#xff08;dict&#xff09;是一种非常重要且常用的数据结构&#xff0c;它用于存储键值对. 如下为字典的创建,打印键,打印值,和清空的操作 二.集合 在 Python 中&#xff0c;集合&#xff08;set&#xff09;是一种无序且唯一的数据…...

【数据分析大屏】基于Django+Vue汽车销售数据分析可视化大屏(完整系统源码+数据库+开发笔记+详细部署教程+虚拟机分布式启动教程)✅

目录 一、项目背景 二、项目创新点 三、项目功能 四、开发技术介绍 五、项目功能展示 六、权威视频链接 一、项目背景 汽车行业数字化转型加速&#xff0c;销售数据多维分析需求激增。本项目针对传统报表系统交互性弱、实时性差等痛点&#xff0c;基于DjangoVue架构构建…...

Ubuntu用户安装cpolar内网穿透

前言 Cpolar作为一款体积小巧却功能强大的内网穿透软件&#xff0c;不仅能够在多种环境和应用场景中发挥巨大作用&#xff0c;还能适应多种操作系统&#xff0c;应用最为广泛的Windows、Mac OS系统自不必多说&#xff0c;稍显小众的Linux、树莓派、群辉等也在起支持之列&#…...

关于sqlalchemy的ORM的使用

关于sqlalchemy的ORM的使用 二、创建表三、使用数据表、查询记录 二、创建表 使用Mapped来映射字段 from sqlalchemy.ext.declarative import declarative_base from sqlalchemy.orm import sessionmaker,Mapped,mapped_columnBase declarative_base() engine create_engin…...

C 语言分支与循环:构建程序逻辑的基石

在 C 语言的世界里&#xff0c;分支和循环结构是编程的核心内容&#xff0c;它们赋予了程序根据不同条件执行不同操作以及重复执行特定代码段的能力&#xff0c;让程序变得更加智能和高效。今天&#xff0c;我们就深入探讨 C 语言分支和循环的相关知识&#xff0c;助力大家夯实…...

J-LangChain - Agent - 编排一个 ReAct + Function Call 反应链

系列文章索引 J-LangChain 入门 介绍 j‑langchain 是一款基于 Java 的 AIGC 编排框架&#xff0c;致力于集成多种大模型&#xff08;LLM&#xff09;调用及 RAG 工具。自 1.0.8 版本起&#xff0c;我们引入了工具函数&#xff08;Function Call&#xff09;调用能力&#xf…...

Rust 之一 基本环境搭建、各组件工具的文档、源码、配置

概述 Rust 是一种强调性能、类型安全和并发性的通用编程语言。它强制执行内存安全&#xff0c;使用其特有的所有权机制&#xff0c;而无需传统的垃圾收集器。Rust 不强制执行编程范式&#xff0c;但受到函数式编程思想的影响。 最初是由 Mozilla 员工 Graydon Hoare 在 2006 年…...

详细介绍 Jupyter nbconvert 工具及其用法:如何将 Notebook 转换为 Python 脚本

nbconvert 是 Jupyter 提供的一个非常强大的工具&#xff0c;允许用户将 Jupyter Notebook 文件&#xff08;.ipynb&#xff09;转换成多种格式&#xff0c;包括 Python 脚本&#xff08;.py&#xff09;、HTML、PDF、LaTeX 等。你可以通过命令行来运行 nbconvert&#xff0c;也…...

C语言之预处理

预处理 一.头文件的包含1.1头文件的作用1.2包含头文件的方式- 包含标准库头文件- 包含用户自定义头文件 1.3嵌套文件包含 二.条件编译2.1条件编译的作用2.2条件编译的指令 三.预定义符号四.define4.1define定义常量4.2#define定义宏4.2.1定义宏时常见错误 4.3宏替换的规则4.4带…...

AcWing--869.试除法求约数

题目&#xff1a; 给定 n 个正整数 ai&#xff0c;对于每个整数 ai&#xff0c;请你按照从小到大的顺序输出它的所有约数。 输入格式 第一行包含整数 n。 接下来 n 行&#xff0c;每行包含一个整数 ai。 输出格式 输出共 n 行&#xff0c;其中第 i 行输出第 i 个整数 ai 的所有…...