2
0

nginx-proxy sets up a container running nginx and docker-gen⁠ https://hub.docker.com/r/nginxproxy/nginx-proxy

Niek 1baf048a6e build: bump nginx 1.27.0 to 1.27.1 (#2506) 9 сар өмнө
.github 261ac6f43b ci: bump docker/build-push-action from 5 to 6 11 сар өмнө
app de4cb3d2b0 refactor: move nginx daemon off to procfile 1 жил өмнө
docs 705dfa090b docs: update version in README.md 1 жил өмнө
test 1baf048a6e build: bump nginx 1.27.0 to 1.27.1 (#2506) 9 сар өмнө
.dockerignore 4ea3437dfa chore: include license into the Docker images 3 жил өмнө
.gitignore 98b5828f83 Modified tests to include dhparams 8 жил өмнө
Dockerfile.alpine 1baf048a6e build: bump nginx 1.27.0 to 1.27.1 (#2506) 9 сар өмнө
Dockerfile.debian 1baf048a6e build: bump nginx 1.27.0 to 1.27.1 (#2506) 9 сар өмнө
LICENSE 679c971a19 docs: update maintainers list on license 3 жил өмнө
Makefile db55ddcab4 ci: use build matrix rather than separate jobs 1 жил өмнө
README.md 1baf048a6e build: bump nginx 1.27.0 to 1.27.1 (#2506) 9 сар өмнө
docker-compose-separate-containers.yml 060f09cfce ci: ensure all compose files are valid compose v2 + formatting 1 жил өмнө
docker-compose.yml 8c95ed1cc0 docs: add comment about host network to compose example 1 жил өмнө
network_internal.conf 28c74e8dae fix: Move NETWORK_ACCESS to location block 3 жил өмнө
nginx.tmpl c5f054ed36 fix: limit exposed ports in template comment to 10 (#2494) 10 сар өмнө

README.md

Test GitHub release nginx 1.27.1 Docker Image Size Docker stars Docker pulls

nginx-proxy sets up a container running nginx and docker-gen. docker-gen generates reverse proxy configs for nginx and reloads nginx when containers are started and stopped.

See Automated Nginx Reverse Proxy for Docker for why you might want to use this.

Usage

To run it:

docker run --detach \
    --name nginx-proxy \
    --publish 80:80 \
    --volume /var/run/docker.sock:/tmp/docker.sock:ro \
    nginxproxy/nginx-proxy:1.6

Then start any containers (here an nginx container) you want proxied with an env var VIRTUAL_HOST=subdomain.yourdomain.com

docker run --detach \
    --name your-proxied-app \
    --env VIRTUAL_HOST=foo.bar.com \
    nginx

Provided your DNS is setup to resolve foo.bar.com to the host running nginx-proxy, a request to http://foo.bar.com will then be routed to a container with the VIRTUAL_HOST env var set to foo.bar.com (in this case, the your-proxied-app container).

The containers being proxied must :

  • expose the port to be proxied, either by using the EXPOSE directive in their Dockerfile or by using the --expose flag to docker run or docker create.
  • share at least one Docker network with the nginx-proxy container: by default, if you don't pass the --net flag when your nginx-proxy container is created, it will only be attached to the default bridge network. This means that it will not be able to connect to containers on networks other than bridge.

Note: providing a port number in VIRTUAL_HOST isn't suported, please see virtual ports or custom external HTTP/HTTPS ports depending on what you want to achieve.

Image variants

The nginx-proxy images are available in two flavors.

Debian based version

This image is based on the nginx:mainline image, itself based on the debian slim image.

docker pull nginxproxy/nginx-proxy:1.6

Alpine based version (-alpine suffix)

This image is based on the nginx:alpine image.

docker pull nginxproxy/nginx-proxy:1.6-alpine

:warning: a note on latest and alpine:

It is not recommended to use the latest (nginxproxy/nginx-proxy, nginxproxy/nginx-proxy:latest) or alpine (nginxproxy/nginx-proxy:alpine) tag for production setups.

Those tags point to the latest commit in the main branch. They do not carry any promise of stability, and using them will probably put your nginx-proxy setup at risk of experiencing uncontrolled updates to non backward compatible versions (or versions with breaking changes). You should always specify the version you want to use explicitly to ensure your setup doesn't break when the image is updated.

Additional documentation

Please check the docs section.