forked from TrueCloudLab/rclone
30 lines
898 B
Markdown
30 lines
898 B
Markdown
# The mount sequence
|
|
|
|
FUSE mounting is a little bit tricky. There's a userspace helper tool
|
|
that performs the handshake with the kernel, and then steps out of the
|
|
way. This helper behaves differently on different platforms, forcing a
|
|
more complex API on us.
|
|
|
|
## Successful runs
|
|
|
|
On Linux, the mount is immediate and file system accesses wait until
|
|
the requests are served.
|
|
|
|
data:image/s3,"s3://crabby-images/9c498/9c498b9ccba6fb5a70b711d104f40c5c66c713e9" alt="Diagram of Linux FUSE mount sequence"
|
|
|
|
On OS X, the mount becomes visible only after `InitRequest` (and maybe
|
|
more) have been served.
|
|
|
|
data:image/s3,"s3://crabby-images/81cb3/81cb3e28ecb062b15febac3545fbdb65d581611e" alt="Diagram of OSXFUSE mount sequence"
|
|
|
|
|
|
## Errors
|
|
|
|
Let's see what happens if `InitRequest` gets an error response. On
|
|
Linux, the mountpoint is there but all operations will fail:
|
|
|
|
data:image/s3,"s3://crabby-images/7d9f6/7d9f6d281a6e2653792db261b3057376798adf3a" alt="Diagram of Linux error handling"
|
|
|
|
On OS X, the mount never happened:
|
|
|
|
data:image/s3,"s3://crabby-images/8f986/8f986cc2d20ea35e3ebc987fd6e4a4a0000cad2d" alt="Diagram of OS X error handling"
|