Database-Information-and-Maintenance
Invidious needs one PostgreSQL database which has the following tables.
- annotationsCaches annotation data if- cache_annotationsis enabled in- config.yml
- channel_videosStores truncated video info, used to create user feeds
- channelsStores UCID and author name
- noncesKeeps track of tokens issued to prevent CSRF
- usersStores user info, such as preferences, username, subscriptions
- session_idsKeeps track of user sessions
- videosStores video cache, used to create "top" page
The table videos grows a lot and needs the most storage. You can clean it up using following commands:
$ sudo -i -u postgres
$ psql invidious -c "DELETE FROM nonces * WHERE expire < current_timestamp"
$ psql invidious -c "TRUNCATE TABLE videos"
$ exit
For regular maintenance you should add a cronjob for these commands
@weekly psql invidious -c "DELETE FROM nonces * WHERE expire < current_timestamp" > /dev/null
@weekly psql invidious -c "TRUNCATE TABLE videos" > /dev/null