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 文件存储是平行结构,不存在文件夹,所以没有你要的“移动文件”,你需要"下载+删除+上传"来近似代替移动文件的概念 |