Update NGINX Controller Settings with helper.sh
You can use the F5 NGINX Controller helper.sh script to update NGINX Controller installation settings and manage the NGINX Controller process. This tutorial shows you how to use helper.sh to perform the following tasks:
- Install the NGINX Controller prerequisites
- View the version of NGINX Controller that’s installed and running
- Start, stop, and restart NGINX Controller
- Back up and restore the NGINX Controller config and encryption keys
- Restore the embedded config database
- Get the NGINX Plus repository key and certificate files (deprecated for helper.shin NGINX Controller v3.9)
- Update the SMTP settings
- Update the database settings
- Update or replace the TLS certificates
- Print the NGINX Controller logs
- Create a support package
You can use the NGINX Controller helper.sh prereqs command to install the required system packages and Docker CE.
| Options | Description | 
|---|---|
| base | Install the required Linux utilities. | 
| docker | Install Docker CE. | 
| nfs | Install NFS system packages. | 
To install all of the NGINX Controller prerequisites for your system at the same time, take the following steps:
- 
Download the NGINX Controller installer package from the MyF5 Customer Portal. 
- 
Extract the installer package files: tar xzf controller-installer-<version>.tar.gz
- 
Run the helper script with the prereqsoption:bash cd controller-installer ./helper.sh prereqs
After you’ve installed NGINX Controller, you can install any of the prerequisites by running the following command:
/opt/nginx-controller/helper.sh prereqs [base|docker|nfs]
To see which version of NGINX Controller is installed and running, type the following command:
/opt/nginx-controller/helper.sh versionThe output looks similar to the following:
Installed version: 3.14.0
Running version: 3.14.0
You can use the helper.sh script to start, stop, restart, and check the status of the NGINX Controller process.
/opt/nginx-controller/helper.sh controller start
/opt/nginx-controller/helper.sh controller stop
/opt/nginx-controller/helper.sh controller restart
/opt/nginx-controller/helper.sh controller status
After installing NGINX Controller, you should back up the cluster config and encryption keys. You’ll need these if you ever need to restore the NGINX config database on top of a new NGINX Controller installation.
- 
To back up the NGINX Controller cluster configuration and encryption keys: /opt/nginx-controller/helper.sh cluster-config saveThe file is saved to /opt/nginx-controller/cluster-config.tgz.
- 
To restore the cluster’s config and encryption keys, take the following steps: /opt/nginx-controller/helper.sh cluster-config load <filename>
This section explains how to restore the embedded config database from the latest backup file or a specific, timestamped file.
If you restore the config database on top of a new installation of NGINX Controller, make sure to follow the steps to restore your NGINX config and encryption keys afterward.
- 
To restore the embedded NGINX Controller config database from the latest automated backup, run the following command: /opt/nginx-controller/helper.sh backup restore
- 
To restore the embedded config database from a specific backup file: /opt/nginx-controller/helper.sh backup restore <filename>- 
If you installed the embedded config database on a local volume, the backup files are located in /opt/nginx-controller/postgres_data/.
- 
If you installed the embedded config database on an NFS volume, follow the steps in (NFS) Copy Config Database Backup to Local Volume for Restoration to download the backup file to your local volume, and then use the helper.shscript to restore from it.
 
- 
To install NGINX Plus as a data plane for NGINX Controller, you need to have the NGINX repository key and certificate files.
DeprecatedUsing the helper.sh script to download your NGINX Plus certificate and key bundle is deprecated in in NGINX Controller v3.9.
If you’re running NGINX Controller v3.10+, you can use the REST API to Download the NGINX Plus Cert and Key Bundle.
If you’re running NGINX Controller 3.9 or earlier, use the helper.sh script to extract the NGINX repository key and certificate files:
/opt/nginx-controller/helper.sh repository-cred [-c|--cert <file name>] [-k|--key <file name>]Make sure that you’ve uploaded your license in NGINX Controller first before running thehelper.sh repository-credcommand to extract the repository files.
| Options | Description | 
|---|---|
| -c|--cert | Creates a certificate called <file name>. The default file name isnginx-repo.crtin the current directory. | 
| -k|--key | Creates a key called <file name>. The default file name isnginx-repo.keyin the current directory. | 
Use the helper.sh script to change the SMTP address; port; TLS; sender; and optionally, the username and password.
/opt/nginx-controller/helper.sh configsmtp <address> <port> <tls> <from> [auth] [username] [password]For example:
/opt/nginx-controller/helper.sh configsmtp 192.0.2.0 25 false noreply@example.com true user1 <password>| Options | Description | 
|---|---|
| address | The host name or IP address of the SMTP server. | 
| port | The port of the SMTP server. | 
| tls | trueorfalse. Set totrueto require SSL for connections to the SMTP server. | 
| from | Sender’s email address. | 
| auth | trueorfalse. Set totrueto authenticate when connecting to the SMTP server. | 
| username | The username to use for access to the SMTP server. | 
| password | The password to use for access to the SMTP server. | 
We strongly recommend that you use environment variables, especially for passwords, to prevent exposing sensitive information in system processes (for example, ps, top) and the bash history.
You use these SMTP environment variables with NGINX Controller:
| Environment Variables | Description | 
|---|---|
| CTR_SMTP_HOST | The host name or IP address of the SMTP server. | 
| CTR_SMTP_PORT | The port of the SMTP server. | 
| CTR_SMTP_TLS | trueorfalse; Set totrueto require SSL for connections to the SMTP server. | 
| CTR_SMTP_FROM | Sender’s email address. | 
| CTR_SMTP_AUTH | trueorfalse; Set totrueto authenticate when connecting to the SMTP server. | 
| CTR_SMTP_USER | The username to use for access to the SMTP server. | 
| CTR_SMTP_PASS | The password to use for access to the SMTP server. | 
For example:
CTR_SMTP_HOST=192.0.2.0 \
CTR_SMTP_PORT=25 \
CTR_SMTP_TLS=false \
CTR_SMTP_FROM=noreply@nginx.test \
CTR_SMTP_AUTH=true CTR_SMTP_USER=user1 CTR_SMTP_PASS=<password> \
/opt/nginx-controller/helper.sh configsmtp
Use the helper.sh script to change the external config database address; port; and optionally, the username, password, and certificate authentication. However, if your current installation uses an internal config database, then these settings are read-only and cannot be modified using the helper.sh script (password and certificates will be automatically rotated with each Controller update).
/opt/nginx-controller/helper.sh configdb <address> <port> [username] [password] [ssl] [ca] [cert] [key]For example:
/opt/nginx-controller/helper.sh configdb 192.0.2.1 5432 user1 <password> false| Options | Description | 
|---|---|
| address | The host name or IP address of config database. | 
| port | The port of the database. | 
| username | The username to use for access to the config database. | 
| password | The password to use for access to the config database. | 
| ssl | trueorfalse. Set to ’true’ to require SSL for connections to the config database. | 
| ca | CA certificate file path. | 
| cert | Certificate file path. | 
| key | Key file path. | 
We strongly recommend that you use environment variables, especially for passwords, to prevent exposing sensitive information in system processes (for example, ps, top) and the bash history.
You can use these database environment variables with NGINX Controller:
| Environment Variables | Description | 
|---|---|
| CTR_DB_HOST | The host name or IP address of the config database. | 
| CTR_DB_PORT | The port of the config database used for incoming connections. | 
| CTR_DB_USER | The username for the account to use for access to the config database; must be provided with password. | 
| CTR_DB_PASS | The password for the account to use for access to the config database; must be provided with username. | 
| CTR_DB_ENABLE_SSL | trueorfalse; Set totrueto require SSL for connections to the config database. | 
| CTR_DB_CA | CA certificate file path. | 
| CTR_DB_CLIENT_CERT | Certificate file path. | 
| CTR_DB_CLIENT_KEY | Key file path. | 
For example:
CTR_DB_HOST=192.0.2.1 \
CTR_DB_PORT=5432 \
CTR_DB_USER=user1 \
CTR_DB_PASS=<password> \
CTR_DB_ENABLE_SSL=false \
/opt/nginx-controller/helper.sh configdb
Use the helper.sh script to update or replace the TLS certificates that are used to connect to NGINX Controller.
/opt/nginx-controller/helper.sh configtls <cert_file> <key_file>| Options | Description | 
|---|---|
| cert_file | Certificate file path. | 
| key_file | Key file path. | 
To print the NGINX Controller logs, enter the following command:
/opt/nginx-controller/helper.sh logs
The NGINX Controller logo in the user interface is replaceable with a custom logo. The requirements being:
- The logo file is in SVG format.
- The logo is square in shape.
The above steps modify the logo in the top left corner and in the menu, not the favicon.
Follow the steps below to replace the logo:
- Connect to the NGINX Controller host using ‘ssh’.
- Transfer the logo file to NGINX Controller using one of the following methods:
- Method 1: Download the file using curl after connecting to the host using the command curl https://example.com/custom-logo.svg.
- Method 2: Upload the logo to the host using SCP: scp /local/path/custom-logo.svg user@controller-host:/remote/path.
- Method 3: Copy/Paste the logo file.
- Copy the logo file to the clipboard before connecting to the host.
- After connecting to the host, paste the file.
 
 
- Method 1: Download the file using curl after connecting to the host using the command 
- Run helper.sh setlogo <filename>(is the name of the SVG file). 
- Wait for approximately five minutes for the cache to clear and the logo to appear in the user interface.
- Re-run the setlogocommand on each NGINX Controller node. This has to be done after an upgrade or reinstallation.
You can create a support package for NGINX Controller that you can use to diagnose issues.
You will need to provide a support package if you open a ticket with NGINX Support via the MyF5 Customer Portal.
/opt/nginx-controller/helper.sh supportpkg [-o|--output <file name>] [-s|--skip-db-dump] [-t|--timeseries-dump <hours>]| Options | Description | 
|---|---|
| -o|--output | Save the support package file to <file name>. | 
| -s|--skip-db-dump | Don’t include the database dump in the support package. | 
| -t|--timeseries-dump <hours> | Include the last <n hours>of timeseries data in the support package (default 12 hours). | 
Take the following steps to create a support package:
- 
Open a secure shell (SSH) connection to the NGINX Controller host and log in as an administrator. 
- 
Run the helper.shutility with thesupportpkgoption:/opt/nginx-controller/helper.sh supportpkgThe support package is saved to: /var/tmp/supportpkg-<timestamp>.tar.gzFor example: /var/tmp/supportpkg-20200127T063000PST.tar.gz
- 
Run the following command on the machine where you want to download the support package to: scp <username>@<controller-host-ip>:/var/tmp/supportpkg-<timestamp>.tar.gz /local/path
The support package is a tarball that includes NGINX Controller configuration information, logs, and system command output. Sensitive information, including certificate keys, is not included in the support package.
The support package gathers information from the following locations:
.
├── database
│   ├── common.dump                                - full dump of the common database
│   ├── common.dump_stderr                         - any errors when dumping the database
│   ├── common-apimgmt-api-client-api-keys.txt     - contents of apimgmt_api_client_api_keys table from the common database
│   ├── common-apimgmt-api-client-groups.txt       - contents of apimgmt_api_client_groups table from the common database
│   ├── common-email-verification.txt              - contents of email_verification table from the common database
│   ├── common-oauth-clients.txt                   - contents of oauth_clients table from the common database
│   ├── common-settings-license.txt                - contents of settings_license table from the common database
│   ├── common-settings-nginx-plus.txt             - contents of settings_nginx_plus table from the common database
│   ├── common-table-size.txt                      - list of all tables and their size in the common database
│   ├── data-table-size.txt                        - list of all tables and their size in the data database
│   ├── postgres-database-size.txt                 - size of every database
│   ├── postgres-long-running-queries.txt          - all queries running longer than 10 seconds
│   ├── system.dump                                - full dump of the system database
│   ├── system-account-limits.txt                  - contents of account_limits table from the system database
│   ├── system-accounts.txt                        - contents of accounts table from the system database
│   ├── system-deleted-accounts.txt                - contents of deleted_accounts table from the system database
│   ├── system-deleted-users.txt                   - contents of deleted_users table from the system database
│   ├── system-users.txt                           - contents of users table from the system database
│   └── system-table-size.txt                      - list of all tables and their size in the system database
├── k8s                                            - output of `kubectl cluster-info dump -o yaml` augmented with some extra info
│   ├── apiservices.txt                            - output of `kubectl get apiservice`
│   ├── kube-system                                - contents of the kube-system namespace
│   │   ├── coredns-5c98db65d4-6flb9
│   │   │   ├── desc.txt                           - pod description
│   │   │   ├── logs.txt                           - current logs
│   │   │   └── previous-logs.txt                  - previous logs, if any
│   │   ├── ...
│   │   ├── daemonsets.yaml                        - list of daemonsets
│   │   ├── deployments.yaml                       - list of deployments
│   │   ├── events.yaml                            - all events in this namespace
│   │   ├── namespace.yaml                         - details of the namespace, including finalizers
│   │   ├── pods.txt                               - output of `kubectl get pods --show-kind=true -o wide`
│   │   ├── pods.yaml                              - list of all pods
│   │   ├── replicasets.yaml                       - list of replicasets
│   │   ├── replication-controllers.yaml           - list of replication controllers
│   │   ├── resources.txt                          - all Kubernetes resources in this namespace
│   │   └── services.yaml                          - list of services
│   ├── nginx-controller                           - contents of the nginx-controller namespace
│   │   ├── apigw-8fb64f768-9qwcm
│   │   │   ├── desc.txt                           - pod description
│   │   │   ├── logs.txt                           - current logs
│   │   │   └── previous-logs.txt                  - previous logs, if any
│   │   ├── ...
│   │   ├── daemonsets.yaml                        - list of daemonsets
│   │   ├── deployments.yaml                       - list of deployments
│   │   ├── events.yaml                            - all events in this namespace
│   │   ├── namespace.yaml                         - details of the namespace, including finalizers
│   │   ├── pods.txt                               - output of `kubectl get pods --show-kind=true -o wide`
│   │   ├── pods.yaml                              - list of all pods
│   │   ├── replicasets.yaml                       - list of replicasets
│   │   ├── replication-controllers.yaml           - list of replication controllers
│   │   ├── resources.txt                          - all Kubernetes resources in this namespace
│   │   ├── services.yaml                          - list of services
│   ├── nodes.txt                                  - output of `kubectl describe nodes`
│   ├── nodes.yaml                                 - list of nodes
│   ├── resources.txt                              - all non-namespaced Kubernetes resources (including PersistentVolumes)
│   └── version.yaml                               - Kubernetes version
├── logs                                           - copy of /var/log/nginx-controller/
│   └── nginx-controller-install.log
├── os
│   ├── cpuinfo.txt                                - output of `cat /proc/cpuinfo`
│   ├── df-h.txt                                   - output of `df -h`
│   ├── df-i.txt                                   - output of `df -i`
│   ├── docker-container-ps.txt                    - output of `docker container ps`
│   ├── docker-images.txt                          - output of `docker images`
│   ├── docker-info.txt                            - output of `docker info`
│   ├── docker-stats.txt                           - output of `docker stats --all --no-stream`
│   ├── docker-version.txt                         - output of `docker version`
│   ├── du-mcs.txt                                 - output of `du -mcs /opt/nginx-controller/* /var/log /var/lib`
│   ├── env.txt                                    - output of `env`
│   ├── firewall-cmd.txt                           - output of `firewall-cmd --list-all`
│   ├── free.txt                                   - output of `free -m`
│   ├── hostname-all-fqdns.txt                     - output of `hostname --all-fqdns`
│   ├── hostname-fqdn.txt                          - output of `hostname --fqdn`
│   ├── hostname.txt                               - output of `hostname`
│   ├── hostsfile.txt                              - output of `cat /etc/hosts`
│   ├── ip-address.txt                             - output of `ip address`
│   ├── ip-neigh.txt                               - output of `ip neigh`
│   ├── ip-route.txt                               - output of `ip route`
│   ├── iptables-filter.txt                        - output of `iptables -L -n -v`
│   ├── iptables-mangle.txt                        - output of `iptables -L -n -v -t mangle`
│   ├── iptables-nat.txt                           - output of `iptables -L -n -v -t nat`
│   ├── iptables-save.txt                          - output of `iptables-save`
│   ├── journal-kubelet.txt                        - output of `journalctl -q -u kubelet --no-pager`
│   ├── lspci.txt                                  - output of `lspci -vvv`
│   ├── netstat-nr.txt                             - output of `netstat -nr`
│   ├── ps-faux.txt                                - output of `ps faux`
│   ├── pstree.txt                                 - output of `pstree`
│   ├── ps.txt                                     - output of `ps aux --sort=-%mem`
│   ├── resolvconf.txt                             - output of `cat /etc/resolv.conf`
│   ├── selinux-mode.txt                           - output of `getenforce`
│   ├── ss-ltunp.txt                               - output of `ss -ltunp`
│   ├── swapon.txt                                 - output of `swapon -s`
│   ├── sysctl.txt                                 - output of `sysctl -a --ignore`
│   ├── systemd.txt                                - output of `journalctl -q --utc`
│   ├── top.txt                                    - output of `top -b -o +%CPU -n 3 -d 1 -w512 -c`
│   ├── uname.txt                                  - output of `uname -a`
│   ├── uptime.txt                                 - output of `cat /proc/uptime`
│   └── vmstat.txt                                 - output of `cat /proc/vmstat`
├── timeseries
│   ├── table-sizes.stat                           - stat table containing controller table sizes
│   ├── events.csv                                 - events table dump in csv
│   ├── events.sql                                 - events table schema
│   ├── metrics_1day.csv                           - metrics_1day table dump in csv
│   ├── metrics_1day.sql                           - metrics_1day table schema
│   ├── metrics_1hour.csv                          - metrics_1hour table dump in csv
│   ├── metrics_1hour.sql                          - metrics_1hour table schema
│   ├── metrics_5min.csv                           - metrics_5min table dump in csv
│   ├── metrics_5min.sql                           - metrics_5min table schema
│   ├── metrics.csv                                - metrics table dump in csv
│   ├── metrics.sql                                - metrics table schema
│   ├── system-asynchronous-metrics.stat           - shows info about currently executing events or consuming resources
│   ├── system-events.stat                         - information about the number of events that have occurred in the system
│   ├── system-metrics.stat                        - system metrics
│   ├── system-parts.stat                          - information about parts of a table in the MergeTree family
│   ├── system-settings.stat                       - information about settings that are currently in use
│   └── system-tables.stat                         - information about all the tables
└── version.txt                                    - Controller version information
This documentation applies to the following versions of NGINX Controller: 3.0, 3.1, 3.2, 3.3, 3.3, 3.4, 3.5, 3.6, 3.7, 3.8, 3.9, 3.10, 3.12, 3.13, 3.14, 3.15, 3.16.1, 3.17, 3.18, 3.18.1, 3.18.2 and 3.18.3.
This documentation applies to the following versions of NGINX Controller API Management module: 3.18, 3.18.1, 3.19, 3.19.1, 3.19.2, 3.19.3, 3.19.4 and 3.19.5.
This documentation applies to the following versions of NGINX Controller App Delivery module: 3.20, 3.20.1, 3.21, 3.22, 3.22.1, 3.22.2, 3.22.3, 3.22.4, 3.22.5, 3.22.6, 3.22.7 and 3.22.8.