Lab 5: Upgrade NGINX Plus to the latest version
In this lab, you’ll upgrade NGINX Plus from R32 (or earlier) to the latest version.
There are two scenarios:
- Docker: Deploy a new container running the latest NGINX Plus image, add it to your Config Sync Group, then shift traffic and retire older containers.
- VM: Push your JWT license to an existing VM instance, install the new NGINX Plus package, and restart the service.
Pick the scenario that matches your setup.
By the end of this lab, you can:
- Deploy a Docker container running the latest NGINX Plus with NGINX Agent installed
- Add a VM to a Config Sync Group and push your JWT license
- Install or upgrade to the latest NGINX Plus on a VM
- Check version and sync status in NGINX One Console
- Clean up unavailable instances in NGINX One Console
Make sure you have:
- All labs require an F5 Distributed Cloud (XC) account with NGINX One enabled. If you don’t have an account or need to verify access, follow the steps in Lab 1: Before you begin. 
- Completed Lab 4: Config Sync Groups
- Docker and Docker Compose installed and running (for Docker scenario)
- A trial or paid NGINX One JWT license (saved as nginx-repo.jwt) from MyF5
- A VM with NGINX Plus R32 (or earlier), SSH access, and NGINX Agent installed (for VM scenario)
- Set these environment variables: - 
TOKEN: your data plane key, for example: export TOKEN="your-data-plane-key"
- 
JWT: your NGINX Plus license JWT. Save it as nginx-repo.jwt, then run:export JWT=$(cat path/to/nginx-repo.jwt)
- 
NAME: a unique ID for your workshop (for example, s.jobs):export NAME="s.jobs"
 
- 
- Basic familiarity with Linux and NGINX
- 
Log in to the private registry: shell echo "$JWT" | docker login private-registry.nginx.com \ --username "$JWT" --password-stdin
- 
Open compose.yamlin a text editor. Uncomment the plus4 service block (lines 74–95). This block pulls the latest Debian NGINX Plus image with NGINX Agent, and sets your data plane key, JWT, and Config Sync Group.yaml plus4: # Debian latest NGINX Plus Web / Load Balancer environment: NGINX_AGENT_SERVER_HOST: 'agent.connect.nginx.com' NGINX_AGENT_SERVER_GRPCPORT: '443' NGINX_AGENT_TLS_ENABLE: 'true' NGINX_AGENT_SERVER_TOKEN: $TOKEN # Data plane key from NGINX One Console NGINX_LICENSE_JWT: $JWT NGINX_AGENT_INSTANCE_GROUP: $NAME-sync-group hostname: $NAME-plus4 container_name: $NAME-plus4 image: private-registry.nginx.com/nginx-plus/agent:debian volumes: - ./nginx-plus/etc/nginx/nginx.conf:/etc/nginx/nginx.conf - ./nginx-plus/etc/nginx/conf.d:/etc/nginx/conf.d - ./nginx-plus/etc/nginx/includes:/etc/nginx/includes - ./nginx-plus/usr/share/nginx/html:/usr/share/nginx/html ports: - '80' - '443' - '9000' - '9113' restart: alwaysIn VS Code, highlight lines 74–95 and pressCtrl+/to uncomment.
- 
Restart your containers: docker compose down && docker compose up --force-recreate -d
- 
In NGINX One Console, go to Instances. 
- 
You should see your new instance ( $NAME-plus4) in the list (for example,s.jobs-plus4).
- 
Select the instance and confirm it runs the latest versions of NGINX Plus and NGINX Agent. 
- 
The $NAME-plus4container joins the$NAME-sync-groupand inherits the shared config.Because new containers in a sync group automatically pick up the shared config, you get a consistent setup across versions. This makes upgrades safer and avoids manual copy-paste steps.
When you recreate containers, old entries remain in NGINX One Console. Clean them up:
- In NGINX One Console, go to Instances.
- Select Add filter > Availability > Unavailable.
- Select the checkboxes for the unavailable hosts.
- Select Delete selected, then confirm.
- Remove the filter by selecting the X next to the filter tag.
 
These steps cover RHEL, Amazon Linux, CentOS, Oracle Linux, AlmaLinux, Rocky Linux, Debian, and Ubuntu only.
- In NGINX One Console, go to Manage > Config Sync Groups.
- Select Add Config Sync Group.
- In the Name field, enter $NAME-sync-group-vm(for example,s.jobs-sync-group-vm), then select Create.
- 
Select Manage > Config Sync Groups, then pick your group’s name. 
- 
On the Details tab, in the Instances pane, select Add Instance to Config Sync Group. 
- 
Select Register a new instance with NGINX One then add to config sync group, then select Next. 
- 
Select Use existing key, paste <your-key>into the Data Plane Key box.
- 
Copy the pre-filled curlcommand and run it on your VM:Example: shell curl https://agent.connect.nginx.com/nginx-agent/install | \ DATA_PLANE_KEY="<your-key>" \ sh -s -- -y -c "<config-sync-group-name>"
- 
Back in NGINX One Console, select Refresh. Your VM appears in the list with Config Sync Status = In Sync. 
Add a new configuration file (/etc/nginx/conf.d/dashboard.conf) in your group config to enable the NGINX Plus API and dashboard.
- In the NGINX One Console, select Manage > Config Sync Groups, then pick your config sync group’s name.
- Select the Configuration tab, then select Edit Configuration.
- Select Add File.
- Select New Configuration File.
- In the File name box, enter /etc/nginx/conf.d/dashboard.conf, then select Add.
- Paste the following into the new file workspace:
# This block enables the NGINX Plus API and dashboard
# For configuration and security recommendations, see:
# https://docs.nginx.com/nginx/admin-guide/monitoring/live-activity-monitoring/#configuring-the-api
server {
    # Change the listen port if 9000 conflicts
    # (8080 is the conventional API port)
    listen 9000;
    location /api/ {
        # To restrict write methods (POST, PATCH, DELETE), uncomment:
        # limit_except GET {
        #     auth_basic "NGINX Plus API";
        #     auth_basic_user_file /path/to/passwd/file;
        # }
        # Enable API in write mode
        api write=on;
        # To restrict access by network, uncomment and set your network:
        # allow 192.0.2.0/24   # replace with your network
        # deny  all;
    }
    # Serve the built-in dashboard at /dashboard.html
    location = /dashboard.html {
        root /usr/share/nginx/html;
    }
}- Select Next, review the diff, then select Save and Publish.
- Open your browser to http://<instance-ip>:9000/dashboard.html(replace<instance-ip>with the IP or hostname of one of your group members). You should see the NGINX Plus dashboard.
Each instance needs a JWT license before upgrading. Add it in your Config Sync Group so all members inherit it.
- In NGINX One Console, select Manage > Config Sync Groups, then pick your group’s name.
- Select the Configuration tab, then Edit Configuration.
- Select Add File, then New Configuration File.
- In File name, enter /etc/nginx/license.jwt.
- Select Add.
- Paste the contents of your JWT file into the editor.
- Select Next, review the diff, then select Save and Publish.
See About subscription licenses for details.
- 
Upgrade the NGINX Plus package: - 
RHEL, Amazon Linux, CentOS, Oracle Linux, AlmaLinux, Rocky Linux sudo yum upgrade nginx-plus
- 
Debian, Ubuntu sudo apt update && sudo apt install nginx-plus
 
- 
- 
In NGINX One Console, go to Manage > Instances. 
- 
Select your VM instance. 
- 
In the Instance Details pane, confirm the NGINX Plus version has been updated. 
- 
If the version doesn’t update right away, refresh the page after a few seconds. 
You have upgraded your instances to the latest NGINX Plus.
Go to the NGINX One documentation for more advanced guides and use cases.