Installation
A comprehensive guide for setting up Pyrodactyl using Docker
This comprehensive guide walks you through setting up Pyrodactyl using Docker, from scratch to a fully functional system.
For Pyrodactyl-specific issues, please use Pyrodactyl GitHub Discussions instead of Pterodactyl or Pelican support channels.
Install for Existing Pterodactyl in Docker Users
Always make sure you take a backup of your Pterodactyl database and other relevant data.
If you already have Pterodactyl running in Docker, simply update your panel image in your docker-compose.yml file:
You can swap back whenever you'd like.
Install for Existing Native Pterodactyl Users
Prerequisites
- Linux system with root access
- Docker Engine and Docker Compose installed
- Docker expertise and basic system administration skills
- Consider Portainer for easier Docker management
- Avoid using Snap-based Docker installations on Ubuntu
- Enable Docker auto-start on boot
Pyrodactyl Installation
-
Create a new folder (e.g. pyrodactyl-panel) on your server in a safe location, and switch to it.
-
Download and configure the docker-compose.example.yml
-
Modify placeholder variables under x-common
-
Add port 443 if you aren't using a reverse proxy for HTTPS. Also set LE_EMAIL under panel in x-common to an email you have used for certbot.
-
Copy the following environment variables from your Pterodactyl .env to your docker-compose.yml:
The following are only applicable if email is set up:
-
If your database is running on the same machine as your panel, set it to listen on the IP 172.17.0.1, and change the DB_HOST environment variable to 172.17.0.1.
-
Rename docker-compose.example.yml to docker-compose.yml
-
Run the following command to start the panel:
Your panel is now running! You can access it at the same URL as before, and use the same user accounts.
Non-Docker (Native migration)
The latest NodeJS LTS is required to be installed to migrate without Docker.
Simply follow the manual Pterodactyl updating guide.
However, on the Download the Update step, use these commands instead:
Prerequisites
- Linux system with root access
- Docker Engine and Docker Compose installed
- Docker expertise and basic system administration skills
- Consider Portainer for easier Docker management
- Avoid using Snap-based Docker installations on Ubuntu
- Enable Docker auto-start on boot
Windows is currently only supported for development purposes.
Fresh Installation
-
Download and configure the docker-compose.example.yml
- Modify placeholder variables under x-common
- Adjust exposed ports if needed
-
Create a new folder (e.g. pyrodactyl-panel) on your server in a safe location, and move or upload your edited compose file into it. Rename the file to docker-compose.yml
-
In terminal, cd into the directory, and run the following command to start the panel:
-
Run the command below, and go through its prompts to create an admin user:
-
Check that the panel is accessible using the IP address or domain of your server
Panel Configuration
-
Access the panel via your server's IP/domain and login to your previously created user
-
Navigate to admin panel (three dots menu → Admin)
-
Navigate to Locations, make a new location. It can have any name
-
Navigate to Nodes, create a new node
- FQDN is the domain or IP address (if you're not using HTTPS) of the server you're going to use as a backend
- You should make sure the daemon ports are free on your backend server
-
On the new node, go to the:
- Configuration tab: Copy the contents to /etc/pterodactyl/config.yml on your backend server
- Allocation tab: Add some allocations to use for your servers. The IP should be 0.0.0.0. If you want to show a different IP in the UI (e.g. a subdomain), add an alias. You can input a range of ports like 25565-26000
Wings Installation
In addition to the Pyrodactyl panel, you'll need Pterodactyl Wings as a backend for your servers, which we will also use Docker for. You can have multiple Wings instances on different servers, but for now, we're setting up just one.
-
Run the commands below to setup the compose for Wings:
-
Run the following command to start Wings:
-
Verify Wings status:
Post-Installation Steps
Email Configuration
For user password reset emails, etc, you'll need an SFTP server. For this, you can use:
Configure in Admin Panel → Settings
DDoS protection
If you're planning to have your server publicly accessible, your server could be vulnerable to DDoS attacks. Although not covered here due to its complexity, consider using:
The goal is to not have your server's IP address on any of your known domains.
Troubleshooting
If issues arise:
- Test with vanilla Pterodactyl by changing panel image to ghcr.io/pterodactyl/panel:latest
- Debug issues
- Switch back to Pyrodactyl image when resolved