2019-04-09 14:39:42 -04:00
## MinIO Server Limits Per Tenant
2021-08-03 16:26:57 -04:00
For best deployment experience MinIO recommends operating systems RHEL/CentOS 8.x or later, Ubuntu 18.04 LTS or later. These operating systems package the latest 'xfsprogs' that support large scale deployments.
2016-12-20 17:42:13 -05:00
### Erasure Code (Multiple Drives / Servers)
2021-05-24 12:37:17 -04:00
| Item | Specification |
|:----------------------------------------------------------------|:--------------|
| Maximum number of servers per cluster | no-limit |
| Maximum number of federated clusters | no-limit |
| Minimum number of servers | 02 |
| Minimum number of drives per server when server count is 1 | 04 |
| Minimum number of drives per server when server count is 2 or 3 | 02 |
| Minimum number of drives per server when server count is 4 | 01 |
| Maximum number of drives per server | no-limit |
| Read quorum | N/2 |
| Write quorum | N/2+1 |
2021-04-29 22:01:43 -04:00
2016-12-20 17:42:13 -05:00
### Limits of S3 API
2021-05-24 12:37:17 -04:00
| Item | Specification |
|:--------------------------------------------------------------------------------|:----------------------------------------------|
| Maximum number of buckets | no-limit |
| Maximum number of objects per bucket | no-limit |
| Maximum object size | 5 TiB |
| Minimum object size | 0 B |
| Maximum object size per PUT operation | 5 TiB |
| Maximum number of parts per upload | 10,000 |
| Part size range | 5 MiB to 5 GiB. Last part can be 0 B to 5 GiB |
| Maximum number of parts returned per list parts request | 10000 |
| Maximum number of objects returned per list objects request | 4500 |
| Maximum number of multipart uploads returned per list multipart uploads request | 1000 |
2021-06-23 15:51:31 -04:00
| Maximum length for bucket names | 63 |
| Maximum length for object names | 1024 |
| Maximum length for '/' seperated object name segment | 255 |
2016-12-20 17:42:13 -05:00
2019-04-09 14:39:42 -04:00
### List of Amazon S3 API's not supported on MinIO
2021-05-24 12:37:17 -04:00
We found the following APIs to be redundant or less useful outside of AWS S3. If you have a different view on any of the APIs we missed, please open a [GitHub issue ](https://github.com/minio/minio/issues ).
2017-02-10 02:26:44 -05:00
2019-04-09 14:39:42 -04:00
#### List of Amazon S3 Bucket API's not supported on MinIO
2016-12-20 17:42:13 -05:00
2019-04-09 14:39:42 -04:00
- BucketACL (Use [bucket policies ](https://docs.min.io/docs/minio-client-complete-guide#policy ) instead)
2017-02-10 02:26:44 -05:00
- BucketCORS (CORS enabled by default on all buckets for all HTTP verbs)
2020-12-31 12:44:07 -05:00
- BucketWebsite (Use [`caddy` ](https://github.com/caddyserver/caddy ) or [`nginx` ](https://www.nginx.com/resources/wiki/ ))
2019-04-09 14:39:42 -04:00
- BucketAnalytics, BucketMetrics, BucketLogging (Use [bucket notification ](https://docs.min.io/docs/minio-client-complete-guide#events ) APIs)
2016-12-20 17:42:13 -05:00
- BucketRequestPayment
2019-04-09 14:39:42 -04:00
#### List of Amazon S3 Object API's not supported on MinIO
2016-12-20 17:42:13 -05:00
2019-04-09 14:39:42 -04:00
- ObjectACL (Use [bucket policies ](https://docs.min.io/docs/minio-client-complete-guide#policy ) instead)
2016-12-20 17:42:13 -05:00
- ObjectTorrent
2018-02-03 09:27:40 -05:00
2019-04-09 14:39:42 -04:00
### Object name restrictions on MinIO
2021-08-03 16:26:57 -04:00
- Object names that contain characters `^*|\/&";` are unsupported on Windows platform or any other file systems that do not support filenames with special charaters. **This list is non exhaustive, it depends on the operating system and filesystem under use - please consult your operating system vendor** . MinIO recommends using Linux based deployments for production workloads.
2021-05-24 12:37:17 -04:00
2021-08-03 16:26:57 -04:00
- Objects should not have conflicting objects as parents, applications using this behavior should change their behavior and use proper unique keys, for example situations such as following conflicting key patterns are not supported.
```
PUT < bucketname > /a/b/1.txt
PUT < bucketname > /a/b
```
```
PUT < bucketname > /a/b
PUT < bucketname > /a/b/1.txt
```