2023-08-07 18:03:00 -04:00
---
title: 'Storage settings'
license: 'CC-BY-SA-4.0'
---
The storage for each subsystem (`attachments`, `lfs` , `avatars` ,
`repo-avatars` , `repo-archive` , `packages` , `actions_log` ,
`actions_artifact` ) is defined in `app.ini` . It can either be on disk
(`local`) or using a MinIO server (`minio`). The default is `local`
2023-08-09 17:26:16 -04:00
storage, using the following hierarchy under the `APP_DATA_PATH` directory:
2023-08-07 18:03:00 -04:00
2023-08-09 18:04:59 -04:00
| storage | default base path | app.ini sections |
| ----------------- | ------------------ | ------------------- |
| attachments | attachments/ | [attachments] |
| lfs | lfs/ | [lfs] |
| avatars | avatars/ | [avatars] |
| repo-avatars | repo-avatars/ | [repo-avatars] |
| repo-archive | repo-archive/ | [repo-archive] |
| packages | packages/ | [packages] |
| actions_log | actions_log/ | [actions_log] |
| actions_artifacts | actions_artifacts/ | [actions_artifacts] |
2023-08-07 18:03:00 -04:00
2023-08-09 17:26:16 -04:00
For instance if `APP_DATA_PATH` was `/appdata` , the default directory to
2023-08-10 04:38:52 -04:00
store attachments would be `/appdata/attachments` .
2023-08-07 18:03:00 -04:00
## Overriding the defaults
These defaults can be modified for all subsystems in the `[storage]`
section. For instance setting:
```
[storage]
PATH = /mystorage
```
2023-08-10 04:38:52 -04:00
would change the default for storing attachments to
2023-08-07 18:03:00 -04:00
`/mystorage/attachments` . It is also possible to change these settings
2023-08-09 18:04:59 -04:00
for each subsystem in a `[XXXX]` section. For instance setting:
2023-08-07 18:03:00 -04:00
```
[storage]
PATH = /mystorage
2023-08-09 18:04:59 -04:00
[attachments]
2023-08-10 04:38:52 -04:00
PATH = /otherstorage/attachments
2023-08-07 18:03:00 -04:00
```
2023-08-10 04:38:52 -04:00
would store attachments in `/otherstorage/attachments` while `lfs`
2023-08-07 18:03:00 -04:00
files would be stored in `/mystorage/lfs` .
## Storage type
The value of `STORAGE_TYPE` can be `local` (the default) or `minio` . For instance:
```
[storage]
STORAGE_TYPE = minio
```
2023-08-10 04:38:52 -04:00
Will use `minio` for all subsystems (`attachments`, `lfs` , etc.)
2023-08-07 18:03:00 -04:00
instead of storing them on disk. Each storage type has its own
settings, as explained below.
## `local` storage
There is just one setting when the `STORAGE_TYPE` is set to `local` ,
`PATH` . For instance:
```
[storage]
STORAGE_TYPE = local
PATH = /mystorage
```
If the value of PATH for the `XXXX` subsystem is relative, it is
constructed as follows:
2023-08-09 17:26:16 -04:00
- The default base path is `APP_DATA_PATH` (for instance `/appdata` )
- If `[storage].PATH` is relative (for instance `storage` ), the default base path becomes `APP_DATA_PATH` /`[storage].PATH` (for instance `/appdata/storage` )
2023-08-07 18:03:00 -04:00
It is recommended to always set the `PATH` values to an absolute path
name because it is easier to understand and maintain.
## `minio` storage
When the `STORAGE_TYPE` is set to `minio` , the settings available in
2023-08-09 18:04:59 -04:00
all sections (`[storage]` and `[XXXX]` ) are:
2023-08-07 18:03:00 -04:00
- `SERVE_DIRECT` : **false** : Allows the storage driver to redirect to authenticated URLs to serve files directly. Only supported via signed URLs.
- `MINIO_ENDPOINT` : **localhost:9000** : Minio endpoint to connect.
- `MINIO_ACCESS_KEY_ID` : Minio accessKeyID to connect.
- `MINIO_SECRET_ACCESS_KEY` : Minio secretAccessKey to connect.
- `MINIO_BUCKET` : **gitea** : Minio bucket to store the data.
- `MINIO_LOCATION` : **us-east-1** : Minio location to create bucket.
- `MINIO_USE_SSL` : **false** : Minio enabled ssl.
- `MINIO_INSECURE_SKIP_VERIFY` : **false** : Minio skip SSL verification.
2023-08-09 18:04:59 -04:00
One setting is only available in the `[XXXX]` sections:
2023-08-07 18:03:00 -04:00
- `MINIO_BASE_PATH` : defaults to the `default base path` of the `XXXX`
subsystem (see the table above) and is a relative path within the
MinIO bucket defined by `MINIO_BUCKET` .
## Sections precedence
The sections in which a setting is found have the following priority:
2023-08-09 18:04:59 -04:00
- [XXXX] has precedence
- [storage] is the default
2023-08-07 18:03:00 -04:00
For instance:
```
[storage]
2023-08-09 18:04:59 -04:00
PATH = /default
2023-08-07 18:03:00 -04:00
[attachments]
PATH = /first
```
2023-08-10 04:38:52 -04:00
Will set the value of `PATH` for attachments to `/first` .
2023-08-09 18:04:59 -04:00
## Undocumented features
It is **strongly** recommended to avoid using undocumented features
2023-08-10 04:38:52 -04:00
(such as `[storage.attachments]` as an alternative to `[attachments]`
2023-08-09 18:04:59 -04:00
for instance) because their behavior is not thoroughly tested and may
lead to unexpected results.