A fast, simple, self-hosted, no-nonsense media server. Lightweight alternative to Jellyfin/Plex without complex metadata tagging.
The aim is to provide an elegant directory listing for images, videos, and audio. It uses folder navigation and predictable thumbail paths for cover art, thumbnails, etc. Other files are also available to browse and can be directly downloaded.
- Beautiful Catppuccin Mocha themed application for modern web-based directory listing
- Dual system with separate Media and Music modes, each with independent directory paths
- Music navigation is folder-first (Artist → Album → Tracks) with no extra pills
- Tracks in Music are always shown in list view without thumbnails
- Intelligent thumbnail system that displays previews when available, else fallback to icons
- Playlist queue automatically created from media (removable items) in current directory
- Player bar with expanded player view supporting audio, video, and image playback
- Image slideshow mode with automatic advancement every 5 seconds
- Shuffle mode for recursive directory playback (media files only)
- Queue dialog showing current playlist with ability to jump to any item
- Video history tracking - stores last 50 video paths in browser local storage
- Fullscreen player support for videos and images
- Subtitle support for videos with automatic detection of SRT files and embedded tracks
- Player with support to switch between multiple available subtitle tracks
- Search functionality to filter files in the current directory
- Ability to upload files to the server at specific paths
- Thumbnail generation mode in CLI for movies, shows, and videos (using
ffmpegand TMDB API) - Automatic cache cleanup that removes old HLS session files older than 3 days
- Fully self-hosted with local assets and self-contained binary and container
- Efficient size for both binary and container, ~15 and ~50 MB resp
mkdir $HOME/raikiri # you don't need to create this if you already have media in a specific directorydocker run --rm -d --name raikiri \
-p 8080:8080 \
-v $HOME/raikiri:/app/media \
-v $HOME/music:/app/music \
-v $HOME/raikiri-cache:/app/cache \
tanq16/raikiri:mainAvailable at http://localhost:8080. Docker Compose example:
services:
raikiri:
image: tanq16/raikiri:main
container_name: raikiri
volumes:
- /home/tanq/raikiri:/app/media # Change as needed
- /home/tanq/music:/app/music # Change as needed
- /home/tanq/raikiri-cache:/app/cache # HLS segment cache
ports:
- 8080:8080To use the binary, simply download the latest version from the project releases and run as follows:
raikiri -media $YOUR_MEDIA_FOLDER -music $YOUR_MUSIC_FOLDER -cache $YOUR_HLD_CACHE_FOLDERFlags:
-media: media directory path-music: music directory path-cache: HLS cache directory
Switch between Media and Music modes via interface tabs. Think of it as your own minimal Netflix on the Media tab and your own minimal Spotify on the Music tab.
Cache directory stores temporary HLS segments generated during video playback. Auto-cleanup runs daily at 3 AM, removing sessions older than 3 days.
Storing cache in your SSD will yield faster performance (or instant seeks anywhere in the video). However, using HDD is recommended for longevity (lots of segment writes), even though it's not instant when seeking to further ahead right after launching the video.
Install with Go 1.24+:
go install github.com/tanq16/raikiri@latestOr build from source:
git clone https://github.com/tanq16/raikiri.git && \
cd raikiri && \
go build .Requires ffmpeg (includes ffprobe) in PATH for:
- Video playback (HLS transmuxing; transcodes if audio is a mismatch)
- Thumbnail generation (
-prepareflag)
For Docker deployments, provided image includes ffmpeg.
Thumbnails are stored as hidden files (.filename.thumbnail.jpg) alongside media. It is displayed in grid view when available.
To generate thumbnails, use the -prepare flag with one of the following modes:
videos: Generate thumbnails recursively for all video files in the current directoryvideo: Generate thumbnails for video files in the current folder onlyshows: Auto-match TV shows using TMDB API (requiresTMDB_API_KEYenvironment variable); needs to be run in directory that has directories of all showsshow: Manual interactive TV show matching using TMDB API (requiresTMDB_API_KEYenvironment variable); needs to be run in directory of a specific showmovies: Auto-match movies using TMDB API (requiresTMDB_API_KEYenvironment variable); ; needs to be run in directory that has directories of all moviesmovie: Manual interactive movie matching using TMDB API (requiresTMDB_API_KEYenvironment variable); needs to be run in directory of a specific movie
raikiri -prepare videosNote
- Video thumbnails are screenshots at 50% of the video duration
- For images, the original file is used as a fallback if no thumbnail exists
Tip
In Music mode, album art is considered as the directory thumbnail (.thumbnail.jpg), artist cover is considered from artist directory thumbnail. Tracks use list view (no thumbnails).
Clicking media auto-creates a playlist from current directory files. Player bar shows current item with controls. Click to expand for seek controls, time display, and queue dialog.
Queue dialog highlights active item; click any item to jump. Shuffle button plays all media recursively in random order (skips non-media).
- Images: auto-advance every 5s
- Videos/audio: play/pause, prev/next, seek
- Fullscreen: videos and images only
History Tracking
- Click the Raikiri logo to open a history modal with last 50 videos (not audio/images) played
- History is stored in browser localStorage and shows full file path as most recent first
Video Playback
- HLS auto-segmented to 6s segments via
ffmpeg - Audio is played back directly in HTML5
- Unplayable files open in new tab as raw GET
Subtitles
- Auto-detection of SRTs in same directory,
subs/, orSubs/ - Auto-extraction of embedded subtitle tracks
- All subtitles are converted to WebVTT and served as options
- CC button allows selecting across available tracks or disabled
- Videos are HLS tranmuxed/transcoding via
ffmpeg(full seekability, format compatibility) - Fullscreen player with custom overlay with controls (play/pause, +-10s seek, seek bar, exit)
- Fullscreen disabled for audio (images/videos only)








