217 lines
4.7 KiB
Text
217 lines
4.7 KiB
Text
.TH FTPFS 4
|
|
.SH NAME
|
|
ftpfs \- file transfer protocol (FTP) file system
|
|
.SH SYNOPSIS
|
|
.B ftpfs
|
|
[
|
|
.B -/dqntc
|
|
]
|
|
[
|
|
.B -m
|
|
.I mountpoint
|
|
]
|
|
[
|
|
.B -a
|
|
.I password
|
|
]
|
|
[
|
|
.B -e
|
|
.I ext
|
|
]
|
|
[
|
|
.B -k
|
|
.I keyspec
|
|
]
|
|
[
|
|
.B -o
|
|
.I os
|
|
]
|
|
[
|
|
.B -r
|
|
remoteroot
|
|
]
|
|
.I system
|
|
.SH DESCRIPTION
|
|
.I Ftpfs
|
|
dials the TCP file transfer protocol (FTP) port, 21, on
|
|
.I system
|
|
and mounts itself (see
|
|
.IR bind (2))
|
|
on
|
|
.I mountpoint
|
|
(default
|
|
.BR /n/ftp )
|
|
to provide access via FTP to files on the remote machine.
|
|
.I Ftpfs
|
|
attempts to use FTP's `passive' mode
|
|
but falls back to using `active' mode if that fails.
|
|
If required by the remote machine,
|
|
.I ftpfs
|
|
will ask
|
|
.IR factotum (4)
|
|
for a key matching the pattern
|
|
.IP
|
|
.EX
|
|
proto=pass service=ftp server=\fIsystem\fP user? !password? \fIkeyspec\fP
|
|
.EE
|
|
.PP
|
|
(If
|
|
.I factotum
|
|
does not have such a key,
|
|
.I factotum
|
|
will prompt the user for one.)
|
|
.PP
|
|
The user names
|
|
.B ftp
|
|
and
|
|
.B anonymous
|
|
conventionally offer guest/read-only access to
|
|
machines.
|
|
Anonymous FTP may be called without using factotum
|
|
by using the
|
|
.B -a
|
|
option and specifying the
|
|
.IR password .
|
|
.PP
|
|
By default the file seen at the mount point is the user's
|
|
remote home directory if he has one.
|
|
The option
|
|
.B -/
|
|
forces the mount point to correspond to the
|
|
remote root.
|
|
The option
|
|
.B -r
|
|
forces the mount point to correspond to the
|
|
remote directory
|
|
.IR remoteroot .
|
|
.PP
|
|
To avoid seeing startup messages from the server use option
|
|
.BR -q .
|
|
To see all messages from the server use option
|
|
.BR -d .
|
|
.PP
|
|
By default ftpfs only caches while a file operation is in progress. The
|
|
.BR -c
|
|
flag enables caching, increasing performance but allowing outdated file and directory data to persist.
|
|
.PP
|
|
Some systems will hangup an ftp connection that has no activity
|
|
for a given period. The
|
|
.BR -K
|
|
option causes ftp to send a NOP command every 15 seconds to attempt
|
|
to keep the connection open. This command can cause some servers to
|
|
hangup, so you'll have to feel your way.
|
|
.PP
|
|
The
|
|
.B -t
|
|
option causes
|
|
.I ftpfs
|
|
to negotiate TLS encryption with the server.
|
|
.PP
|
|
To terminate the connection,
|
|
.B unmount
|
|
(see
|
|
.IR bind (1))
|
|
the mount point.
|
|
.PP
|
|
Since there is no specified format for metadata retrieved
|
|
in response to an FTP directory request,
|
|
.I ftpfs
|
|
has to apply heuristics to steer the interpretation. Sometimes,
|
|
though rarely, these heuristics fail. The following options are
|
|
meant as last resorts to try to steer interpretation.
|
|
.PP
|
|
A major clue to the heuristics is the operating system at the other
|
|
end. Normally this can be determined automatically using the
|
|
FTP SYST command. However, in some cases the server doesn't implement
|
|
the SYST command. The
|
|
.B -o
|
|
option will force the case by specifying the name of the operating
|
|
system. Known system types are:
|
|
.BR UNIX ,
|
|
.BR SUN ,
|
|
.BR TOPS ,
|
|
.BR Plan9 ,
|
|
.BR VM ,
|
|
.BR VMS ,
|
|
.BR MVS ,
|
|
.BR NetWare ,
|
|
.BR OS/2 ,
|
|
.BR TSO ,
|
|
and
|
|
.BR WINDOWS_NT .
|
|
.PP
|
|
Some systems and/or FTP servers return directory listings that don't
|
|
include the file extension. The
|
|
.B -e
|
|
option allows the user to specify an extension to append to all
|
|
remote files (other than directories).
|
|
.PP
|
|
Finally, there are two FTP commands to retrieve the contents of a
|
|
directory, LIST and NLST. LIST is approximately equivalent to
|
|
.L ls -l
|
|
and NLST to
|
|
.LR ls .
|
|
.I Ftpfs
|
|
normally uses LIST. However, some FTP servers interpret LIST
|
|
to mean, give a wordy description of the file.
|
|
.I Ftpfs
|
|
normally notices this and switches to using NLST. However, in
|
|
some rare cases, the user must force the use of NLST with the
|
|
.B -n
|
|
option.
|
|
.SH EXAMPLE
|
|
You want anonymous FTP access to the system
|
|
.BR export.lcs.mit.edu .
|
|
The first
|
|
.IR import (4)
|
|
command is only necessary if your machine does not have access to the
|
|
desired system, but another, called
|
|
.B gateway
|
|
in this example, does.
|
|
.IP
|
|
.EX
|
|
import gateway /net
|
|
ftpfs -a yourname@yourmachine export.lcs.mit.edu
|
|
.EE
|
|
.SH SOURCE
|
|
.B /sys/src/cmd/ip/ftpfs
|
|
.SH "SEE ALSO"
|
|
.IR bind (2)
|
|
.SH BUGS
|
|
Symbolic links on remote Unix systems will always have mode 0777
|
|
and a length of 8.
|
|
.PP
|
|
After connecting to a TOPS-20 system, the mount point will contain
|
|
only one directory, usually
|
|
.BR /n/ftp/PS:<ANONYMOUS> .
|
|
However, walking to any valid directory on that machine will succeed
|
|
and cause that directory entry to appear under the mount point.
|
|
.PP
|
|
If caching is active, remote
|
|
changes that have been cached will not be visible.
|
|
Attempting to walk to
|
|
.IB directory /.flush.ftpfs
|
|
will flush
|
|
.I directory
|
|
from the cache, thus forcing
|
|
.I ftpfs
|
|
to re-read it.
|
|
.PP
|
|
There is no way to issue the appropriate commands to handle special synthetic
|
|
FTP file types such as directories
|
|
that automatically return a
|
|
.B tar
|
|
of their contents.
|
|
.PP
|
|
.I Ftpfs
|
|
makes copies in
|
|
.B /tmp
|
|
of files being transferred,
|
|
so its effects might not be immediate.
|
|
If there is enough main memory, you might want to run
|
|
.IR ramfs (4)
|
|
first.
|
|
.PP
|
|
Filenames containing spaces will confuse
|
|
.I ftpfs
|
|
(and other FTP clients).
|