Creating a new Panel

Time Required

30 Minutes

Difficulty

Easy

Installing the Panel

Setting up the Portainer stack

Create your Portainer stack using the below compose and .env file

I would recommend deploying GitOps (have a look at the this guide) as this will shift your compose file off of your server and into GitHub.

https://github.com/trentnbauer/agg/blob/main/docker-compose/pterodactyl-panel.yml
.ENV File
MYSQL_PASS=
MYSQL_PASS_ROOT=
PORT_HTTP=
MAIL_FROM=
MAIL_SERVER=smtp.gmail.com
MAIL_PORT=587
[email protected]
MAIL_PASS= #SMTP App Password https://www.febooti.com/products/automation-workshop/tutorials/enable-google-app-passwords-for-smtp.html
SUBDOMAIN= #the subdomain, including the . for your panel. Eg panel.
DOMAIN= #the domain for your panel, eg example.com
TZ= #your timezone
HASHIDS_SALT= #This MUST be a 20 character string, per https://github.com/pterodactyl/panel/issues/5012#issuecomment-1960789655

Confirm the Panel is running

Check the Portainer logs for the panel container, you should see something similar to below

Confirm the Login page loads

Browse to http://yourserver:port and confirm you see the below

Create your Admin user

  1. Open up Portainer and navigate to the Panel container

  2. Click on Console and change the command to '/bin/sh'

  3. Hit Connect

  4. Input the below command and next through the prompts (set account as administrator)

  1. Log into Pterodactyl with your newly created administrator account

Configure the Panel

Enforce 2FA

  1. Click on the Settings cog in the top right hand corner

  2. Click on Settings

  3. Set 'Require 2FA authentication' to 'All Users' and hit Save

  4. Click on 'Enable 2FA' and follow the steps

  5. Save your backup codes somewhere

Create Node Locations

  1. Click on Locations, then 'create new'

  2. Create 2 locations,

    1. a location for 'On Prem' nodes

    2. a location for 'Off Prem' nodes

Set up your Proxy

This step can be skipped thanks to the labels in the compose file, if you are using DockFlare

  1. Refer to the Cloudflare Proxy and Authentication guides

    • Your subdomain and domain need to match the APP_URL variable set on the container ( SUBDOMAIN+DOMAIN, eg panel.example.com )

    • Type is HTTP, pointing at yourserver:port

panel.example.com proxies to yourserver:port
  1. navigate to your proxy url and confirm you see the login page

Last updated

Was this helpful?