5.11消息有异常如何处理

这里主要还是之前看到的Sender.java中的completeBatch方法

 private void completeBatch(RecordBatch batch, Errors error, long baseOffset, long timestamp, long correlationId, long now) {
        //说明响应里面带有异常 并且这个请求是可以重试的
        if (error != Errors.NONE && canRetry(batch, error)) {
            // retry
            log.warn("Got error produce response with correlation id {} on topic-partition {}, retrying ({} attempts left). Error: {}",
                     correlationId,
                     batch.topicPartition,
                     this.retries - batch.attempts - 1,
                     error);
            //重新把发送失败的批次重新加入到队列里面。
            this.accumulator.reenqueue(batch, now);
            this.sensors.recordRetries(batch.topicPartition.topic(), batch.recordCount);
        } else {
            //其余的情况会走这里,这里可能是原本就不可以重试,还可能是重试次数超了
            RuntimeException exception;
            //如果响应里面带有没有权限的异常
            if (error == Errors.TOPIC_AUTHORIZATION_FAILED)
                //自己封装一个异常信息(自定义异常)
                exception = new TopicAuthorizationException(batch.topicPartition.topic());
            else
                exception = error.exception();
            // tell the user the result of their request
            //TODO 核心代码 把异常信息也带过去了
            //回调函数调用完之后
            //说明一个完整的消息发送流程就结束了
            batch.done(baseOffset, timestamp, exception);
            this.accumulator.deallocate(batch);
            if (error != Errors.NONE)
                this.sensors.recordErrors(batch.topicPartition.topic(), batch.recordCount);
        }

我们可以简单的看一下reenqueue做了什么处理

  */
    public void reenqueue(RecordBatch batch, long now) {
        //重试次数累加
        batch.attempts++;
        //上一次重试的时间
        batch.lastAttemptMs = now;
        batch.lastAppendTime = now;
        batch.setRetry();
        Deque<RecordBatch> deque = getOrCreateDeque(batch.topicPartition);
        synchronized (deque) {
            //重新放入到队列里面
            //放入到队头
            deque.addFirst(batch);
        }
    }

最后如果真的是有一些消息带有异常导致无法正常发送,我们也不能放任不管,这样就丢数据了,通常的做法就是在生产者代码的回调函数中捕获到这样的消息,将它存储到备用链路里面,防止丢数据

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Dev C++是一款免费的集成开发环境(IDE),主要用于C和C++语言的编程。它提供了一个直观且易于使用的界面,适合新手学习和开发C和C++程序。 Dev C++ 5.11是其中的一个版本,在新版本中,开发者提供了一些更新和改进。其中一项改进是对编译器的更新,包括GCC编译器的最新版本。这使得Dev C++能够支持更多的C和C++语言特性,以及更好的代码生成和性能优化。 此外,Dev C++ 5.11还提供了更好的用户体验和工具,例如更快的编译速度、更强大的代码自动完成功能,以及改进的调试器和错误提示。这些功能的改进使得开发者能够更高效地开发和调试项目。 总的来说,Dev C++ 5.11是一个经过改进的集成开发环境,它的目标是提供一个友好和功能强大的平台供C和C++编程。无论是初学者还是有经验的开发者,都可以使用Dev C++来进行代码编写、调试和运行。 ### 回答2: "Dev C++ 5.11" 是一个免费的集成开发环境(IDE),适用于C和C++编程语言。它是用于Windows操作系统的一个开发工具,为开发人员提供了编写、调试和执行C和C++代码的平台。 Dev C++ 5.11有许多功能和优点。首先它具有简单易用的界面,适合初学者和有经验的开发者。它提供了代码自动完成和语法高亮等功能,使代码编写更加快捷和方便。 除此之外,Dev C++ 5.11还具有强大的调试功能,可以帮助开发人员定位和修复程序中的错误。它支持断点、监视变量和单步执行,可以逐行查看代码的执行过程,帮助开发者进行程序调试和故障排除。 Dev C++ 5.11还具有多种编译器选项,开发者可以选择不同的编译器来编译和运行代码。这使得开发者可以根据需要选择最适合自己项目的编译器,从而提高代码的性能和效率。 总结而言,Dev C++ 5.11是一个功能强大且易于使用的集成开发环境,适用于C和C++编程语言。它提供了丰富的功能和选项,帮助开发人员编写、调试和执行代码。无论是初学者还是有经验的开发者,都可以通过Dev C++ 5.11来开发高质量的C和C++程序。 ### 回答3: Dev-C++是一款集成开发环境(IDE),用于在Windows平台上进行C和C++编程。版本号5.11通常表示软件的更新版本,它可能包含了一些修复bug和改进性能的更新。Dev-C++5.11版本相对较新,可能提供了更好的用户体验和更高的稳定性。 与先前版本相比,Dev-C++ 5.11可能会引入一些新功能和特性。这些新功能可能包括更强大的代码编辑器,更丰富的代码自动补全功能,更好的错误检查和调试工具等。在开发过程中,这些新功能可以提高代码的编写效率和质量,并且可以更轻松地定位和解决错误。 此外,Dev-C++5.11版本可能还修复了一些在之前版本中已知的bug或问题。这些修复可以增强软件的稳定性和可靠性,减少在开发过程中出现意外错误的可能性。 总之,Dev-C++5.11是一款用于C和C++编程的IDE,版本号可能代表了软件的更新和改进。使用这个更新版本可以提供更好的用户体验、更高的稳定性,以及一些新的功能和改进。对于正在使用Dev-C++的开发人员来说,升级到5.11版本可能会带来更好的编程体验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值