mirror of
https://github.com/minio/minio.git
synced 2025-01-26 14:13:16 -05:00
170 lines
5.5 KiB
Markdown
170 lines
5.5 KiB
Markdown
# MinIO FTP/SFTP Server
|
||
|
||
MinIO natively supports FTP/SFTP protocol, this allows any ftp/sftp client to upload and download files.
|
||
|
||
Currently supported `FTP/SFTP` operations are as follows:
|
||
|
||
| ftp-client commands | supported |
|
||
|:-------------------:|:----------|
|
||
| get | yes |
|
||
| put | yes |
|
||
| ls | yes |
|
||
| mkdir | yes |
|
||
| rmdir | yes |
|
||
| delete | yes |
|
||
| append | no |
|
||
| rename | no |
|
||
|
||
MinIO supports following FTP/SFTP based protocols to access and manage data.
|
||
|
||
- Secure File Transfer Protocol (SFTP) – Defined by the Internet Engineering Task Force (IETF) as an
|
||
extended version of SSH 2.0, allowing file transfer over SSH and for use with Transport Layer
|
||
Security (TLS) and VPN applications.
|
||
|
||
- File Transfer Protocol over SSL/TLS (FTPS) – Encrypted FTP communication via TLS certificates.
|
||
|
||
- File Transfer Protocol (FTP) – Defined by RFC114 originally, and replaced by RFC765 and RFC959
|
||
unencrypted FTP communication (Not-recommended)
|
||
|
||
## Scope
|
||
|
||
- All IAM Credentials are allowed access excluding rotating credentials, rotating credentials
|
||
are not allowed to login via FTP/SFTP ports, you must use S3 API port for if you are using
|
||
rotating credentials.
|
||
|
||
- Access to bucket(s) and object(s) are governed via IAM policies associated with the incoming
|
||
login credentials.
|
||
|
||
- Allows authentication and access for all
|
||
- Built-in IDP users and their respective service accounts
|
||
- LDAP/AD users and their respective service accounts
|
||
- OpenID/OIDC service accounts
|
||
|
||
- On versioned buckets, FTP/SFTP only operates on latest objects, if you need to retrieve
|
||
an older version you must use an `S3 API client` such as [`mc`](https://github.com/minio/mc).
|
||
|
||
- All features currently used by your buckets will work as is without any changes
|
||
- SSE (Server Side Encryption)
|
||
- Replication (Server Side Replication)
|
||
|
||
## Prerequisites
|
||
|
||
- It is assumed you have users created and configured with relevant access policies, to start with
|
||
use basic "readwrite" canned policy to test all the operations before you finalize on what level
|
||
of restrictions are needed for a user.
|
||
|
||
- No "admin:*" operations are needed for FTP/SFTP access to the bucket(s) and object(s), so you may
|
||
skip them for restrictions.
|
||
|
||
## Usage
|
||
|
||
Start MinIO in a distributed setup, with 'ftp/sftp' enabled.
|
||
|
||
```
|
||
minio server http://server{1...4}/disk{1...4}
|
||
--ftp="address=:8021" --ftp="passive-port-range=30000-40000" \
|
||
--sftp="address=:8022" --sftp="ssh-private-key=/home/miniouser/.ssh/id_rsa"
|
||
...
|
||
...
|
||
```
|
||
|
||
Following example shows connecting via ftp client using `minioadmin` credentials, and list a bucket named `runner`:
|
||
|
||
```
|
||
ftp localhost -P 8021
|
||
Connected to localhost.
|
||
220 Welcome to MinIO FTP Server
|
||
Name (localhost:user): minioadmin
|
||
331 User name ok, password required
|
||
Password:
|
||
230 Password ok, continue
|
||
Remote system type is UNIX.
|
||
Using binary mode to transfer files.
|
||
ftp> ls runner/
|
||
229 Entering Extended Passive Mode (|||39155|)
|
||
150 Opening ASCII mode data connection for file list
|
||
drwxrwxrwx 1 nobody nobody 0 Jan 1 00:00 chunkdocs/
|
||
drwxrwxrwx 1 nobody nobody 0 Jan 1 00:00 testdir/
|
||
...
|
||
```
|
||
|
||
Following example shows how to list an object and download it locally via `ftp` client:
|
||
|
||
```
|
||
ftp> ls runner/chunkdocs/metadata
|
||
229 Entering Extended Passive Mode (|||44269|)
|
||
150 Opening ASCII mode data connection for file list
|
||
-rwxrwxrwx 1 nobody nobody 45 Apr 1 06:13 chunkdocs/metadata
|
||
226 Closing data connection, sent 75 bytes
|
||
ftp> get
|
||
(remote-file) runner/chunkdocs/metadata
|
||
(local-file) test
|
||
local: test remote: runner/chunkdocs/metadata
|
||
229 Entering Extended Passive Mode (|||37785|)
|
||
150 Data transfer starting 45 bytes
|
||
45 3.58 KiB/s
|
||
226 Closing data connection, sent 45 bytes
|
||
45 bytes received in 00:00 (3.55 KiB/s)
|
||
...
|
||
```
|
||
|
||
|
||
Following example shows connecting via sftp client using `minioadmin` credentials, and list a bucket named `runner`:
|
||
|
||
```
|
||
sftp -P 8022 minioadmin@localhost
|
||
minioadmin@localhost's password:
|
||
Connected to localhost.
|
||
sftp> ls runner/
|
||
chunkdocs testdir
|
||
```
|
||
|
||
Following example shows how to download an object locally via `sftp` client:
|
||
|
||
```
|
||
sftp> get runner/chunkdocs/metadata metadata
|
||
Fetching /runner/chunkdocs/metadata to metadata
|
||
metadata 100% 226 16.6KB/s 00:00
|
||
sftp>
|
||
```
|
||
|
||
## Advanced options
|
||
|
||
### Change default FTP port
|
||
|
||
Default port '8021' can be changed via
|
||
|
||
```
|
||
--ftp="address=:3021"
|
||
```
|
||
|
||
### Change FTP passive port range
|
||
|
||
By default FTP requests OS to give a free port automatically, however you may want to restrict
|
||
this to specific ports in certain restricted environments via
|
||
|
||
```
|
||
--ftp="passive-port-range=30000-40000"
|
||
```
|
||
|
||
### Change default SFTP port
|
||
|
||
Default port '8022' can be changed via
|
||
|
||
```
|
||
--sftp="address=:3022"
|
||
```
|
||
|
||
### TLS (FTP)
|
||
|
||
Unlike SFTP server, FTP server is insecure by default. To operate under TLS mode, you need to provide certificates via
|
||
|
||
```
|
||
--ftp="tls-private-key=path/to/private.key" --ftp="tls-public-cert=path/to/public.crt"
|
||
```
|
||
|
||
> NOTE: if MinIO distributed setup is already configured to run under TLS, FTP will automatically use the relevant
|
||
> certs from the server certificate chain, this is mainly to add simplicity of setup. However if you wish to terminate
|
||
> TLS certificates via a different domain for your FTP servers you may choose the above command line options.
|
||
|