-
mountpoint-s3
A simple, high-throughput file client for mounting an Amazon S3 bucket as a local file system.
> Truncation will not be supported.
The sequential requirement for writes is the part that I've been mulling over whether or not it's actually required in S3. Last year I discovered that S3 can do transactional I/O via multipart upload[2] operations combined with the CopyObject[3] operation. This should, in theory, allow for out of order writes, existing partial object re-use, and file appends.
[1] https://github.com/awslabs/mountpoint-s3/blob/main/doc/SEMAN...
-
InfluxDB
Purpose built for real-time analytics at any scale. InfluxDB Platform is powered by columnar analytics, optimized for cost-efficient storage, and built with open data standards.
-
rclone
"rsync for cloud storage" - Google Drive, S3, Dropbox, Backblaze B2, One Drive, Swift, Hubic, Wasabi, Google Cloud Storage, Azure Blob, Azure Files, Yandex Files
I started out with davfs2 but it was a) very slow at uploading for some reason, b) there was no way to explicitly sync it but to either wait a minute for some internal timer or to unmount it, and c) it implements writes by writing to a cache directory in /var/cache, which is just yet another redundant copy of the data I already have.
I use `rclone`. Currently rclone doesn't support the SHA1 checksums that Fastmail Files implements. I have a PR for that: https://github.com/rclone/rclone/pull/6839
-
There's a similar project under awslabs for using S3 as a FileSystem within the Java JVM: https://github.com/awslabs/aws-java-nio-spi-for-s3
-
JungleDisk was backup software I used ~2008 that allowed mounting S3. They were bought by Rackspace and the product wasn't updated. Seems to be called/part of Cyberfortress now.
Later I used Panic's Transmit Disk but they removed the feature.
Recently I'd been looking at s3fs-fuse to use with gocryptfs but haven't actually installed it yet!
https://github.com/s3fs-fuse/s3fs-fuse
https://github.com/rfjakob/gocryptfs
-
JungleDisk was backup software I used ~2008 that allowed mounting S3. They were bought by Rackspace and the product wasn't updated. Seems to be called/part of Cyberfortress now.
Later I used Panic's Transmit Disk but they removed the feature.
Recently I'd been looking at s3fs-fuse to use with gocryptfs but haven't actually installed it yet!
https://github.com/s3fs-fuse/s3fs-fuse
https://github.com/rfjakob/gocryptfs
-
seekable-s3-stream
Code library that uses S3's API to provide an efficient random-access (seekable) Stream implementation for use in code where efficient network I/O is paramount.
I think you’re spot on: using multipart uploads, different sections of the ultimate object can be created out of order. Unfortunately, though, that’s subject to restrictions that require you to ensure all but the last part are sufficiently sized.
I’m a little disappointed that this library (which is supposed to be “read optimized”) doesn’t take advantage of S3 Range requests to optimize read after seek. The simple example is a zip file in S3 for which you want only the listing of files from the central directory record at the end. As far as I can tell this library reads the entire zip to get that. I have some experience with this[1][2].
[1] https://github.com/mlhpdx/seekable-s3-stream
-
s3-upload-stream
Code library that provides a Stream implementation that makes working with uploads to S3 easier where the size of the content isn't known a priori. It holds only partial content in memory (works with large objects), and is compatible with code libraries that work with output streams.
-
SaaSHub
SaaSHub - Software Alternatives and Reviews. SaaSHub helps you find the best software and product alternatives
-
That depends on what you consider "fast". EFS (the "serverless" NFS) has sub-millisecond operation latency. S3 is more in the 10-20ms range for most operations, with occasional spikes.
BTW, if you need a pure Go client for NFSv4 (including AWS EFS), feel free to check my: https://github.com/Cyberax/go-nfs-client
-
https://github.com/bloomreach/s4cmd
-
WinFsp (FUSE for Windows) has an NFS driver: https://github.com/winfsp/nfs-win
-
-
PosixSyncFS
PosixSyncFS is a set of Bash scripts that allow users to create a real POSIX filesystem and sync it to a remote storage bucket for backup and recovery purposes.
Upon reading this idea I created https://github.com/lrvl/PosixSyncFS - feel free to comment
Related posts
-
Gocryptfs – An encrypted overlay filesystem written in Go
-
Gcsfuse: A user-space file system for interacting with Google Cloud Storage
-
Does btrfs send/receive provide any benefit for moving new, non-incremental data?
-
Is veracrypt still the best option
-
Enigma: A simple cross-platform encrypted filesystem in Golang