1
flyingdog 2022-12-10 07:13:53 +08:00
> 移动 API
什么是移动 API 啊? |
2
wangyu17455 2022-12-10 07:23:18 +08:00
@flyingdog 移动文件
|
3
needpp 2022-12-10 07:41:06 +08:00
盲猜应该是在 移动端比如 ios android 等系统中使用的 api 吧, 但是 s3 不就是一个基于 http 的应用层协议吗? 随便找个合适的语言封装一下就可以了?
|
4
crysislinux 2022-12-10 08:59:54 +08:00 via Android
大概是 s3 本来就没有移动这个概念,看起来你可以保存路径,但那实际上并不是目录,本质上跟 kv 数据路类似。
|
5
8520ccc 2022-12-10 09:13:08 +08:00 via iPhone
有 copyObject 再 delete 就行
|
6
wanguorui123 2022-12-10 11:06:11 +08:00
涉及到锁吧
|
7
gfwuzer 2022-12-10 13:34:17 +08:00
s3 是分布式的,移动很难做成原子操作。类比移动文件跨硬盘也只能 copy 。
|
8
flyingdog 2022-12-12 03:36:15 +08:00
@wanguorui123 不涉及到锁。S3 整个系统是无锁的。
|
9
flyingdog 2022-12-12 03:39:06 +08:00
上面有人的解释是对的。S3 的目录看起来是目录,一个 object ,底层存储是分布在很多的 host 上面的,所以没有移动的概念。比如说,分布式的 MySQL 里面也没有移动的概念对吧?你只能复制再删除,但是不是原子性的,需要自己加锁之类的。
|
10
wanguorui123 2022-12-12 09:26:38 +08:00
@flyingdog 没有锁不好做移动操作
|
11
flyingdog 2022-12-12 09:55:20 +08:00
@wanguorui123 对,如果 LZ 想自己实现这种 copy+delete 的操作,是需要锁的。
但我上面的意思是,S3 内部实现是无锁的。用了一些 Quorum 之类的东西。 |
12
Pythondr 2022-12-12 12:14:30 +08:00
无它,S3 不是一个文件系统。
|
13
opengps 2022-12-14 15:28:40 +08:00
文件存储是平行结构,不存在文件夹,所以没有你要的“移动文件”,你需要"下载+删除+上传"来近似代替移动文件的概念
|