-
-
Notifications
You must be signed in to change notification settings - Fork 2.3k
S3 Bucket Quota
To manage quota, the system first needs to know how much storage currently used. Usually this would need some relatively complicated counting, rolling up the directory tree. One way is to count during write time, but the upper tree nodes would become hot spots. This would slow down the normal write operations.
Since SeaweedFS uses one collection for each bucket, the usage can be efficiently collected from the volumes used by the collection. So the usage collection is very cheap and does not interfere with write operations.
There are two aspects of quota management: "quota configuration" and "quota enforcement".
- "Quota Configuration" is done in by an admin script in
weed shell
, where you can set/remove/enable/disable bucket quota for each bucket. - "Quota Enforcement" is actually also an admin script, which you can run it periodically by adding it to
master.toml
. It will check whether all the buckets are over their limit or not. If one bucket is over quota, it will set the bucket to read only.
The bucket's "readOnly" flag is checked when the filer processes write requests. If a bucket is readOnly, the creation and update requests on the bucket will be denied, except deletion. The read operations are not be affected.
1. View current bucket usage
Here there are 3 example buckets created. The bucket sizes and file counts are listed. The bucket size is the actual disk space used, including replicated copies.
> s3.bucket.list
b1 size:527971104 file:151
b2 size:468432 file:6
b3 size:10280 file:3
2. Set bucket "b1" to a low quota
> s3.bucket.quota -name b1 -sizeMB 15
updated quota for bucket b1
> s3.bucket.list
b1 size:527971104 file:151 quota:15728640 usage:3356.75%
b2 size:468432 file:6
b3 size:10280 file:3
3. Enforce the quota, and found it should be set to read only.
> s3.bucket.quota.enforce -apply
b1 size:527971104 quota:15728640 usage:3356.75%
changing bucket b1 to read only!
Note: Internally this readOnly flag is saved into filer configuration for locationPrefix="/buckets/b1/"
. So you could directly check the bucket readOnly
property with fs.configure
also.
> fs.configure
{
"locations": [
{
"locationPrefix": "/buckets/b1/",
"collection": "b1",
"readOnly": true
}
]
}
s3.bucket.quota.enforce -apply
should be run regularly. You can add it to the master.toml
file, or add it to some shell scripts. The frequency depends on how much you trust your users. :)
- Replication
- Store file with a Time To Live
- Failover Master Server
- Erasure coding for warm storage
- Server Startup Setup
- Environment Variables
- Filer Setup
- Directories and Files
- Data Structure for Large Files
- Filer Data Encryption
- Filer Commands and Operations
- Filer JWT Use
- Filer Cassandra Setup
- Filer Redis Setup
- Super Large Directories
- Path-Specific Filer Store
- Choosing a Filer Store
- Customize Filer Store
- Migrate to Filer Store
- Add New Filer Store
- Filer Store Replication
- Filer Active Active cross cluster continuous synchronization
- Filer as a Key-Large-Value Store
- Path Specific Configuration
- Filer Change Data Capture
- Cloud Drive Benefits
- Cloud Drive Architecture
- Configure Remote Storage
- Mount Remote Storage
- Cache Remote Storage
- Cloud Drive Quick Setup
- Gateway to Remote Object Storage
- Amazon S3 API
- AWS CLI with SeaweedFS
- s3cmd with SeaweedFS
- rclone with SeaweedFS
- restic with SeaweedFS
- nodejs with Seaweed S3
- S3 API Benchmark
- S3 API FAQ
- S3 Bucket Quota
- S3 API Audit log
- S3 Nginx Proxy
- Docker Compose for S3
- Hadoop Compatible File System
- run Spark on SeaweedFS
- run HBase on SeaweedFS
- run Presto on SeaweedFS
- Hadoop Benchmark
- HDFS via S3 connector
- Async Replication to another Filer [Deprecated]
- Async Backup
- Async Filer Metadata Backup
- Async Replication to Cloud [Deprecated]
- Kubernetes Backups and Recovery with K8up