Nginx Proxy Manager On Docker

Nginx Proxy Manager Docker Container On Raspberry Pi 4

·

7 min read

Nginx Proxy Manager On Docker

Introduction

Nginx Proxy Manager (NPM) is an easy way to accomplish reverse proxying hosts with SSL termination and as the author puts it "It has to be so easy that a monkey could do it".

Screenshot

NPM Screenshot

Installation

Pre-Installation Steps

  • Folder Setup Script

The first thing we need to do is set up the folder structure and install some files that need to be in place for everything to work correctly.

Run the following script

wget -qO- https://raw.githubusercontent.com/akkupy/Homelab/main/scripts/install_nginx_proxy_manager.sh | bash

Your output should look something like this

# wget -qO- https://raw.githubusercontent.com/akkupy/Homelab/main/scripts/install_nginx_proxy_manager.sh | bash
Creating directories...
Creating a blank nginx-proxy-manager config files
Creating a blank docker compose file
Pre-installaton complete.

Now we need to move into that directory using the following:

cd /home/$USER/nginx-proxy-manager

We now need to open the config.json file using the nano editor so we can input some data.

nano config.json

Copy and paste the following into the file.

Note: Replace all “changeme” values with something unique and secure.

{
  "database": {
    "engine": "mysql",
    "host": "db",
    "name": "npm",
    "user": "changeme",
    "password": "changeme",
    "port": 3306
  }
}

Once you have done that press “Ctrl + X” then Y to save and “Enter” to exit the nano editor.

We now need to open the docker-compose.yml file using the nano editor.

nano docker-compose.yml

Copy and paste the below data into the docker-compose.yml file.

Like before change all “changeme” values to match the same as set in the config.json file.

Note: Create a new password for MYSQL_ROOT_PASSWORD.

version: '3'
services:
  app:
    image: 'jc21/nginx-proxy-manager:latest'
    restart: unless-stopped
    ports:
      - '80:80'
      - '81:81'
      - '443:443'
    environment:
      DB_MYSQL_HOST: "db"
      DB_MYSQL_PORT: 3306
      DB_MYSQL_USER: "changeme"
      DB_MYSQL_PASSWORD: "changeme"
      DB_MYSQL_NAME: "npm"
    volumes:
      - ./data:/data
      - ./letsencrypt:/etc/letsencrypt
  db:
    image: 'jc21/mariadb-aria:latest'
    restart: unless-stopped
    environment:
      MYSQL_ROOT_PASSWORD: 'changeme'
      MYSQL_DATABASE: 'npm'
      MYSQL_USER: 'changeme'
      MYSQL_PASSWORD: 'changeme'
    volumes:
      - ./data/mysql:/var/lib/mysql

Once you have done that press “Ctrl + X” then Y to save and “Enter” to exit the nano editor.

To deploy the dockers run the following command:

sudo docker-compose up -d

This will take some time to finish.

Once complete you can check that the docker containers exist by typing the following:

sudo docker ps

Or you can check in Portainer by logging in via your browser and navigating to “Containers“.

If you see any problems like “unhealthy” Please restart the container and all should be well.

After the containers are healthy or running, Proceed to the next steps.

We want to select nginx-proxy-manager from the list of containers. This will display lots of information regarding your container.

You will notice 3 ports listed. Port 80, 443, and Port 81. Ports 80 and 443 are for managing your services and really shouldn't be changed. Port 81 is for managing your lists of hosts. It can be changed but for this install, we are going to assume it to be port 81.

It is important before you go to the next step that you get your public IP forwarded through your firewall for ports 80 and 443 to your NPM install. You also need to have your DNS pointing at the IP address. There are many ways to do this and outside the scope of this install document. If you are not sure where to start feel free to log in to the Discord chat and ask someone will help point you at different options for your setup.

Post Install Setup

Login to the site

Now that it is installed let's set up our first proxy host. The first thing we need to do is log in to the site. Click on port 81 in the list and you will see the login screen below.

Login

The Default Email Address is: admin@example.com The Default Password is: changeme

Please login and we will then change those to our settings.

If you get a Bad Gateway error you likely forgot to run the script on the host to set up the folders/files first although it can also happen if you leave one of the database password blank as well. Delete the Stack and start back from the beginning.

First Login

Update Your Email address and Password

First, we need to select the User menu and select Edit Details

User Menu

Fix your user information and save the changes.

User Menu

Now it is time to change your password. Select the User menu again and select Change Password

User Menu

Set the password to something you like and save the changes.

User Menu

Update Default Screen

When going to the proxy with a new domain or in some cases where you used *wildcard DNS and someone goes using a DNS you don't have set setup yet they will see the default screen. By default, this is the Congratulations Screen as shown below. It is useful for confirming you are set up correctly but in production, I prefer a 404 page or a custom page of some kind so we will go through how to set that up.

  • Wildcard DNS can have security issues make sure you reach these before using them.

Congratulations Screen

We start by going to the Settings Tab

Settings Screen

Click on the 3 dots and select Edit from the list.

3 Dots Screen

You will now be shown the different options you can select for your default screen. You can have it display a 404 page, a Custom Page, or simply redirect depending on your preference. This is entirely up to you. I prefer to use a 404 screen so I am going to set that now.

Setting Edit Screen

There we are with the default being a 404 page.

Settings Screen with 404

So now when someone goes to a site that isn't setup yet they will see a 404 page.

404 Page

Great Nginx Proxy Manager is now all set up. In the next sections, we are going to walk through setting up your first proxy host.

First Proxy Host Setup

We are now back to the first login screen.

First Login

Select Hosts > Proxy Hosts

Proxy Hosts

Select Add Proxy Hosts

Proxy Hosts

We need to enter the proxy information. In this example, we are going to use the following information.

Secure External connections to the service using https.
Domain Name: homer.example.com
Scheme: http
Forward Hostname/IP address: 192.168.1.23
Port: 8902
Cache Assets: Disabled
Block Common Exploits: Disabled
Websockets Support: Disabled
Access List: Publicly Accessible

Most of these options should be self-explanatory if you aren't sure what they do it is likely best to leave them disabled.

The most important options.

Domain Name is the public Domain name that will point at your host.
Forward Hostname/IP is the server running the resource.
Port is the port the service is running on that server.

Two options you might want to enable are Cache Assets and Block Common Exploits they will help protect and reduce the load on your sites but they can cause problems for some sites so be aware of this before enabling.

Some applications will use WebSockets if the app uses this you will need to enable it but very few applications do so. To put it simply if you don't know what it is, then leave it disabled.

Proxy Hosts

Hint: Generating Certificates can be complicated I will be outlining one of the simplest ways to generate one. There are other ways not outlined here.

Now we need to set up our secure https connection to the server. Select the SSL tab.

Method 1(Recommended for internet based usage):

Under SSL Certificates we are going to select Request a new SSL Certificate.

I am also going to select Force SSL this will prevent non-secure connections from being used.

I will agree to the terms after reading them you should at least review them once so you understand the terms of service.

It should have your correct email address listed if it doesn't please fix it as this is where you will get alerts if there is an issue with the Certificate.

Proxy Hosts

Once you click Save it will generate a new certificate this can take a few minutes to do.

Method 2(Recommended for Local usage and usage with tailscale):

You can use a self-generated SSL certificate(which can be generated here).In this case, select Custom under the SSL Certificates and upload the key and certificate generated.

Post SSL Certificate Generation

Assuming there are no errors your new host has been created and you will be returned to the proxy host screen. Below is an example of what the screen will look like with several hosts added.

NPM Screenshot

Additional documentation

Additional documentation can be found here.

(Optional): Configure Reverse Proxy using the documentation here.

Did you find this article valuable?

Support Akash S by becoming a sponsor. Any amount is appreciated!