A compiled list of 500+ ready to go Portainer App templates
🌐 portainer-templates.as93.net
TL;DR Under Settings → App Templates in your Portainer GUI, paste this URL:
https://raw.githubusercontent.com/phil-markarian/portainer-templates/main/templates.json
This repository is a fork of the original project. It includes custom modifications and fixes for personal use. Below you will find the original credits and additional information about the changes made in this fork.
- Updated Schema to reflect Portainer version 2.19s requirement for template files.
- added regrex for ports so it relatively lax
- Updated the validator script so that it catches all errors and outputs them to the terminal.
- Changed the download script to init_and_update
- Allows you to initialize templates in your source files.
- Creates a log so you can fix any issues when downloading templates.
- Fixes any tempaltes that don't follow the schema
- If an image is missing it will look on Docker Hub for an image. However, if no image is found it will put in a place holder.
- If a description or category is not found it will search Docker Hub and place a placeholder if none are found.
- It makes a new folder with the name of your template file and makes individual json files for each template that is currently not working.
- Added a script to combine and remove any duplicates.
- Creates a log of all the templates from sources in processed_templates.json
- Creates a log of updates made to template.json (template_update.og)
- Creates a log that shows what templates have been modified or removed (combine_and_remove.log)
- Added a sort script so you can sort your templates (templates.json) alphabetically, if you so choose.
- Changed list script to readme_list so that it makes it more obvious what the script is for. It's for making a list of templates in the readme.
- Added other scripts in lib/misc folder to help fix and organize templates. They were the precursor the the updated scripts. Feel free to get inspiration or change them to your liking. I plan to use this misc folder for scripts that only have very limited usage.
Contents
In Portainer, App Templates enable you to easily deploy services with a predetermined configuration, while allowing you to customize options through the web UI. While Portainer ships with some default templates (see portainer/templates), it's often helpful to have 1-click access to many more apps + stacks, without having to constantly switch template sources.
This repo combines app templates from several sources, to create a ready-to-go template file containing all the apps you'll ever need. It's also possible to self-host, as well as combine with your own custom templates.
You can browse all supported apps and stacks and see stats, config options and stand-alone installation commands for each, at portainer-templates.as93.net
- Log into your Portainer web UI
- Under Settings --> App Templates, update the URL to
https://raw.githubusercontent.com/phil-markarian/portainer-templates/main/templates.json
- Now under Home --> App Templates, you should see all apps. Click one to deploy.
Alternatively, when you start Portainer, you can append the --templates
flag pointing to the templates URL.
If you'd prefer to source templates locally, you can self-host with Docker - there's a sample NGINX container provided
Just run: docker run -p 8080:80 phil-markarian/portainer-templates
(changing 8080 to a port of your choice)
You'll then be able to pass Portainer the template file located at http://[host]:[port]/templates.json
Alternatively, you can build the image yourself locally, with the following commands (if you're using your own fork, don't forget to switch phil-markarian
out for your username!)
git clone https://github.com/phil-markarian/portainer-templates.git
cd portainer-templates
docker build -t portainer-templates .
docker run -d -p "8080:80" portainer-templates
If you're using your own template file, but don't want to fork this repository, you can instead simply pass your templates.json
file to the above Docker container as a volume, with -v "${PWD}/templates.json:/usr/share/nginx/html/templates.json"
This repository provides a comprehensive list of Portainer templates, generated using scripts and GitHub Actions. It includes a variety of sources and allows easy integration of new templates.
The template.json
file is generated using the scripts in lib
and GitHub Actions. Running the make
command will download all listed sources, parse them, and combine them with anything in the sources directory, outputting the templates.json
file.
Note: You only need to edit either the sources.csv
file, or add your templates directly into the sources/
directory.
If you're maintaining your own list of Portainer templates and would like them to be included, just add the URL to your template.json
file to sources.csv
, along with a name. When the action runs, it will download the content, parse it, and add it to the final template.
Alternatively, place your template file within the sources
directory, and it will be automatically combined into the main template.json
. Ensure that your template corresponds to Portainer's App Template JSON Format.
There is a schema defined in Schema.json
, which can be used to validate any Portainer template. Run make validate
to ensure your template conforms to Portainer's App Template specification.
If you'd like to use this repo as a base but maintain your own list of templates, just fork the repository and update phil-markarian
with your username in the import URL.
- Purpose: Downloads template sources, validates them, and updates the local repository.
- Usage: Run the script to fetch templates from URLs listed in
sources.csv
, validate them, and update the repository. Handles rate limits and logs detailed processing information. - Logs:
template_processing.log
: Contains detailed logs of template processing, including download attempts, validation results, and any errors encountered.
- Purpose: Combines templates from various sources and removes duplicates.
- Usage: Run the script to load, filter, and combine templates into
templates.json
. It also logs updates and errors. - Logs:
combine_and_remove.log
: Contains logs of the template combination process, including loaded files, any JSON decoding errors, and duplicate removals.template_updates.log
: Logs details of templates that were added or modified during the combination process.
- Purpose: Generates lists of templates and sources for the README file.
- Usage: Run the script to update the README with the current list of templates and sources.
- Logs: This script does not generate logs.
- Purpose: Sorts the templates in
templates.json
alphabetically by title and ensures consistent key ordering. - Usage: Run the script to sort templates and write the sorted data back to
templates.json
. - Logs: This script prints the result of the sorting process to the console.
- Purpose: Validates the
templates.json
file against the schema defined inSchema.json
and additional checks. - Usage: Run the script to validate templates, checking for missing required properties and ensuring they conform to Portainer's format.
- Logs: This script prints validation errors and details to the console.
- Fork the Repository: Create your own fork to maintain a personalized list of templates.
- Add Sources: Edit the
sources.csv
file to include URLs to your template lists. - Add Templates Directly: Place your template files in the
sources
directory. - Run Scripts:
init_and_update.py
to fetch and update templates from listed sources.combine_and_remove.py
to combine and filter templates.read_me_list.py
to update the README with the current templates and sources.sort.py
(optional) to sort templates intemplates.json
.validate.py
to validate templates if you are adding them manually.
By following these steps, you can easily manage and maintain your list of Portainer templates.
↕️ Click to Expand ↕️
Click an item, to see stats, config options and installation instructions
Activepieces
Actual
Adguard
Adguardhome
Adguardhome-Sync
Airsonic
Airsonic-Advanced
Alpine Xfce4 Novnc
Altus
Ansible-Semaphore
Apache Httpd
Apprise-Api
Appsmith
Appwrite
Archisteamfarm
Archivebox
Ardour
Aria2 Pro
Ariang
Asciinema {Shmolf}
Audacity
Audiobookshelf
Authelia
Authentik
Autobrr
Babybuddy
Baikal
Bambustudio
Baserow
Bazarr
Beets
Bitwarden Rs
Bitwarden Rs Backup
Bitwarden Stack
Blender
Boinc
Booksonic
Booksonic-Air
Bookstack
Broadlink Manager
- Budge
Budibase
- Build-Agent
Caddy
Calibre
Calibre Web
Calligra
Cardigann
Castopod
Changedetection
Changedetection.Io
Chevereto
Chibisafe
Chiefonboarding
Chowdown
Chromium
Chrony Ntp
- Ci
Clamav
Cloud Commander
Cloud9
Cloudflare Ddns
Cockpit {Shmolf}
Cockroachdb
Code Server
Codex
Codiad
- Codimd
Commandbox
Contentbox
Cops
Couchpotato
Cratedb
Cryptofolio
Cura
Daapd
Darktable
Dashdot
Dashmachine
Dashy
Datadog Agent
Davinci Postgres Server
Davos
Ddclient
Deemix
Deluge
- Deluge Openvpn
Digikam
Diskover
Docker Container Stats
Docker Registry
Dockge
- Documize
Dokemon
- Dokku
Dokuwiki
Domoticz
Doplarr
Doublecommander
Dozzle
Dradis
Draw.Io
Droppy
Drupal
Duckdns
Duplicacy
Duplicati
Eclipse Mosquitto Mqtt
Edgeconnector 840D
Edgeconnector Aggregator
Edgeconnector Fanuc Cnc
Edgeconnector Modbus
Edgeconnector Siemens
- Eetv Plex Proxy
Elasticsearch
Emby
Embystat
Emulatorjs
Endlessh
Eufy Security Ws
Excalidraw
Fail2Ban
Faster-Whisper
Fdo
Feed2Toot
- Feedcord
Fenrus
Ferdi Server
Ferdium
Fetchcord
- Ffmpeg
Filebrowser
Filebrowser Latest
Filebrowser S6
Filepizza
Filerun
Filestash
Filezilla
Firefox
Firefoxv2
Fireshare
Flame
Flame-Dashboard
Flaresolverr
- Fleet
Flexget
Floating License Server
Flood
Flowiseai
Foldingathome
Foundryvtt Server
Freeboard
Freecad
Freescout
Freetube
Freshrss
Frigate Nvr
Funkwhale
Gaps
Gazee
Geo Energy Data
Ghost
Ghostfolio
Gimp
Gitea
Github-Desktop
Gitlab Ce
Gitlab Runner
Gitqlient
Glances
Go-Socks5-Proxy
Gokapi
Google Chrome
Gophish
Gotify
Grafana
Grav
Grocy
Guacamole
Habridge
- Hasty-Paste
Hauk
Headphones
Healthchecks
Hedgedoc
Heimdall
Hishtory-Server
Homarr
Homarr-Secured
Homeassistant
Homebridge
Homebridge - Debian
Homechart
Homepage
Homer
Htpc Manager
Httpd
Huginn
Hydra2
- I Hate Money
Immich
Immich {Shmolf}
Influxdb
Influxdb & Telegraf
Influxdb 1.8.10
Inkscape
Invidious
Invoice Ninja
Iobroker
- Iperf
Ironfunctions
Ironfunctions Api
Ironfunctions Ui
Jackett
Jdownloader
Jellyfin
Jellyfin-Accounts
Jellyseer
Jellyseerr
Jenkins
- Jenkins-Builder
Jetbrains Teamcity Agent
Jetbrains Teamcity Agent Docker
Jetbrains Teamcity Server
Jetbrains Teamcity Stack
Joomla
Joplin
- Jump
- Jupyter Notebook
Kanzi
- Kapowarr
Kasm
Kavita
Kdenlive
Keepassxc
Kicad
Kimai
Kiwix
Klaxon
Klipper[Testing], Mainsail, Moonraker
Kodi Headless
Koillection
Kometa
Komga
Krita
Lazylibrarian
- Lazytainer
Ldap-Auth
Leantime
Let'S Encrypt
Let'S Encrypt / Swag
Libreddit
Libreoffice
Libresonic
Librespeed
Librewolf
Lidarr
Limnoria
Linkstack
Littlelink Server
Liveswitch
Lldap
Logzio Logs Collector
Logzio Metrics Collector
Lollypop
Lychee
Magento 2
Magicmirror2
Magicmirror²
Mailpile
Maloja
Mariadb
- Mariadb Backups
Mastodon
- Matomo
Mautic
Mayan Edms
Mcmyadmin 2
Mealie
- Media Grabber Worker With Proxy
- Media Grabber Worker With Redis
Mediaelch
Medusa
Meilisearch
Meshcentral
Metube
Metube (Youtubedl)
Microsoft Oms Agent
Midarr
Minecraft Server
Minetest
- Miniflux
Minio
Minisatip
Mongo
Monica
Moodle
Mozilla Syncserver
Msedge
Mstream
Mullvad-Browser
Murmur
Musicbrainz
Muximux
Mylar
Mylar3
Mysql
Mysql-Workbench
N8N
Nano
Nano-Wallet
Navidrome
Neko
Netalertx
Netboot.Xyz
Netbox
Netdata
Nextcloud
Nextcloudstack
Nginx
Nginx Official
- Nginx Proxy Manager
Nginx Proxy Manager V2 With Sqlite And Goaccess Charts
Nginx Proxy Manager V2 With Sqllite
Nginx Proxy Manager V3 [Devel] Not Ready For Use
Ngircd
Nitter
Nocodb
Node Red
Nodejs
Nord-Vpn
Nut Server
- Nuts
Nzbget
Nzbhydra 2
Obsidian
Octoprint
Odoo
Omada Eap Controller
Ombi
Opc Router
Openamt
Openbudgeteer
Openfaas
Openssh-Server
Openvpn Access Server
Openvpn-As
Openvscode-Server
Opera
Orcaslicer
Organizr
Organizr V2
Ory Kratos (Oathkeeper)
Ory Kratos (Standalone)
Oscam
Overseerr
Owncloud
Pairdrop
Paperless Ngx
Paperless-Ng
Papermerge
Passbolt
Passky Client
Passky Server
Penpot (Http) {Shmolf}
Petio
Pgadmin
Photoprism
Photoshow
Phpmyadmin
Pi-Hole
Pi-Hole Doh/Dot
Pi-Hole-Unbound
Pi.Alert
Pidgin
Pingvin
Piper
Piwigo
Pixapop
Pixel-Server
Plane
Plesk
Plex
Plex Media Server
Plex Requests
Plex-Meta-Manager
Plextraktsync
Plone
Portainer Agent
- Poste.Io
Postgresql
Pritunl
Privatebin
Pro Mosquitto With Management Center
Projectsend
Protonmail Bridge
Prowlarr
- Proxitok
Pure-Ftp Server
- Pve-Exporter
Pwndrop
Pydio
Pydio-Cells
Pyload-Ng
Pylon
- Python
Qbittorrent
Qdirstat
Qflood
Quassel Irc
Quassel-Core
Quassel-Web
Rabbitmq
Radarr
Raneto
Raspberry Pi Docker Monitor
Rclone Config Backup
Rdesktop
Reactive-Resume
Readarr
- Readme-Sync
Redis
Redis Cluster
Redmine
Registry
Registry (Cache)
Remmina
- Remotely
Requestrr
Resilio Sync
Reveal.Js
Rocket Chat
- Roundcube Mail
Rport
Rsnapshot
Rustdesk
Rutorrent
Sabnzbd
Samba
Scality S3
Scrutiny
Seafile
Searxng
Sematext Docker Agent
Series-Troxide
Servas
Shaarli
Shiori
Shotcut
Sickchill
Sickgear
Sickrage
Signal Proxy
Silverstripe
Smokeping
Snapdrop
Snibox
Snipe-It
Snippet-Box
- Socket-Proxy
- Softing Edgeconnector 840D
- Softing Edgeconnector Aggregator
- Softing Edgeconnector Fanuc Cnc
- Softing Edgeconnector Modbus
- Softing Edgeconnector Siemens
Solr
Sonarr
Speedtest-Tracker
Spotube
Sql Server
Sql Server Express
Sqlitebrowser
Sshwifty
Stash
Statping
Steamos
Stirling Pdf {Shmolf}
Stirling-Pdf
- Strapi
- Surrealdb
Swag
Swarm Monitoring
- Switch Lan Play Server
Synclounge
Syncthing
Syslog-Ng
System Stats Oled Display
Tabby
Tailscale
Tandoor
Tautulli
Tdarr
Teleport
Terraria Server {Shmolf}
Tester
Testproject Agent Browser Stack
Thelounge
Tiddlywiki
Timetagger
Tiny Tiny Rss
Tooljet
Tosibox Lock For Container
Traefik
Traggo
Transmission
Transmission Openvpn Latest
Transmission Openvpn V3
Transmission-Openvpn
Trilium
Trudesk
Tubearchivist
Tvheadend
- Tvhproxy
Twitch Points Miner
Ubooquity
Ubuntu
Umami.Is
Unifi Controller
Unifi Video
Unifi-Network-Application
Unmanic
- Unrar
Upsnap
Uptime Kuma
Urbackup
Urlwatch
Vaultwarden
Vikunja
Vlmcsd - Kms
Vscodium
Vsftpd Ftp Server
Wallabag
- Wallabag + Sqlite
Wallbag
Watchtower
Watchtower {Shmolf}
Webcord
Webgrab+Plus
Webtop
Webtrees
Wger
Whisparr
Whoogle
Wikijs
- Wireguard
Wireguard Server
Wireshark
Wizarr
Wordpress
Wordpress + Mariadb
Wordpress + Mysql
Wowza
Wps-Office
Xbackbone
Xwiki
Yacht
Your_Spotify
Youtubedl-Material
- Yq
Znc
Zotero
Zus.Am
↕️ Click to Expand ↕️
Full credit to the authors of the following templates.
The main templates.json
file is composes of these sources, along with the content of the sources
directory.
template by @dnburgess
template by @Qballjos
template by @SelfhostedPro
template by @technorabilia
template by @mikestraney
template by @xneo1
template by @novaspirit
template by @donpablonow
template by @mediadepot
template by @mycroftwilde
template by @mediadepot
template by @shmolf
template by @portainer
template by @OliverCullimore
template by @AndyYangUK
If you notice something not working as it should in any of the lib/
scripts, website
code, README
documentation, or workflows
automations - then raise an issue or PR in this repository.
If you encounter an issue with any container included here, please raise a ticket/PR on the up-stream repo, not in this repository. This project simply compiles templates listed in the Sources into a single manifest, so once a fix has been pushed out upstream, it will be available here.
Contributions of any kind are very welcome, and would be much appreciated. For Code of Conduct, see Contributor Convent.
Not a coder? You can still help, by raising bugs you find, updating docs, or consider sponsoring me on GitHub
For a guide on adding templates, see the Editing section above (TLDR; either update sources.csv, or paste your template collection into the ./sources directory). Or, to make changes to the website, see the Website section below.
Before raising an issue or editing a template, please see the Raising Issues section above (TL;DR: changes need to be made upstream, NOT in this repo).
If you're new to open source, I've put together some guides in Git-In, but feel free to reach out if you need any support.
There's a simple website, which lists all available templates and shows stats, config options and installation instructions for each app / stack. You can view it at portainer-templates.netlify.app
The source is located in the website
branch, and it's build as a simple SSR Svelte app (using SvelteKit + TypeScript + SCSS + Vite).
To make changes to the website, you'll need Node.js and Git installed. Then just run the following commands:
git clone -b website [email protected]:phil-markarian/portainer-templates.git # Clone the website branch
cd portainer-templates # Navigate into the directory
npm i # Install dependencies
npm run dev # Start the development server
And to pubish, run npm run build
then either use npm start
or host the content of the '/build' directory using a web server of your choice. Alternatively, there's a Dockerfile, for easy deployment :)
Note that it's not required to make any changes to the website when adding a new template or templates source, as data is fetched directly from templates.json
in the repo's main branch - so should show up automatically once your changes are merged.
Here's your markdown updated with the auto-inserted content for apps and sources. This is assuming the content for apps and sources has been generated correctly as described:
Alicia Bot |
Alicia Sykes |
Nicholas Browning |
Benjamin Ranson |
Gilbert Palau |
Kartik Rao |
Lee Trout |
Pierre Balzack |
Note For licenses for each app listed here, see their websites (linked to above).
Lissy93/Portainer-Templates is licensed under MIT © Alicia Sykes 2023.
For information, see TLDR Legal > MIT
Expand License
The MIT License (MIT)
Copyright (c) Alicia Sykes <[email protected]>
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sub-license, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included
install copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANT ABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NON INFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
Additional Modifications Copyright (c) [2024] [Phil Markarian]
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
© Alicia Sykes 2023
Licensed under MIT
Thanks for visiting :)
Modifications by Phil Markarian © 2024
Licensed under MIT