AWS SDK Rust 多部分上传失败问题分析与解决方案
2025-06-26 16:53:14作者:幸俭卉
问题背景
AWS SDK Rust 用户在升级到较新版本后遇到了多部分上传功能失效的问题。具体表现为上传过程中出现"current throughput: 0 B/s is below minimum: 1 B/s"的错误提示,导致上传操作失败。
问题现象
用户在使用aws-config 1.4.0、aws-sdk-s3 1.28.0和aws-smithy-types 1.1.9版本组合时,多部分上传功能开始出现以下错误日志:
[DEBUG] current throughput: 0 B/s is below minimum: 1 B/s
[DEBUG] grace period ended; timing out request
[DEBUG] not retrying because we are out of attempts
技术分析
这个问题源于AWS SDK Rust引入的"停滞流保护"(Stalled Stream Protection)机制。该机制旨在检测并防止上传或下载过程中出现停滞情况,默认情况下会监控传输速率,如果低于设定的最小值(默认为1B/s),则会中断连接。
对于大文件上传场景,特别是网络条件不佳的环境,这种保护机制可能会误判正常的上传过程为停滞状态。在底层实现上,这是通过aws_smithy_runtime::client::http::body::minimum_throughput模块来监控和执行的。
解决方案
AWS SDK Rust团队提供了几种解决方案:
- 完全禁用停滞流保护:
let config = aws_config::defaults(aws_config::BehaviorVersion::latest())
.stalled_stream_protection(StalledStreamProtectionConfig::disabled())
.load()
.await;
- 仅禁用上传部分的保护(推荐方案):
let config = aws_config::defaults(aws_config::BehaviorVersion::latest())
.stalled_stream_protection(
StalledStreamProtectionConfig::enabled()
.upload_enabled(false)
.build(),
)
.load()
.await;
- 调整最低吞吐量阈值(如果未来版本支持): 开发者可以设置更高的最低吞吐量阈值以适应特定网络环境。
最佳实践建议
- 对于大文件上传场景,建议采用方案2,仅禁用上传部分的保护,保留下载保护
- 在网络条件不稳定的环境中,考虑实现自定义的重试逻辑
- 监控上传进度,提供用户反馈,避免长时间无响应
- 考虑分块大小调整,找到适合当前网络环境的最佳分块大小
技术原理深入
停滞流保护机制的核心是防止资源被长时间占用而没有任何进展。它通过定期检查数据传输速率来实现:
- 设置一个监控周期(如1秒)
- 计算该周期内的数据传输量
- 如果低于阈值,开始计时
- 超过宽限期后仍低于阈值,则终止连接
对于多部分上传,每个部分的上传都是独立的HTTP请求,因此每个部分都会受到此机制的影响。在网络波动或高延迟环境下,即使实际上传在进行中,短期的速率下降也可能触发保护机制。
后续发展
AWS SDK Rust团队已意识到这一问题,并在后续版本中进行了优化。开发者应关注官方更新日志,及时获取最新的稳定性改进和功能增强。
对于特殊场景下的上传需求,建议开发者根据实际网络条件调整SDK配置,或考虑实现自定义上传策略以获得更好的控制权和适应性。
登录后查看全文
热门项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
LongCat-AudioDiT-1BLongCat-AudioDiT 是一款基于扩散模型的文本转语音(TTS)模型,代表了当前该领域的最高水平(SOTA),它直接在波形潜空间中进行操作。00- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
HY-Embodied-0.5这是一套专为现实世界具身智能打造的基础模型。该系列模型采用创新的混合Transformer(Mixture-of-Transformers, MoT) 架构,通过潜在令牌实现模态特异性计算,显著提升了细粒度感知能力。Jinja00
FreeSql功能强大的对象关系映射(O/RM)组件,支持 .NET Core 2.1+、.NET Framework 4.0+、Xamarin 以及 AOT。C#00
热门内容推荐
最新内容推荐
Onekey Steam清单智能管理工具:让游戏文件效率倍增的技术方案MusicFreeDesktop:插件化架构重塑无广告音乐体验的跨平台解决方案B站增强脚本:三步打造专属你的个性化B站体验OWL框架在企业级界面开发中的实践指南高效轻量API测试工具:Postman便携版的绿色化解决方案Perseus:重新定义游戏体验的技术解决方案Il2CppAssemblyUnhollower 新手入门指南:从功能解析到配置实践游戏存档管理全攻略:探索Checkpoint的跨平台解决方案7步掌握开源RAW处理:用darktable打造专业级照片 workflow开源macOS电源管理工具深度解析:提升续航效率的系统优化方案
项目优选
收起
deepin linux kernel
C
27
14
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
659
4.26 K
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.54 K
894
Ascend Extension for PyTorch
Python
503
609
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
391
286
暂无简介
Dart
905
218
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
69
21
昇腾LLM分布式训练框架
Python
142
168
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
939
862
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
1.33 K
108