mirror of
https://github.com/rclone/rclone.git
synced 2025-02-19 23:40:45 +08:00
31 lines
898 B
Markdown
31 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/be5f6/be5f6181dbb9da763149dc6784b09c73b263853c" 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/55a70/55a7034ee29e5ac03dcde8a68e546b298a34e8f8" 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/6a9be/6a9bed5616a28f2529c774470064c24b3a63c39e" alt="Diagram of Linux error handling"
|
||
|
|
||
|
On OS X, the mount never happened:
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/63f8b/63f8b56fae5deae3ceae3f02153c78c21a2aa92c" alt="Diagram of OS X error handling"
|