一次 STS 缓存优化引发的 Android 视频上传“分片权限”问题复盘

原文件上传接口逻辑为获取临时key返回客户端客户端做上传操作,但生产服务器因为RTT的问题导致上传文件接口实时获取 STS变得很慢,这就导致用户在使用文件上传相关接口时非常难受,于是决定写定时任务获取STS存入Redis中,过期之前重新刷新,兜底实时获取STS同时刷新Redis缓存。编写,自测,push一气呵成,接口耗时自降到2-3ms,非常舒服!

提测后收到反馈,iOS各项正常,但Android中有一部分机型不能上传视频类文件,但有些机型又可以

非常的诡异,这说明因为iOS和Android的某些差异导致了文件上传的不确定

可以确定图片,日志,压缩包都能上传成功,只有视频有问题,那会不会和视频大小有关?

经过同一个视频上传的测试发现不是这个问题且Android上传一直403。

那么换一个方向,会不会是Android SDK 文件上传策略是否与iOS不一致?

我着重查看了过期时间剩余对Android SDK文件上传策略的影响,发现当 STS 已被使用一段时间(缓存 STS 场景)时,Android SDK 更倾向选择 分片上传(Multipart Upload),以提高成功率。

woc!!!

我没开分片上传权限添加

复制代码
allowActions:
  - name/cos:PutObject
  - name/cos:PostObject

开启下面权限

复制代码
allowActions:
  - name/cos:PutObject
  - name/cos:PostObject
  - name/cos:InitiateMultipartUpload
  - name/cos:UploadPart
  - name/cos:CompleteMultipartUpload
  - name/cos:AbortMultipartUpload

push,测试,完美通过!

这里做一个总结

缓存型 STS 会暴露客户端真实上传行为

Android + 大文件 = 必须默认支持 Multipart Upload

实时 STS 可能"掩盖权限设计缺陷"

STS 权限应覆盖"可能发生的完整行为集合",而不是理想路径

相关推荐
我爱学习好爱好爱2 小时前
Prometheus监控栈 监控Springboot2+Vue3+redis项目
数据库·redis·prometheus
czlczl200209252 小时前
SpringBoot自定义Redis
spring boot·redis·后端
Go高并发架构_王工2 小时前
Redis命令执行原理与源码分析:深入理解内部机制
数据库·redis·后端
panzer_maus3 小时前
Redis的简单介绍(1)
数据库·redis·缓存
填满你的记忆4 小时前
【从零开始——Redis 进化日志|Day1】初见 Redis,开启内存加速之旅
数据库·redis·缓存
小Mie不吃饭4 小时前
Spring boot + mybatis-plus + Redis 实现数据多级缓存(模拟生产环境)
java·spring boot·redis·mysql·缓存
K哥11254 小时前
【Redis】缓存策略
数据库·redis·缓存
星辰_mya17 小时前
redis集群
数据库·redis·缓存
我爱学习好爱好爱1 天前
Docker Compose部署SpringBoot2+Vue3+redis项目(Rockylinux9.6)
redis·docker·容器