Configuration
Rustus is highly configurable. You can adjust it with CLI or you can use environment variables.
Info
Information about hooks you can find on Hooks page.
Configuring server
We use actix to run server.
You can configure on wich host
and port
rustus is listenging.
Also you can configure number of actix workers
that handle connections.
--max-body-size
is the max number of bytes that users can send in request body.
--url
is a base URL for all tus requests.
--workers
by default is euqal to number of physical CPU cores. Edit it carefully.
Configuring data storage
Info
Currently only file storage is available,
so if you pass to --storage
parameter other than file-storage
you will get an error.
Available parameters:
--storage
- type of data storage to be used;--data-dir
- path to the directory where all files are stored;--dir-structure
- pattern of a directory structure inside data dir;--force-fsync
- calls fsync system call after every write to disk. `` You can use variables within the pattern.
Available variables:
{year}
- current year;{month}
- current month number from 1 to 12;{day}
- current day number from 1 to 31;{hour}
- hour number from 0 to 23;{minute}
- minute number from 0 to 59;{env[ENV_NAME]}
- environment variable whereENV_NAME
is name of your variable.
Note
All environment variables are saved in memory during rustus startup. So you cannot change variable dynamically. Even if you change env used in structure pattern it won't change.
For example if you use {env[HOSTNAME]}/{year}/{month}/{day}
as your dir-structure, rustus stores files like:
$ tree data
data
└── rtus-68cb5b8746-5mgw9
└── 2022
└── 1
└── 8
├── 0bd911d4054d41c6a3ad54be67ee3e66
└── 5bc9c62384494c439e2a064b82a39cc6
Configuring info storage
Info storages are used to store information about file uploads. These storages must be persistent, because every time chunk is uploaded rustus updates information about upload. And when someone wants to download file, information about it requested from storage to get actual path of an upload.
Available info storages:
file-info-storage
- stores information in files on disk;redis-info-storage
- information is stored in Redis;db-info-storage
- information is stored in database;
File info storage
file info storage stores information in files on disk. It's default info storage. Every download has it's own associated file. All .info files stored in flat structure so it's the least preferable way of storing information about uploads. But if you don't plan to have many uploads, it may fit well.
--info-dir
- directory where all .info file will be stored (default is ./data
).
Redis info storage
Redis db is a good way to store information.
Note
If you're using Redis as a cluster you must provide connection string for master Redis server. Since rustus need to have latest information and it writes a lot.
--info-db-dsn
- connection string for your Redis database.
It's required if redis-info-storage
is chosen.
DB info storage
Rustus can store information about upload in a database.
It's a good and reliable option. But Rustus can't work with replicas, since it requires the most recent information about uploads.
You can use postgresql
, mysql
or even sqlite
schemas to
connect to database.
--info-db-dsn
- connection string for your database.
Configuring TUS
Since TUS protocol offers extensibility you can turn off some protocol extensions.
Available extensions:
getting
- Rustus specific extension that helps you download uploaded files with get request;creation
- helps you to create files (It's like a core feature you better have this enabled);termination
- allows you to delete uploads with DELETE request;creation-with-upload
- allows you to write first bytes of a file while creating;creation-defer-length
- allows you to create file without specifying file length;concatenation
- allows you to concatenate finished partial uploads.checksum
- allows you to verify checksum of every batch.
You can read more about extensions on official web-site.
--tus-extensions
- a list of enabled extensions.
--remove-parts
- remove parts files after successfull concatentation (disabled by default).
By default all extensions are enabled.