Upgrade to NGINX Ingress Controller 4.0.0
This document explains how to upgrade F5 NGINX Ingress Controller to 4.0.0.
There are two necessary steps required: updating the apiVersion
value of custom resources and configuring structured logging.
For NGINX Plus users, there is a third step to create a Secret for your license.
Update custom resource apiVersion
If the Helm chart you have been using is v2.x
, before upgrading to NGINX Ingress Controller 4.0.0 you must update your GlobalConfiguration, Policy and TransportServer resources from apiVersion: k8s.nginx.org/v1alpha1
to apiVersion: k8s.nginx.org/v1
.
If the Helm chart you have been using is v1.0.2
or earlier (NGINX Ingress Controller v3.3.2
), upgrade to Helm chart v1.4.2
(NGINX Ingress Controller v3.7.2
) before updating your GlobalConfiguration, Policy and TransportServer resources.
The example below shows the change for a Policy resource: you must do the same for all GlobalConfiguration and TransportServer resources.
apiVersion: k8s.nginx.org/v1alpha1
kind: Policy
metadata:
name: rate-limit-policy
spec:
rateLimit:
rate: 1r/s
key: ${binary_remote_addr}
zoneSize: 10M
apiVersion: k8s.nginx.org/v1
kind: Policy
metadata:
name: rate-limit-policy
spec:
rateLimit:
rate: 1r/s
key: ${binary_remote_addr}
zoneSize: 10M
Warning:
If a GlobalConfiguration, Policy or TransportServer resource is deployed withapiVersion: k8s.nginx.org/v1alpha1
, it will be deleted during the upgrade process.
Once above specified custom resources are moved to v1
,please run below kubectl
commands before upgrading to v4.0.0 Custom Resource Definitions (CRDs) to avoid this issue.
kubectl patch customresourcedefinitions transportservers.k8s.nginx.org --subresource='status' --type='merge' -p '{"status":{"storedVersions": ["v1"]}}'
kubectl patch customresourcedefinitions globalconfigurations.k8s.nginx.org --subresource='status' --type='merge' -p '{"status":{"storedVersions": ["v1"]}}'
Configure structured logging
To configure structured logging, you must update your log deployment arguments from an integer to a string. The logs themselves can also be rendered in different formats.
Note:
These options apply to NGINX Ingress Controller logs, and do not affect NGINX logs.
Level arguments | Format arguments |
---|---|
trace |
json |
debug |
text |
info |
glog |
warning |
|
error |
|
fatal |
The Helm value of controller.logLevel
has been changed from an integer to a string.
To change the rendering of the log format, use the controller.logFormat
key.
controller:
logLevel: info
logFormat: json
The command line argument -v
has been replaced with -log-level
, and takes a string instead of an integer. The argument -logtostderr
has also been deprecated.
To change the rendering of the log format, use the -log-format
argument.
args:
- -log-level=info
- -log-format=json
Create License secret
If you’re using NGINX Plus with NGINX Ingress Controller, you should read the Create License Secret topic to set up your NGINX Plus license.
The topic also contains guidance for sending reports to NGINX Instance Manager, which is necessary for air-gapped environments.
In prior versions, usage reporting with the cluster connector was required: it is no longer necessary, as it is built into NGINX Plus.