news 2026/4/28 3:57:57

这段代码msg消息过大的时候导致生产者没有收到消息的报错会提示出来吗

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
这段代码msg消息过大的时候导致生产者没有收到消息的报错会提示出来吗

不会“自动”把 **消息过大** 的报错打出来,
**除非你主动去拿发送结果**,否则 `template.send(...)` 只是 **异步把消息放进客户端缓冲区**,
当消息 **> max.request.size / message.max.bytes** 时,生产者会收到 `RecordTooLargeException`,
但这段代码 **没有任何回调或 `.get()`**,异常就 **安静地躺在客户端内部** 不会被打印,
于是看起来就像“消息丢了”。

---

### 1. 当前代码的隐患
```java
template.send(userTopic, model.getPlstx(), msg); // 异步发
log.info("sync user:{}", msg); // 立即打印
return true; // 永远返回 true
```
- 发送失败(太大、网络抖动、队列满)→ **回调没人管**,异常没人看。
- 日志里只能看到 **“sync user:……”**,看不到任何错误,**运维会以为“已发出”**。

---

### 2. 如何立刻把“过大”错误暴露出来

#### ① 最简单:同步等结果(阻塞 5 秒)
```java
try {
SendResult<String, String> result = template
.send(userTopic, model.getPlstx(), msg)
.get(5, TimeUnit.SECONDS); // 立即把异步变同步
log.info("sync user ok, offset={}", result.getRecordMetadata().offset());
return true;
} catch (InterruptedException | ExecutionException | TimeoutException e) {
log.error("sync user failed, msg size={}", msg.getBytes(StandardCharsets.UTF_8).length, e);
return false;
}
```
- 消息 **> 1 MB** 时会直接抛 `ExecutionException: RecordTooLargeException`,日志就能看见。
- 不影响主流程,只是多等 5 秒;重试策略仍由 Kafka 客户端自己完成。

#### ② 非阻塞回调(不卡点)
```java
template.send(userTopic, model.getPlstx(), msg)
.addCallback(
r -> log.info("sync user ok, offset={}", r.getRecordMetadata().offset()),
e -> log.error("sync user failed, msg size={}",
msg.getBytes(StandardCharsets.UTF_8).length, e)
);
return true; // 先返回,错误在回调里打
```
> 既不会阻塞业务线程,也能把 **RecordTooLargeException** 打出来。

---

### 3. 一键验证
1. 把 `msg` 手动拼到 **1.5 MB**(复制几万字符即可)。
2. 用 **① 同步** 方式调用,日志立即出现:
```
sync user failed, msg size=1572864
org.apache.kafka.common.errors.RecordTooLargeException: The message is 1572864 bytes when serialized which is larger than the maximum request size you have configured with the max.request.size configuration.
```
3. 调大生产者配置后重试即可成功:
```yaml
spring:
kafka:
producer:
max-request-size: 10485760 # 10 MB
compression-type: snappy
```

---

### 4. 结论
> **当前代码不会主动把“消息过大”报错打出来,因为没调用 `.get()` 也没加回调;**
> **加上 `.get(5, TimeUnit.SECONDS)` 或 `addCallback` 后,一旦超过 `max.request.size` 就会立即在日志里看到 `RecordTooLargeException`,从而真正发现“为什么消息没到”。**

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/28 0:27:07

UI自动化测试、接口测试等自动化测试详解

今天跟大家介绍UI测试、接口测试、单元测试主要内容&#xff0c;以及每种测试花费时间讨论。一.UI测试【Selenium】UI测试是最接近软件真实用户使用行为的测试类型。通常是模拟真实用户使用软件的行为&#xff0c;即模拟用户在软件界面上的各种操作&#xff0c;并验证这些操作对…

作者头像 李华
网站建设 2026/4/25 2:10:55

巴菲特的企业价值与投资回报

巴菲特的企业价值与投资回报 关键词:巴菲特、企业价值、投资回报、价值投资、财务分析、内在价值评估、长期投资 摘要:本文深入探讨了巴菲特所倡导的企业价值与投资回报理念。首先介绍了该研究的背景,包括目的、预期读者、文档结构和相关术语。接着阐述了企业价值与投资回报…

作者头像 李华
网站建设 2026/4/25 13:16:28

如何使用Jenkins来定时执行JMeter脚本,并查看测试报告

Jenkins是一个开源的持续集成工具&#xff0c;可以帮助开发人员自动构建、测试和部署软件项目。JMeter是一个流行的性能测试工具&#xff0c;它可以模拟多种负载情况来测试应用程序的性能和稳定性。本文将介绍如何使用Jenkins来定时执行JMeter脚本&#xff0c;并查看测试报告。…

作者头像 李华
网站建设 2026/4/27 17:00:48

Linux下PyTorch安装全攻略:结合Miniconda与CUDA加速

Linux下PyTorch安装全攻略&#xff1a;结合Miniconda与CUDA加速 在深度学习项目开发中&#xff0c;最让人头疼的往往不是模型设计本身&#xff0c;而是环境搭建——尤其是当你面对一台全新的Linux服务器时。明明按照官方文档一步步操作&#xff0c;却总是卡在 torch.cuda.is_av…

作者头像 李华
网站建设 2026/4/25 3:11:20

10 万块 GPU 的竞赛,终于有了反击利器?算力破局关键一役

当顶尖科技阵营用 10 万块英伟达 Blackwell GPU 打造 2200 exaflops 超算集群时&#xff0c;全球科研机构还在为进口芯片卡脖子发愁 ——2025 年的全球算力竞赛&#xff0c;正站在生死攸关的转折点。就在全行业陷入 "无卡可用" 的焦虑时&#xff0c;12 月 20 日摩尔线…

作者头像 李华
网站建设 2026/4/25 4:21:39

HTML嵌入Python图表:Miniconda环境中使用Bokeh和Dash实战

HTML嵌入Python图表&#xff1a;Miniconda环境中使用Bokeh和Dash实战 在数据驱动决策的时代&#xff0c;静态图表早已无法满足人们对洞察深度的需求。想象这样一个场景&#xff1a;科研人员提交的论文附带一个可交互的动态图谱&#xff0c;读者能自由缩放、悬停查看原始数据点&…

作者头像 李华