Skip to content

jsen-/fuse-http

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

10 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

fuse-http

Read-only mount URL pointing to a file into local directory using FUSE
The remote server must support ranged requests (respond with Accept-Ranges: bytes header to HEAD request to the provided URL) and respond with 206 Partial Content when Range: bytes=<start>-<end> request header is present with GET request.

installation

cargo build --release

For maximum portability you can use build-musl.sh. This will build the project with MUSL which requires no runtime libraries whatsoever, but requires nightly rust and musl-toolchain installed on the build host.

$ ldd target/x86_64-unknown-linux-musl/release/fuse-http
        statically linked

usage

$ fuse-http --help
fuse-http 0.3.0
Mount remote file over HTTP

USAGE:
fuse-http [OPTIONS] <MOUNTPOINT> <URL>

ARGS:
    <MOUNTPOINT>    path to an empty directory
    <URL>           URL pointing to a file to mount

OPTIONS:
    -f, --filename <FILENAME>        file name [default: "file"]
    -s, --cache-size <CACHE_SIZE>    cache size [default: 10MiB]
    --no-daemonize                   keep the process running in foreground
    -h, --help                       Print help information
    -V, --version                    Print version information

example:

$ fuse-http \
    --cache-size 50MiB \
    --filename disk_img \
    /tmp/remote_image \
    http://192.168.0.37/files/ubuntu.iso

$ ls -la /tmp/remote_image/
total 2097152
dr--r--r--  0 root root          0 Jan  1  1970 .
drwxrwxrwt 19 root root        600 May  4 13:14 ..
-r--r--r--  0 root root 2147483648 Jan  1  1970 disk_img

$ time md5sum /tmp/remote_image/disk_img
f44196d7c5ce6a05770206b165c4b414  /tmp/remote_image/disk_img

real    0m7,041s
user    0m3,157s
sys     0m0,558s

$ time qemu-img convert /tmp/remote_image/disk_img -O raw /tmp/tmp.img

real    0m11,112s
user    0m0,147s
sys     0m1,579s

$ umount /tmp/remote_image

Log verbosity is controlled by environment variable RUST_LOG

RUST_LOG=fuse_http=trace fuse-http ...

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.