Updated documentation, installation instructions and examples

This commit is contained in:
Jamie Curnow 2019-05-10 15:26:12 +10:00
parent 06272d3d2c
commit 2d0f7d5126
5 changed files with 68 additions and 83 deletions

View File

@ -6,6 +6,7 @@
![Stars](https://img.shields.io/docker/stars/jc21/nginx-proxy-manager.svg?style=for-the-badge) ![Stars](https://img.shields.io/docker/stars/jc21/nginx-proxy-manager.svg?style=for-the-badge)
![Pulls](https://img.shields.io/docker/pulls/jc21/nginx-proxy-manager.svg?style=for-the-badge) ![Pulls](https://img.shields.io/docker/pulls/jc21/nginx-proxy-manager.svg?style=for-the-badge)
[nginxproxymanager.jc21.com](https://nginxproxymanager.jc21.com)
[View on Github](https://github.com/jc21/nginx-proxy-manager) [View on Github](https://github.com/jc21/nginx-proxy-manager)
This project comes as a pre-built docker image that enables you to easily forward to your websites This project comes as a pre-built docker image that enables you to easily forward to your websites
@ -15,16 +16,18 @@ running at home or otherwise, including free SSL, without having to know too muc
## Tags ## Tags
* latest 2, 2.x.x ([Dockerfile](https://github.com/jc21/nginx-proxy-manager/blob/master/Dockerfile)) * latest 2, 2.x.x ([Dockerfile](https://github.com/jc21/nginx-proxy-manager/blob/master/Dockerfile))
* latest-armhf, 2-armhf, 2.x.x-armhf ([Dockerfile](https://github.com/jc21/nginx-proxy-manager/blob/master/Dockerfile.armhf))
* latest-arm64, 2-arm64, 2.x.x-arm64 ([Dockerfile](https://github.com/jc21/nginx-proxy-manager/blob/master/Dockerfile.arm64)) * latest-arm64, 2-arm64, 2.x.x-arm64 ([Dockerfile](https://github.com/jc21/nginx-proxy-manager/blob/master/Dockerfile.arm64))
* 1, 1.x.x ([Dockerfile](https://github.com/jc21/nginx-proxy-manager/blob/1.1.2/Dockerfile)) * latest-arm7l, 2-arm7l, 2.x.x-arm7l ([Dockerfile](https://github.com/jc21/nginx-proxy-manager/blob/master/Dockerfile.arm7l))
* 1-armhf, 1.x.x-armhf ([Dockerfile](https://github.com/jc21/nginx-proxy-manager/blob/1.1.2/Dockerfile.armhf))
## Getting started ## Getting started
Please consult the [installation instructions](https://github.com/jc21/nginx-proxy-manager/blob/master/doc/INSTALL.md) for a complete guide or Please consult the [installation instructions](https://github.com/jc21/nginx-proxy-manager/blob/master/doc/INSTALL.md) for a complete guide or
if you just want to get up and running in the quickest time possible, grab all the files in the [doc/example/](https://github.com/jc21/nginx-proxy-manager/tree/master/doc/example) folder and run `docker-compose up -d` if you just want to get up and running in the quickest time possible, grab all the files in the [doc/example/](https://github.com/jc21/nginx-proxy-manager/tree/master/doc/example) folder and run:
```bash
docker-compose up -d
```
## Screenshots ## Screenshots

View File

@ -1,9 +1,13 @@
## Installation and Configuration ## Installation and Configuration
There's a few ways to configure this app depending on: If you just want to get up and running in the quickest time possible, grab all the files in
the [doc/example/](https://github.com/jc21/nginx-proxy-manager/tree/master/doc/example)
folder and run:
```bash
docker-compose up -d
```
- Whether you use `docker-compose` or vanilla docker
- Which architecture you're running it on (raspberry pi also supported - Testers wanted!)
### Configuration File ### Configuration File
@ -13,22 +17,22 @@ Don't worry, this is easy to do.
The app requires a configuration file to let it know what database you're using. The app requires a configuration file to let it know what database you're using.
Here's an example configuration for `mysql` (or mariadb): Here's an example configuration for `mysql` (or mariadb) that is compatible with the docker-compose example below:
```json ```json
{ {
"database": { "database": {
"engine": "mysql", "engine": "mysql",
"host": "127.0.0.1", "host": "db",
"name": "nginxproxymanager", "name": "npm",
"user": "nginxproxymanager", "user": "npm",
"password": "password123", "password": "npm",
"port": 3306 "port": 3306
} }
} }
``` ```
Once you've created your configuration file it's easy to mount it in the docker container, examples below. Once you've created your configuration file it's easy to mount it in the docker container.
**Note:** After the first run of the application, the config file will be altered to include generated encryption keys unique to your installation. These keys **Note:** After the first run of the application, the config file will be altered to include generated encryption keys unique to your installation. These keys
affect the login and session management of the application. If these keys change for any reason, all users will be logged out. affect the login and session management of the application. If these keys change for any reason, all users will be logged out.
@ -36,37 +40,13 @@ affect the login and session management of the application. If these keys change
### Database ### Database
This app doesn't come with a database, you have to provide one yourself. Currently only `mysql/mariadb` is supported. This app doesn't come with a database, you have to provide one yourself. Currently only `mysql/mariadb` is supported for the minimum versions:
It's easy to use another docker container for your database also and link it as part of the docker stack. Here's an example: - MySQL v5.7.8+
- MariaDB v10.2.7+
```yml It's easy to use another docker container for your database also and link it as part of the docker stack, so that's what the following examples
version: "3" are going to use.
services:
app:
image: jc21/nginx-proxy-manager:latest
restart: always
ports:
- 80:80
- 81:81
- 443:443
volumes:
- ./config.json:/app/config/production.json
- ./data:/data
- ./letsencrypt:/etc/letsencrypt
depends_on:
- db
db:
image: jc21/mariadb-aria
restart: always
environment:
MYSQL_ROOT_PASSWORD: "password123"
MYSQL_DATABASE: "nginxproxymanager"
MYSQL_USER: "nginxproxymanager"
MYSQL_PASSWORD: "password123"
volumes:
- ./data/mysql:/var/lib/mysql
```
### Running the App ### Running the App
@ -80,48 +60,51 @@ services:
image: jc21/nginx-proxy-manager:latest image: jc21/nginx-proxy-manager:latest
restart: always restart: always
ports: ports:
# Public HTTP Port:
- 80:80 - 80:80
- 81:81 # Public HTTPS Port:
- 443:443 - 443:443
# Admin Web Port:
- 81:81
volumes: volumes:
# Make sure this config.json file exists as per instructions above:
- ./config.json:/app/config/production.json - ./config.json:/app/config/production.json
- ./data:/data - ./data:/data
- ./letsencrypt:/etc/letsencrypt - ./letsencrypt:/etc/letsencrypt
depends_on:
- db
db:
image: mariadb
restart: always
environment:
MYSQL_ROOT_PASSWORD: "npm"
MYSQL_DATABASE: "npm"
MYSQL_USER: "npm"
MYSQL_PASSWORD: "npm"
volumes:
- ./data/mysql:/var/lib/mysql
``` ```
Vanilla Docker: Then:
```bash ```bash
docker run -d \ docker-compose up -d
--name nginx-proxy-manager \
-p 80:80 \
-p 81:81 \
-p 443:443 \
-v /path/to/config.json:/app/config/production.json \
-v /path/to/data:/data \
-v /path/to/letsencrypt:/etc/letsencrypt \
jc21/nginx-proxy-manager:latest
``` ```
### Running on Raspberry PI / `armhf` ### Running on Raspberry PI / ARM devices
I have created `armhf` and `arm64` docker containers just for you. There may be issues with it, There are docker images for all versions of the Rasberry Pi with the exception of the really old `armv6l` versions.
if you have issues please report them here.
Note: Rpi v2 and below won't work with these images. The `latest` docker image is a manifest of all the different architecture docker builds supported, so this means
you don't have to worry about doing anything special and you can follow the common instructions above.
```bash Check out the [dockerhub tags](https://cloud.docker.com/repository/registry-1.docker.io/jc21/nginx-proxy-manager/tags)
docker run -d \ for a list of supported architectures and if you want one that doesn't exist,
--name nginx-proxy-manager-app \ [create a feature request](https://github.com/jc21/nginx-proxy-manager/issues/new?assignees=&labels=enhancement&template=feature_request.md&title=).
-p 80:80 \
-p 81:81 \ Also, if you don't know how to already, follow [this guide to install docker and docker-compose](https://manre-universe.net/how-to-run-docker-and-docker-compose-on-raspbian/)
-p 443:443 \ on Raspbian.
-v /path/to/config.json:/app/config/production.json \
-v /path/to/data:/data \
-v /path/to/letsencrypt:/etc/letsencrypt \
jc21/nginx-proxy-manager:latest-armhf
```
### Initial Run ### Initial Run
@ -162,4 +145,3 @@ value by specifying it as a Docker environment variable. The default if not spec
``` ```
... -e "X_FRAME_OPTIONS=sameorigin" ... ... -e "X_FRAME_OPTIONS=sameorigin" ...
``` ```

View File

@ -2,9 +2,9 @@
"database": { "database": {
"engine": "mysql", "engine": "mysql",
"host": "db", "host": "db",
"name": "nginxproxymanager", "name": "npm",
"user": "nginxproxymanager", "user": "npm",
"password": "password123", "password": "npm",
"port": 3306 "port": 3306
} }
} }

View File

@ -1,7 +1,7 @@
version: "3" version: "3"
services: services:
app: app:
image: jc21/nginx-proxy-manager:2 image: jc21/nginx-proxy-manager:latest
restart: always restart: always
ports: ports:
- 80:80 - 80:80
@ -17,12 +17,12 @@ services:
# if you want pretty colors in your docker logs: # if you want pretty colors in your docker logs:
- FORCE_COLOR=1 - FORCE_COLOR=1
db: db:
image: jc21/mariadb-aria image: mariadb:latest
restart: always restart: always
environment: environment:
MYSQL_ROOT_PASSWORD: "password123" MYSQL_ROOT_PASSWORD: "npm"
MYSQL_DATABASE: "nginxproxymanager" MYSQL_DATABASE: "npm"
MYSQL_USER: "nginxproxymanager" MYSQL_USER: "npm"
MYSQL_PASSWORD: "password123" MYSQL_PASSWORD: "npm"
volumes: volumes:
- ./data/mysql:/var/lib/mysql - ./data/mysql:/var/lib/mysql

View File

@ -4,9 +4,9 @@ services:
app: app:
image: jc21/nginx-proxy-manager-base:latest image: jc21/nginx-proxy-manager-base:latest
ports: ports:
- 8080:80 - 80:80
- 8081:81 - 81:81
- 8443:443 - 43:443
environment: environment:
- NODE_ENV=development - NODE_ENV=development
- FORCE_COLOR=1 - FORCE_COLOR=1
@ -22,7 +22,7 @@ services:
- db - db
command: node --max_old_space_size=250 --abort_on_uncaught_exception node_modules/nodemon/bin/nodemon.js command: node --max_old_space_size=250 --abort_on_uncaught_exception node_modules/nodemon/bin/nodemon.js
db: db:
image: mariadb:10.3.7 image: jc21/mariadb-aria
environment: environment:
MYSQL_ROOT_PASSWORD: "npm" MYSQL_ROOT_PASSWORD: "npm"
MYSQL_DATABASE: "npm" MYSQL_DATABASE: "npm"