Exchange邮件审批报错 --- {“The request failed. 基础连接已经关闭: 发送时发生错误。“} 的解决方案

本文记录了一次由于Exchange禁用TLS1.0并要求使用TLS1.2导致的邮件审批功能故障。问题表现为请求失败,基础连接关闭。解决方案包括在代码中添加TLS1.2配置及升级项目.NET Framework版本到4.6.2以上。经过修改和验证,邮件审批功能在生产和本地环境恢复正常。

问题描述:

在6月7日的时候,我负责系统中的邮件审批任务突然无法执行,并且提示{"The request failed. 基础连接已经关闭: 发送时发生错误。"}的错误信息。导致邮件审批功能无法正常使用。并且在本地调试时,也会出现同样的提示描述。

检查过程:

1、Exchange的EWS在6月份的时候,禁用了TLS1.0的默认安全协议。原代码中使用的是TLS1.0的默认协议,需进行协议更新

2、TLS1.2的安全协议仅支持Net Framework4.6.2及以上版本,当时项目的设置Netframework版本为4.0

解决方案:

1、在原代码中添加TLS1.2安全协议的配置

ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls12;

2、更新项目的Netframework版本为4.6.2及以上。

验证:

在本地调试时,可以正常获取邮件并且邮件审批功能可正常执行。修复完成之后更新生产环境中的邮件审批服务,经验证,发布之后,生产环境邮件审批功能恢复正常。

以此做一个记录。

<think>首先,用户的问题是中文的:"分析报错原因"。用户提供了一段日志,内容是: ``` 2025-08-08 15:57:43.199 INFO 56956 --- [ main] o.s.a.r.c.CachingConnectionFactory : Created new connection: rabbitConnectionFactory#56637cff:0/SimpleConnection@991cbde [delegate=amqp://guest@127.0.0.1:5672/, localPort= 7194] 2025-08-08 15:57:43.224 ERROR 56956 --- [ 127.0.0.1:5672] o.s.a.r.c.CachingConnectionFactory : Channel shutdown: channel error; protocol method: #method<channel.close>(reply-code=406, reply-text=PRECONDITION_FAILED - unknown exchange type 'x-delayed-message', class-id=40, method-id=10) 2025-08-08 15:57:44.238 ERROR 56956 --- [ 127.0.0.1:5672] o.s.a.r.c.CachingConnectionFactory : Channel shutdown: channel error; protocol method: #method<channel.close>(reply-code=406, reply-text=PRECONDITION_FAILED - unknown exchange type 'x-delayed-message', class-id=40, method-id=10) ``` 用户要求分析报错原因。报错的核心是:"PRECONDITION_FAILED - unknown exchange type 'x-delayed-message'"。 关键点: - 错误代码:406 (PRECONDITION_FAILED) - 错误信息:unknown exchange type 'x-delayed-message' - 类和方法:class-id=40, method-id=10(这通常对应AMQP协议中的方法,但在这里,重点是错误信息) 分析原因: 1. **未知的交换器类型**:RabbitMQ支持多种交换器类型,如 direct、topic、fanout、headers 等。'x-delayed-message' 是一个自定义的交换器类型,用于实现延迟消息功能。这不是RabbitMQ核心功能的一部分;它是通过插件提供的。 2. **插件未安装**:错误表明RabbitMQ服务器不认识 'x-delayed-message' 类型。这意味着RabbitMQ实例上没有安装 "rabbitmq_delayed_message_exchange" 插件。 3. **RabbitMQ版本或配置**:如果插件已安装但未启用,或者RabbitMQ版本不兼容,也可能导致此错误。但最常见的原因是插件未安装。 4. **应用配置**:应用(基于Spring AMQP)试图声明一个类型为 'x-delayed-message' 的交换器,但服务器不支持它,因此连接失败。 总结报错原因: - 主要原因是RabbitMQ服务器缺少 "rabbitmq_delayed_message_exchange" 插件,导致无法识别 'x-delayed-message' 交换器类型。 回答需要用中文,因为用户指定了"请使用中文回答问题"。 接下来,回答完问题后,必须提出3-5个相关问题。输出必须以"§§相关问题§§"开头,然后列出问题,禁止换行分散。 相关问题应该基于用户的问题和我的回答: - 用户问题:分析报错原因 - 我的回答:关于RabbitMQ插件缺失导致的问题 所以,相关问题可以包括: 1. 如何安装RabbitMQ的延迟消息插件? 2. 如何检查RabbitMQ插件是否已安装? 3. 除了插件问题,还有哪些原因可能导致类似的错误? 4. 如何配置Spring应用来使用延迟交换器? 5. 如果RabbitMQ不支持延迟消息,有哪些替代方案? 确保有3-5个问题。 最后,输出格式: - 先回答问题。 - 然后直接输出"§§相关问题§§"。 - 接着列出问题,用数字点(如1. ... 2. ...)或类似格式,但根据示例,是使用数字点。 示例格式是: ``` 快速排序的基本思想是... ```python 代码... ``` §§相关问题§§ 1. ··· 2. ··· 3. ··· ``` 在我的回答中,没有代码块,所以直接写文本。 完整结构: - 分析报错原因(中文)。 - 然后"§§相关问题§§"。 - 然后相关问题列表。</think>### 报错原因分析 该错误日志表明,在使用Spring AMQP(如RabbitMQ客户端),尝试创建或使用一个名为`x-delayed-message`的交换器类型失败。核心错误信息是`PRECONDITION_FAILED - unknown exchange type 'x-delayed-message'`(预处理失败 - 未知的交换器类型 'x-delayed-message')。具体原因如下: 1. **RabbitMQ插件缺失**:`x-delayed-message`是RabbitMQ的**延迟消息插件**(rabbitmq_delayed_message_exchange)提供的自定义交换器类型,用于实现消息延迟投递功能。如果RabbitMQ服务器未安装或未启用此插件,服务器将无法识别该交换器类型,从而抛出此错误。 2. **插件未启用或版本不兼容**:即使插件已安装,如果未通过`rabbitmq-plugins enable`命令启用,或RabbitMQ版本过低(如低于3.5.8),插件可能无法正常工作。 3. **应用配置问题**:客户端(如Spring Boot应用)在代码或配置中声明了`x-delayed-message`类型的交换器,但连接的RabbitMQ实例不支持此类型。错误日志中的`reply-code=406`表示AMQP协议层面的预处理失败,`class-id=40`对应交换器声明方法(Exchange.Declare),进一步确认是交换器类型无效。 4. **连接重试失败**:日志显示两次相同的错误间戳15:57:43和15:57:44),表明客户端在连接后立即尝试创建交换器但失败,且未正确处理该异常,导致重复尝试。 **解决方案建议**: - 在RabbitMQ服务器上安装并启用延迟消息插件:执行命令`rabbitmq-plugins enable rabbitmq_delayed_message_exchange`。 - 验证插件状态:通过`rabbitmq-plugins list`检查插件是否已激活。 - 确保RabbitMQ版本兼容:延迟消息插件要求RabbitMQ 3.5.8及以上版本。 - 在客户端代码中,添加对插件支持的检查逻辑,避免在不支持的服务器上声明该交换器。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值