This is a solution of a common problem with Nexus Docker repositories. The administrator has to expose port for "pull", another port for "push", other ports for each hosted repository. This solution is about leveraging Nginx reverse proxy to avoid using these ports.
Given :
- Nexus hostname is "nexus.example.com"
- Nexus web port is 8081
- A hosted repository is named "docker-hosted"
- A group repository is named "docker-group"
- Your nginx (with the nginx.conf of this gist) will run for example under cregistry.example.com
The following Nginx configuration file is for a reverse proxy without the need to expose connector ports from nexus :
docker pull cregistry.example.com/myimage
lets Nginx forward the request to "docker-group"docker push cregistry.example.com/myimage
lets Nginx forward the request to "docker-hosted"
-
If you have more than one hosted repository, create another Nginx reverse proxy for it, then aggregate them using a parent Nginx reverse proxy that forwards the request according to certain criteria (.i.e: Host header).
-
All Nexus repositories must have consistent configuration of authentication: Either all require authentication, or all don't.
-
If TLS is enabled with Nexus, change
proxy_set_header X-Forwarded-Proto "http";
byproxy_set_header X-Forwarded-Proto "https";
The following Docker pulls are working as expected:
docker pull nexus-repo.de/docker-snapshot-local/final:test ✔️
docker pull nexus-repo.de/docker/nginx:latest ✔️
docker pull nexus-repo.de/docker/docker-snapshot-local/final:test ✔️
However, I'm encountering an issue with:
docker pull nexus-repo.de/docker/final:test ❌
When I push something to the Docker repository hosted in Nexus, I can pull it from the Docker group repository using the full name, like: nexus-repo.de/docker/docker-snapshot-local/final:test.
However, I would like to simplify this naming convention when pulling my images, such as docker pull
nexus-repo.de/docker/final:test.
Do you have any ideas on how I can achieve this?