A forest of podcasts, rooted in the spirit of self-hosting.
PinePods is a complete, self-hosted podcast management system written in Rust.
You run one server, your whole household connects to it, and your subscriptions, history, queue, downloads, and settings follow you from device to device β because everything lives in your own database. Listen in the browser, on the desktop, on your phone, in the car, or even from the terminal.
- π Self-hosted & open source β your podcasts and listening data stay on your hardware (Postgres or MySQL/MariaDB).
- π₯ Multi-user β one instance serves your whole family, each with their own library, stats, and settings.
- π± Native apps everywhere β web, Linux, Windows, macOS, Android, and iOS, plus a CLI client.
- π Bring your own apps β a built-in gpodder-compatible sync server lets you keep using AntennaPod and friends alongside PinePods.
- π Speaks your language β translated into 36 languages by the community.
π Want the full story, deep configuration, and tutorials? Head to the documentation site.
| π§ Listen | Audio and video podcasts, variable speed, chapters, transcripts, downloads, a persistent queue panel, serial auto-play, and per-podcast auto-download. |
| ποΈ Organize | Subscriptions, smart playlists, manual playlists, saved episodes, favorites & favorite categories, full history, and local file-system podcasts. |
| π Discover | Search across Podcast Index, iTunes, and YouTube, search inside your own library for episodes, follow podcast hosts via PodPeople DB, and generate shareable episode links. |
| π Sync & apps | Built-in gpodder server (AntennaPod, etc.), OIDC / SSO, MFA / TOTP, web + desktop + mobile clients with CarPlay and Android Auto, plus the Firewood CLI. |
| π¨ Make it yours | Multiple built-in themes plus a custom theme creator, detailed listening stats, OPML import/export, push notifications (ntfy / webhook), and 36 languages. |
See the full feature catalog in the docs.
A home dashboard that picks up where you left off β with dozens of built-in themes plus a custom theme creator
Browse your whole library and dig into any show
One unified feed of every new episode across your subscriptions
Rich episode pages with show notes, chapters, and transcripts
Listen your way β full-screen audio and native video playback
A persistent queue, smart playlists, library search, and detailed stats
Mobile apps for iOS & Android, with CarPlay and Android Auto
A public demo instance lives at try.pinepods.online β make an account and take a look before you self-host. It's for evaluation only; accounts there are wiped periodically, so run your own server for real use.
The fastest way to run PinePods is Docker Compose with PostgreSQL. Create a
docker-compose.yml:
services:
db:
container_name: db
image: postgres:18
environment:
POSTGRES_DB: pinepods_database
POSTGRES_USER: postgres
POSTGRES_PASSWORD: myS3curepass
PGDATA: /var/lib/pgdata/pgdata
volumes:
- /home/user/pinepods/pgdata:/var/lib/pgdata
restart: always
valkey:
image: valkey/valkey:8-alpine
restart: always
pinepods:
image: madeofpendletonwool/pinepods:latest
ports:
- "8040:8040"
environment:
# Basic server info
SEARCH_API_URL: 'https://search.pinepods.online/api/search'
PEOPLE_API_URL: 'https://people.pinepods.online'
HOSTNAME: 'http://localhost:8040'
# Database
DB_TYPE: postgresql
DB_HOST: db
DB_PORT: 5432
DB_USER: postgres
DB_PASSWORD: myS3curepass
DB_NAME: pinepods_database
# Valkey cache
VALKEY_HOST: valkey
VALKEY_PORT: 6379
DEBUG_MODE: false
# Run as your host user so downloads stay accessible (optional)
PUID: ${UID:-911}
PGID: ${GID:-911}
# Local timezone (optional, used for logs)
TZ: "America/New_York"
volumes:
- /home/user/pinepods/downloads:/opt/pinepods/downloads
- /home/user/pinepods/backups:/opt/pinepods/backups
restart: always
depends_on:
- db
- valkeyThen start it:
sudo docker compose up -dOpen http://localhost:8040 and you'll be prompted to create your first admin
account. That's it β you're up.
βΉοΈ On PostgreSQL 18 / upgrading from 17. New installs default to
postgres:18and need no special steps. Two things to know when moving an existing install to 18:
- Data isn't auto-migrated across major versions.
postgres:18won't start against a data directory created by 17 (FATAL: database files are incompatible with server). Your data is safe β rundeployment/docker/upgrade-postgres.sh(takes a backup, then upgrades in place) or follow the Upgrading PostgreSQL guide. Back up first β the upgrade is one-way.- The
postgres:18image moved its data dir andVOLUME. Bind-mounting to the old/var/lib/postgresql/datacan fail on some Linux/overlay2 hosts withchange mount propagation through procfd ... no such file or directory. The compose above avoids this by mounting at/var/lib/pgdata, outside the image'sVOLUME; use that same pattern when you upgrade. See docker-library/postgres#1363.
Need more? Helm/Kubernetes, MySQL/MariaDB, admin bootstrap vars, the self-hosted search API, timezone tuning, PUID/PGID, and OIDC are all covered in the docs:
- π³ Full server install guide
- β Helm chart β
helm repo add pinepods http://helm.pinepods.online - π Self-hosting the search API
- π OIDC / SSO setup
Run the server, then connect any client by pointing it at your server URL and signing in. The web client is served by the server itself β the rest are optional native apps.
| Platform | How to get it | Notes |
|---|---|---|
| π Web | Built in β browse to your server's port | No install needed |
| π§ Linux | Flathub, AUR (paru -S pinepods), or AppImage / .deb / .rpm on Releases |
Flatpak recommended |
| πͺ Windows | .exe (installer) or .msi (portable) on Releases |
|
| π macOS | .dmg (installer) or portable build on Releases |
|
| π± iOS | App Store | CarPlay supported |
| π€ Android | Google Play, IzzyOnDroid, or Obtainium | Android Auto supported |
| π» Terminal | Pinepods Firewood (CLI) |
ARM devices β including 64-bit Raspberry Pis β are fully supported; the latest tag
auto-pulls the right architecture. Client setup details live in the
clients docs.
PodPeople DB β A community database that supplements podcast person tags so you can follow hosts across every show they appear on, even when a feed doesn't publish host info. Use the hosted instance at podpeopledb.com or self-host your own. Repo Β· Why it exists.
Pinepods Firewood β A terminal-only client for enjoying your podcasts from the comfort of the command line. Check it out.
Helm chart β Deploy on Kubernetes with helm repo add pinepods http://helm.pinepods.online. See the install docs
for values.
- π Documentation: pinepods.online
- π¬ Discord: join the chat
- π¬ Matrix: #pinepods:matrix.org
- π Blog: pinepods.online/blog
- π Translate PinePods: contribute on Weblate β 36 languages and counting.
- π Issues & contributing: see CONTRIBUTING.md and the issue tracker.
PinePods is an open-source podcast player developed by Gooseberry Development and licensed under the GNU General Public License v3.0 (GPL-3.0).
The mobile app includes code adapted from the excellent Anytime Podcast Player by Ben Hills.
Anytime Podcast Player β Β© 2020 Ben Hills and contributors, licensed under the BSD 3-Clause License. Affected files retain the original BSD license and attribution at the top; see
LICENSE.ben_hillsin themobile/directory. Huge thanks to Ben Hills for open-sourcing Anytime β it accelerated PinePods' mobile development enormously.
ARM container images are made possible by Runs-On.


















