diff --git a/Dockerfile b/Dockerfile index a3f45064e..c868153e7 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,4 +1,4 @@ -FROM jc21/nginx-proxy-manager-base:latest +FROM ohheyalan/nginx_proxy_manager_layer_1:latest MAINTAINER Jamie Curnow LABEL maintainer="Jamie Curnow " @@ -37,3 +37,5 @@ EXPOSE 9876 HEALTHCHECK --interval=15s --timeout=3s CMD curl -f http://localhost:9876/health || exit 1 +# Print built version +RUN nginx -V diff --git a/doc/DOCKERHUB.md b/doc/DOCKERHUB.md index ca66f3d72..0e1edcea7 100644 --- a/doc/DOCKERHUB.md +++ b/doc/DOCKERHUB.md @@ -1,6 +1,6 @@ ![Nginx Proxy Manager](https://public.jc21.com/nginx-proxy-manager/github.png "Nginx Proxy Manager") -# Nginx Proxy Manager +# [Nginx Proxy Manager](https://nginxproxymanager.jc21.com) ![Version](https://img.shields.io/badge/version-2.0.13-green.svg?style=for-the-badge) ![Stars](https://img.shields.io/docker/stars/jc21/nginx-proxy-manager.svg?style=for-the-badge) @@ -14,17 +14,19 @@ running at home or otherwise, including free SSL, without having to know too muc ## Tags -* 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 2, 2.x.x ([Dockerfile](https://github.com/jc21/nginx-proxy-manager/blob/master/Dockerfile)) * 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)) -* 1-armhf, 1.x.x-armhf ([Dockerfile](https://github.com/jc21/nginx-proxy-manager/blob/1.1.2/Dockerfile.armhf)) +* latest-arm7l, 2-arm7l, 2.x.x-arm7l ([Dockerfile](https://github.com/jc21/nginx-proxy-manager/blob/master/Dockerfile.arm7l)) ## Getting started 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 diff --git a/doc/INSTALL.md b/doc/INSTALL.md index 3b06e4106..ad74c08d1 100644 --- a/doc/INSTALL.md +++ b/doc/INSTALL.md @@ -1,9 +1,13 @@ ## 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 @@ -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. -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 { "database": { "engine": "mysql", - "host": "127.0.0.1", - "name": "nginxproxymanager", - "user": "nginxproxymanager", - "password": "password123", + "host": "db", + "name": "npm", + "user": "npm", + "password": "npm", "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 affect the login and session management of the application. If these keys change for any reason, all users will be logged out. @@ -36,9 +40,18 @@ affect the login and session management of the application. If these keys change ### 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: + +- MySQL v5.7.8+ +- MariaDB v10.2.7+ + +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 +are going to use. -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: + +### Running the App + +Via `docker-compose`: ```yml version: "3" @@ -47,81 +60,51 @@ services: image: jc21/nginx-proxy-manager:latest restart: always ports: + # Public HTTP Port: - 80:80 - - 81:81 + # Public HTTPS Port: - 443:443 + # Admin Web Port: + - 81:81 volumes: + # Make sure this config.json file exists as per instructions above: - ./config.json:/app/config/production.json - ./data:/data - ./letsencrypt:/etc/letsencrypt depends_on: - db db: - image: jc21/mariadb-aria + image: mariadb restart: always environment: - MYSQL_ROOT_PASSWORD: "password123" - MYSQL_DATABASE: "nginxproxymanager" - MYSQL_USER: "nginxproxymanager" - MYSQL_PASSWORD: "password123" + MYSQL_ROOT_PASSWORD: "npm" + MYSQL_DATABASE: "npm" + MYSQL_USER: "npm" + MYSQL_PASSWORD: "npm" volumes: - ./data/mysql:/var/lib/mysql ``` - -### Running the App - -Via `docker-compose`: - -```yml -version: "3" -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 -``` - -Vanilla Docker: +Then: ```bash -docker run -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 +docker-compose up -d ``` -### 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, -if you have issues please report them here. +There are docker images for all versions of the Rasberry Pi with the exception of the really old `armv6l` versions. -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 -docker run -d \ - --name nginx-proxy-manager-app \ - -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-armhf -``` +Check out the [dockerhub tags](https://cloud.docker.com/repository/registry-1.docker.io/jc21/nginx-proxy-manager/tags) +for a list of supported architectures and if you want one that doesn't exist, +[create a feature request](https://github.com/jc21/nginx-proxy-manager/issues/new?assignees=&labels=enhancement&template=feature_request.md&title=). + +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/) +on Raspbian. ### 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" ... ``` - diff --git a/doc/example/config.json b/doc/example/config.json index dfc9f049d..64ab577c8 100644 --- a/doc/example/config.json +++ b/doc/example/config.json @@ -2,9 +2,9 @@ "database": { "engine": "mysql", "host": "db", - "name": "nginxproxymanager", - "user": "nginxproxymanager", - "password": "password123", + "name": "npm", + "user": "npm", + "password": "npm", "port": 3306 } } diff --git a/doc/example/docker-compose.yml b/doc/example/docker-compose.yml index 4547bbc1f..e6707b957 100644 --- a/doc/example/docker-compose.yml +++ b/doc/example/docker-compose.yml @@ -1,7 +1,7 @@ version: "3" services: app: - image: jc21/nginx-proxy-manager:2 + image: jc21/nginx-proxy-manager:latest restart: always ports: - 80:80 @@ -17,12 +17,12 @@ services: # if you want pretty colors in your docker logs: - FORCE_COLOR=1 db: - image: jc21/mariadb-aria + image: mariadb:latest restart: always environment: - MYSQL_ROOT_PASSWORD: "password123" - MYSQL_DATABASE: "nginxproxymanager" - MYSQL_USER: "nginxproxymanager" - MYSQL_PASSWORD: "password123" + MYSQL_ROOT_PASSWORD: "npm" + MYSQL_DATABASE: "npm" + MYSQL_USER: "npm" + MYSQL_PASSWORD: "npm" volumes: - ./data/mysql:/var/lib/mysql diff --git a/docker-compose.yml b/docker-compose.yml index 2ff821b21..ab50c910a 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -4,9 +4,9 @@ services: app: image: jc21/nginx-proxy-manager-base:latest ports: - - 8080:80 - - 8081:81 - - 8443:443 + - 80:80 + - 81:81 + - 43:443 environment: - NODE_ENV=development - FORCE_COLOR=1 @@ -22,7 +22,7 @@ services: - db command: node --max_old_space_size=250 --abort_on_uncaught_exception node_modules/nodemon/bin/nodemon.js db: - image: mariadb:10.3.7 + image: jc21/mariadb-aria environment: MYSQL_ROOT_PASSWORD: "npm" MYSQL_DATABASE: "npm"