一次 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 权限应覆盖"可能发生的完整行为集合",而不是理想路径

相关推荐
万象.7 小时前
redis数据结构list的基本指令
数据结构·redis·list
難釋懷8 小时前
Redis桌面客户端
数据库·redis·缓存
填满你的记忆8 小时前
【从零开始——Redis 进化日志|Day5】分布式锁演进史:从 SETNX 到 Redisson 的完美蜕变
java·数据库·redis·分布式·缓存
hanqunfeng8 小时前
(四十)SpringBoot 集成 Redis
spring boot·redis·后端
難釋懷8 小时前
Jedis快速入门
redis·缓存
小北方城市网8 小时前
SpringBoot 集成 MinIO 实战(对象存储):实现高效文件管理
java·spring boot·redis·分布式·后端·python·缓存
iVictor9 小时前
Redis 调优:必须关注的几个参数
redis
難釋懷10 小时前
Jedis连接池
redis·缓存
存在的五月雨12 小时前
Redis的一些使用
java·数据库·redis
鲨莎分不晴20 小时前
Redis 基本指令与命令详解
数据库·redis·缓存