Imagine using rocksdb backed by S3. You store only sstables in S3. You append the WAL in EBS and archive it in S3. You cache blocks in local SSD. If you want faster WAL, you append the WAL in local-ssd and use multi-az replication in your db and fsync WAL to EBS less frequently than locally.
> What about transactionality, partial updates, running multi document queries, consistency of the whole set of documents.
You do that in another layer on top. The filesystem doesn't provide transactions, yet you do them on a layer on top.
> In terms of scalability there are, limits 3500rps per key prefix.
The S3 metadata is (was?) sharded on key-prefix. You fix this by using more prefixes. By hashing the filenames or something.
> The latency from s3 on a get is orders of magnitude poorer that EBS or LSSD and should be used "infrequently".
Yes, it is. You should use a local SSD for most things.