Server Hosting
Nginx Proxy Manager

Nginx Proxy Manager

Introduction

Nginx Proxy Manager (opens in a new tab) is a powerful tool that allows you to manage Nginx configurations through a web interface. This guide will walk you through installing NPM on proxmox and setting up a reverse proxy to route traffic to your applications via Cloudflare. By following these steps, you'll be able to manage your Nginx configurations with ease and securely host multiple applications on your server. Let's get started!

For more detailed information and official documentation, you can visit the Nginx Proxy Manager documentation (opens in a new tab) or the Proxmox VE Helper-Scripts documentation (opens in a new tab).

Prerequisites

Before you begin, ensure you have the following:

Step-by-Step Guide

Install Nginx Proxy Manager

Open a new terminal on your Proxmox server and run the following command to install Nginx Proxy Manager, using Proxmox VE Helper-Scripts:

Follow the instructions on the screen to complete the installation.

We recommend using the default settings for the installation process.

However, advanced users can customize the installation by choosing the advanced installation option.

⚡ Default Settings: 1GB RAM - 3GB Storage - 1vCPU ⚡

bash -c "$(wget -qLO - https://github.com/tteck/Proxmox/raw/main/ct/nginxproxymanager.sh)"
⚠️

You MUST forward ports 80 and 443 from your router to your Nginx Proxy Manager IP address.

This is required for the SSL certificate to be issued by Let's Encrypt, and to route traffic to your applications.

To access the NPM web interface from your browser, navigate to http://<your-npm-server-ip>:81.

The default login credentials are:

  • Username: admin@example.com
  • Password: changeme

After logging in, you will be prompted to change your password. We also recommend changing the default email address to your own.

Configure Cloudflare DNS

Once you have registered your domain with Cloudflare, you need to configure your DNS settings to route traffic to your NPM server.

Head over to your Cloudflare dashboard (opens in a new tab), select your domain, and navigate to the DNS tab on the left. From here click on the Add Record button and create an A record with the following details:

This record will be the root record for your domain.

  • Name: For the root domain, enter @
  • IPv4 Address: Enter your Public IP address, which you can find here (opens in a new tab).
  • Proxy Status: Leave the Proxy status as Proxied.
  • TTL: May be left as Auto.
  • You may want to add a comment for future reference.

Click on the Save button to create the record.

Add NPM Subdomain

⚠️

We DO NOT recommend using a public subdomain for Nginx Proxy Manager.

To create a subdomain for Nginx Proxy Manager, click on the Add Record button. In the Type dropdown, select CNAME and enter the following details:

  • Name: Enter a subdomain name, such as npm or proxy.
  • Target: Enter your domain name, e.g., example.com or simply enter @.
  • Proxy Status: Leave the Proxy status as Proxied.
  • TTL: May be left as Auto.
  • You may want to add a comment for future reference.

Click on the Save button to create the record.

This will point your subdomain to your Public IP address of your router, which will then forward the traffic to your NPM server, via the ports your have forwarded, in this step of the guide.

Create Cloudflare API Token

You can find this in your Cloudflare account under My Profile > API Tokens. Click on the Create Token button and select the Edit zone DNS template for the token.

Ensure it has the following details:

  • Token name: Enter a name for the token.
  • Permissions Click + Add more and select the following permissions:
    • Zone - DNS - Edit
    • Zone - Zone - Read
  • Zone Resources Select the domain you wish to use for the token.

Click Continue to Summary and then Create Token. Copy the token and save it in a secure location.

Configure Nginx Proxy Manager

Next, log back into your Nginx Proxy Manager web interface and navigate to the Proxy Hosts tab. Click on the Add Proxy Host button to create a new host.

💡

We will now create a host for your Pterodactyl Panel.

However, you can use this process to create hosts for any application you wish to route traffic to.

Fill in the following details:

  • Domain Names: Enter the subdomain you wish to use for the Pterodactyl Panel, e.g., panel.example.com.
  • Scheme: Select https.
  • Forward Hostname/IP: Enter the IP address of your Pterodactyl Panel server. (NOT the Wings server)
  • Forward Port: Enter the port your Pterodactyl Panel is running on, e.g., 80 by default.
  • Block Common Exploits: Enable this option if you plan to share the domain publicly.
  • Websockets Support: This option, is required only on the Wings, not on the Panel itself and therefore, can be left off.
  • Leave the rest of the settings as default.

Next, click on the SSL tab and from the SSL Certificate dropdown, select Request a new SSL Certificate. This will automatically request a new SSL certificate from Let's Encrypt for your domain.

Toggle the Use a DNS Challenge option, and fill in the following details:

  • DNS Provider: Select Cloudflare.
  • Credentials File Content: Set the dns_cloudflare_api_token to your Cloudflare API token. How to get your Cloudflare API token.
  • Email Address for Let's Encrypt: Enter your email address.

Toggle the I Agree to the Let's Encrypt Terms of Serivce option and click Save.

Conclusion

That's it! You have successfully set up Nginx Proxy Manager on your Proxmox server and configured a proxy host. You can now securely access your host by navigating to the proxy host domain name, e.g., https://panel.example.com.

Happy Hosting!