Connect NGINX Plus container images
This guide explains how to set up an F5 NGINX Plus Docker container with NGINX Agent and connect it to the NGINX One Console.
Before you start, make sure you have:
- A valid JSON Web Token (JWT) for your NGINX subscription.
- A data plane key from NGINX One.
- Docker installed and running on your system.
- Log in to MyF5.
- Go to My Products & Plans > Subscriptions to see your active subscriptions.
- Find your NGINX subscription, and select the Subscription ID for details.
- Download the JSON Web Token file from the subscription page.
Use your JWT to log in to the NGINX private registry. Replace YOUR_JWT_HERE with your JWT.
sudo docker login private-registry.nginx.com --username=YOUR_JWT_HERE --password=noneProtect sensitive dataTo protect your system and data, follow these security practices:
JWTs: Treat JSON Web Tokens (JWTs) as sensitive data. Store them securely and delete them after use to prevent unauthorized access.
Shell history: Commands with JWTs or passwords are saved in plain text in your shell history. After running such commands, clear the history to protect credentials. For example:
- Edit your shell history file (such as ~/.bash_history or ~/.zsh_history) to remove specific commands.
- Use
history -cto clear all shell history in bash or zsh.
Pull the NGINX Plus image from the private registry. Replace <version-tag> with the desired version, such as alpine, debian, or ubi.
docker pull private-registry.nginx.com/nginx-plus/agentv3:<version-tag>You must specify a version tag that matches your distribution. The latest tag is not supported. Learn more in the Deploying NGINX and NGINX Plus on Docker guide.
Example:To pull the
debianimage:sudo docker pull private-registry.nginx.com/nginx-plus/agent:debian
Start the Docker container to connect it to NGINX One. Replace YOUR_NGINX_ONE_DATA_PLANE_KEY_HERE with your data plane key and version-tag with the version tag you pulled.
For NGINX Plus R33 or later:
- Use the NGINX_LICENSE_JWTvariable to pass your JWT license. ReplaceYOUR_JWT_HEREwith your JWT.
For more details, see About subscription licenses.
sudo docker run \
--env=NGINX_LICENSE_JWT="YOUR_JWT_HERE" \
--env=NGINX_AGENT_COMMAND_SERVER_PORT=443 \
--env=NGINX_AGENT_COMMAND_SERVER_HOST=agent.connect.nginx.com \
--env=NGINX_AGENT_COMMAND_AUTH_TOKEN="DPK" \
--env=NGINX_AGENT_COMMAND_TLS_SKIP_VERIFY=false \
--restart=always \
--runtime=runc \
-d private-registry.nginx.com/nginx-plus/agentv3:<version-tag>Example:To start the container with the
debianimage:sudo docker run \ --env=NGINX_LICENSE_JWT="YOUR_JWT_HERE" \ --env=NGINX_AGENT_COMMAND_SERVER_PORT=443 \ --env=NGINX_AGENT_COMMAND_SERVER_HOST=agent.connect.nginx.com \ --env=NGINX_AGENT_COMMAND_AUTH_TOKEN="DPK" \ --env=NGINX_AGENT_COMMAND_TLS_SKIP_VERIFY=false \ --restart=always \ --runtime=runc \ -d private-registry.nginx.com/nginx-plus/agentv3:debian
For more details, see:
- Deploying NGINX and NGINX Plus on Docker
- Full List of Agent Environment Variables
- NGINX One Data Plane Keys
- My F5 Knowledge Article