To upgrade a Release 22.9 or later NSP cluster
Purpose
CAUTION Network management outage |
The procedure requires a shutdown of the NSP system, which causes a network management outage.
Ensure that you perform the procedure only during a scheduled maintenance period with the assistance of technical support.
Perform this procedure to upgrade a standalone or DR NSP system at Release 22.9 or later after you have performed To prepare for an NSP system upgrade from Release 22.9 or later.
Note: The NSP RHEL user named nsp that is created on an NSP deployer host or NSP cluster VM during deployment requires user ID 1000. If either of the following is true, you must make the ID available to the nsp user on the affected station before the upgrade, or the upgrade fails:
The following RHEL command returns the name of the user that has ID 1000, or nothing if the user ID is unassigned:
awk -F: ' { print $1" "$3 } ' /etc/passwd | grep 1000
You can make the ID available to the nsp user by doing one of the following:
• deleting the user
• using the RHEL usermod command to change the user ID
Note: The following denote a specific NSP release ID in a file path;
Each release ID has the following format:
R.r.p-rel.version
where
R.r.p is the NSP release, in the form MAJOR.minor.patch
version is a numeric value
Steps
Back up NSP deployer host configuration files | |
1 |
Log in as the root user on the NSP deployer host. |
2 |
Open a console window. |
3 |
Back up the following NSP Kubernetes registry certificate files: Note: The files are in one of the following directories, depending on the release you are upgrading from: |
4 |
Back up the following Kubernetes deployer configuration file: /opt/nsp/nsp-k8s-deployer-old-release-ID/config/k8s-deployer.yml |
5 |
Back up the following NSP deployer configuration file: /opt/nsp/NSP-CN-DEP-old-release-ID/config/nsp-deployer.yml |
6 |
Copy the files backed up in Step 3, Step 4, and Step 5 to a separate station outside the NSP cluster for safekeeping. |
Disable SELinux enforcing mode | |
7 |
If SELinux enforcing mode is enabled on the NSP deployer host and NSP cluster members, you must switch to permissive mode on each; otherwise, you can skip this step. Perform “How do I switch between SELinux modes on NSP system components?” in the NSP System Administrator Guide on the NSP deployer host and on each NSP cluster member. Note: If SELinux enforcing mode is enabled on any NSP component during the upgrade, the upgrade fails. |
Apply OS update to NSP deployer host | |
8 |
If the NSP deployer host is deployed in a VM created using an NSP RHEL OS disk image, perform To apply a RHEL update to an NSP image-based OS. |
9 |
If your Kubernetes version is supported, as determined in To prepare for an NSP system upgrade from Release 22.9 or later, you do not need to upgrade Kubernetes; go to Step 28. |
Prepare for Kubernetes upgrade | |
10 |
Transfer the downloaded NSP_K8S_DEPLOYER_R_r.tar.gz file to the /opt/nsp directory on the NSP deployer host. |
11 |
Enter the following on the NSP deployer host: # cd /opt/nsp ↵ |
12 |
Enter the following: # tar -zxvf NSP_K8S_DEPLOYER_R_r.tar.gz ↵ The bundle file is expanded, and the following directories are created: |
13 |
After the file expansion completes successfully, enter the following to remove the file, which is no longer required: # rm -f NSP_K8S_DEPLOYER_R_r.tar.gz ↵ |
14 |
If you are upgrading from Release 22.9, restore the Kubernetes registry certificates.
|
Upgrade Kubernetes registry | |
15 |
Enter the following: # cd /opt/nsp/nsp-registry-new-release-ID/bin ↵ |
16 |
Enter the following to begin the registry upgrade: Note: During the registry upgrade, the registry may be temporarily unavailable. During such a period, an NSP pod that restarts on a new cluster node, or a pod that starts, is in the ImagePullBackOff state until the registry upgrade completes. Any such pods recover automatically after the upgrade, and no user intervention is required. # ./nspregistryctl install ↵ |
17 |
When the registry upgrade is complete, verify the upgrade.
|
Configure Kubernetes deployer | |
18 |
You must merge the current k8s-deployer.yml settings into the new k8s-deployer.yml file.
|
19 |
Edit the following line in the cluster section of the new file to read: hosts: "/opt/nsp/nsp-k8s-deployer-release-ID/config/hosts.yml" |
20 |
If you have disabled remote root access to the NSP cluster VMs,configure the following parameters in the cluster section, sshAccess subsection: sshAccess: userName: "user" privateKey: "path" where user is the designated root-equivalent user path is the SSH key path, for example, /home/user/.ssh/id_rsa |
21 |
Configure the following parameter, which specifies whether dual-stack NE management is enabled: Note: Dual-stack NE management can function only when the network environment is appropriately configured, for example:
enable_dual_stack_networks: value where value must be set to true if the cluster VMs support both IPv4 and IPv6 addressing |
22 |
Save and close the new k8s-deployer.yml file. |
23 |
Enter the following on the NSP deployer host: # cd /opt/nsp/nsp-k8s-deployer-new-release-ID/bin ↵ |
24 |
Enter the following to create the new hosts.yml file: # ./nspk8sctl config -c ↵ |
25 |
Enter the following to list the node entries in the new hosts.yml file: # ./nspk8sctl config -l ↵ Output like the following example for a four-node cluster is displayed: Note: If NAT is used in the cluster: Note: If NAT is not used in the cluster: Existing cluster hosts configuration is: all: hosts: node1: ansible_host: 203.0.113.11 ip: ip access_ip: access_ip node2: ansible_host: 203.0.113.12 ip: ip access_ip: access_ip node3: ansible_host: 203.0.113.13 ip: ip access_ip: access_ip node4: ansible_host: 203.0.113.14 ip: ip access_ip: access_ip |
26 |
Verify the IP addresses. |
27 |
Enter the following to import the Kubernetes images to the repository: .# ./nspk8sctl import ↵ |
Update NSP cluster configuration | |
28 |
Transfer the following downloaded file to the /opt/nsp directory on the NSP deployer host: NSP_DEPLOYER_R_r.tar.gz |
29 |
Enter the following on the NSP deployer host: # cd /opt/nsp ↵ |
30 |
Enter the following: # tar xvf NSP_DEPLOYER_R_r.tar.gz ↵ The bundle file is expanded, and the following directory of NSP installation files is created: /opt/nsp/NSP-CN-DEP-new-release-ID/NSP-CN-new-release-ID |
31 |
Enter the following: # rm -f NSP_DEPLOYER_R_r.tar.gz ↵ The bundle file is deleted. |
32 |
Restore the required NSP configuration files.
|
33 |
Perform one of the following.
|
34 |
Merge the current nsp-deployer.yml settings into the new nsp-deployer.yml file.
|
35 |
If you have disabled remote root access to the NSP cluster VMs, configure the following parameters in the cluster section, sshAccess subsection: sshAccess: userName: "user" privateKey: "path" where user is the designated root-equivalent user path is the SSH key path, for example, /home/user/.ssh/id_rsa |
36 |
Save and close the new nsp-deployer.yml file. |
37 |
Enter the following to import the NSP images and Helm charts to the NSP Kubernetes registry: Note: The import operation may take 20 minutes or longer. # /opt/nsp/NSP-CN-DEP-new-release-ID/bin/nspdeployerctl import ↵ |
Configure NSP software | |
38 |
You must merge the nsp-config.yml file content from the existing deployment into the new nsp-config.yml file. Open the following files using a plain-text editor such as vi:
Note: See nsp-config.yml file format for configuration information. Note: The following REST-session parameters in the nsp section of the nsp-config.yml file apply only to an NSP system that uses CAS authentication, and are not to be configured otherwise: |
39 |
Copy each configured parameter line from the previous nsp-config.yml file and use the line to overwrite the same line in the new file. Note: The peer_address value that you specify must match the advertisedAddress value in the configuration of the peer cluster and have the same format; if one value is a hostname, the other must also be a hostname. Note: You must maintain the structure of the new file, as any new configuration options for the new release must remain. Note: You must replace each configuration line entirely, and must preserve the leading spaces in each line. Note: If NSP application-log forwarding to NSP Elasticsearch is enabled, special configuration is required.
|
40 |
Configure the following parameter in the platform section as shown below: Note: You must preserve the lead spacing of the line. clusterHost: "cluster_host_address" where cluster_host_address is the address of NSP cluster member node1, which is subsequently used for cluster management operations |
41 |
Configure the type parameter in the deployment section as shown below: deployment: type: "deployment_type" where deployment_type is one of the parameter options listed in the section |
42 |
If the NSP system currently performs model-driven telemetry or classic telemetry statistics collection, perform the following steps.
|
43 |
If all of the following are true, configure the following parameters in the integrations section:
nfmpDB: primaryIp: "" standbyIp: "" |
44 |
If both of the following are true, configure the following parameters in the integrations section: auxServer: primaryIpList: "" standbyIpList: "" |
45 |
If the NSP system includes one or more Release 22 analytics servers that are not being upgraded as part of the current NSP system upgrade, you must enable NSP and analytics compatibility; otherwise, you can skip this step. Set the legacyPortEnabled parameter in the analyticsServer subsection of the integrations section to true as shown below: analyticsServer: legacyPortEnabled: true |
46 |
If required, configure the user authentication parameters in the sso section, as shown below; see NSP SSO configuration parameters for configuration information. |
47 |
If you have an updated license, ensure that the location of your license.zip file, as indicated in the nsp-config.yml file, is in the correct location on the NSP deployer host. |
48 |
Save and close the new nsp-config.yml file. |
49 |
Close the previous nsp-config.yml file. |
50 |
The steps in the following section align with the cluster-specific actions described in Workflow for DR NSP system upgrade from Release 22.9 or later. If you are upgrading a standalone NSP system, go to Step 56. |
DR-specific instructions | |
51 |
Perform Step 56 to Step 59 on the standby NSP cluster. |
52 |
Perform Step 56 to Step 86 on the primary NSP cluster. |
53 |
Perform Step 60 to Step 86 on the standby NSP cluster. |
54 |
Perform Step 87 to Step 92 on each NSP cluster. |
55 |
Go to Step 93. |
Stop and undeploy NSP cluster | |
56 |
Perform the following steps on the NSP deployer host to preserve the existing cluster data.
|
57 |
Enter the following on the NSP deployer host to undeploy the NSP cluster: Note: If you are upgrading a standalone NSP system, or the primary NSP cluster in a DR deployment, this step marks the beginning of the network management outage associated with the upgrade. Note: If the NSP cluster VMs do not have the required SSH key, you must include the --ask-pass argument in a command, as shown in the following example, and are subsequently prompted for the root password of each cluster member: nspdeployerctl --ask-pass uninstall --undeploy --clean # /opt/nsp/NSP-CN-DEP-old-release-ID/bin/nspdeployerctl uninstall --undeploy --clean ↵ The NSP cluster is undeployed. |
58 |
On the NSP cluster host, enter the following periodically to display the status of the Kubernetes system pods: Note: You must not proceed to the next step until the output lists only the following: # kubectl get pods -A ↵ The pods are listed. |
Apply OS update to NSP cluster VMs | |
59 |
If the NSP cluster VMs were created using an NSP RHEL OS disk image, perform the following steps on each NSP cluster VM to apply the required OS update.
|
Upgrade Kubernetes deployment environment | |
60 |
If your Kubernetes version is supported, as determined in To prepare for an NSP system upgrade from Release 22.9 or later, go to Step 63. See the Host Environment Compatibility Guide for NSP and CLM for Kubernetes version-support information. |
61 |
If you are not upgrading Kubernetes from the immediately previous version supported by the NSP, but from an earlier version, you must uninstall Kubernetes; otherwise, you can skip this step. Enter the following on the NSP deployer host: Note: If the NSP cluster VMs do not have the required SSH key, you must include the --ask-pass argument in a command, as shown in the following example, and are subsequently prompted for the root password of each cluster member: nspk8sctl --ask-pass uninstall # /opt/nsp/nsp-k8s-deployer-old-release-ID/bin/nspk8sctl uninstall ↵ The Kubernetes software is uninstalled. |
62 |
Enter the following on the NSP deployer host: Note: If the NSP cluster VMs do not have the required SSH key, you must include the --ask-pass argument in a command, as shown in the following example, and are subsequently prompted for the root password of each cluster member: nspk8sctl --ask-pass install # /opt/nsp/nsp-k8s-deployer-new-release-ID/bin/nspk8sctl install ↵ Note: The installation takes considerable time; during the process, each cluster node is cordoned, drained, upgraded, and uncordoned, one node at a time. The operation on each node may take 15 minutes or more. The NSP Kubernetes environment is deployed. |
Label NSP cluster nodes | |
63 |
Open a console window on the NSP cluster host. |
64 |
Enter the following periodically to display the status of the Kubernetes system pods: Note: You must not proceed to the next step until each pod STATUS reads Running or Completed. # kubectl get pods -A ↵ The pods are listed. |
65 |
Enter the following periodically to display the status of the NSP cluster nodes: Note: You must not proceed to the next step until each node STATUS reads Ready. # kubectl get nodes -o wide ↵ The NSP cluster nodes are listed, as shown in the following three-node cluster example: NAME STATUS ROLES AGE VERSION INTERNAL-IP EXTERNAL-IP node1 Ready master nd version int_IP ext_IP node2 Ready master nd version int_IP ext_IP node3 Ready <none> nd version int_IP ext_IP |
66 |
Enter the following on the NSP deployer host to apply the node labels to the NSP cluster: # /opt/nsp/NSP-CN-DEP-new-release-ID/bin/nspdeployerctl config ↵ |
67 |
If you are not including any dedicated MDM nodes in addition to the number of member nodes in a standard or enhanced NSP cluster, go to Step 75. |
68 |
On the NSP cluster host, if remote root access is disabled, switch to the designated root-equivalent user. |
69 |
Perform the following steps for each additional MDM node.
|
70 |
If remote root access is disabled, switch back to the root user. |
71 |
Enter the following: # kubectl get nodes -o wide ↵ A list of nodes like the following is displayed. NAME STATUS ROLES AGE VERSION INTERNAL-IP EXTERNAL-IP node1 Ready master nd version int_IP ext_IP node2 Ready master nd version int_IP ext_IP node3 Ready <none> nd version int_IP ext_IP |
72 |
Record the NAME value of each node whose INTERNAL-IP value is the IP address of a node that has been added to host an additional MDM instance. |
73 |
For each node, enter the following sequence of commands: # kubectl label node node mdm=true ↵ where node is the recorded NAME value of the MDM node |
Upgrade NSP software | |
74 |
Return to the console window on the NSP deployer host. |
75 |
Restore the Keycloak secret files. Note: Keycloak secret files may or may not be present, depending on the deployment.
|
76 |
Enter the following: # cd /opt/nsp/NSP-CN-DEP-new-release-ID/bin ↵ |
77 |
Enter the following: Note: If the NSP cluster VMs do not have the required SSH key, you must include the --ask-pass argument in a command, as shown in the following example, and are subsequently prompted for the root password of each cluster member: nspdeployerctl --ask-pass install --config --deploy # ./nspdeployerctl install --config --deploy ↵ The NSP is upgraded. |
Monitor NSP initialization | |
78 |
Open a console window on the NSP cluster host. |
79 |
Monitor and validate the NSP cluster initialization. Note: You must not proceed to the next step until each NSP pod is operational.
|
80 |
Enter the following on the NSP cluster host to ensure that all pods are running: # kubectl get pods -A ↵ The status of each pod is listed; all pods are running when the displayed STATUS value is Running or Completed. The nsp deployer log file is /var/log/nspdeployerctl.log. |
Verify upgraded NSP cluster operation | |
81 |
Use a browser to open the NSP cluster URL. |
82 |
Verify the following.
Note: If the UI fails to open, perform “How do I remove the stale NSP allowlist entries?” in the NSP System Administrator Guide to ensure that unresolvable host entries from the previous deployment do not prevent NSP access. |
Upgrade MDM adaptors | |
83 |
If the NSP system currently performs model-driven telemetry or classic telemetry statistics collection, you must upgrade your MDM adaptors to the latest in the adaptor suite delivered as part of the new NSP release, and install the required Custom Resources, or CRs. Perform the following steps. Note: Upgrading the adaptors to the latest version is mandatory in order for gNMI telemetry collection to function.
|
Upgrade or enable additional components and systems | |
84 |
If the NSP deployment includes the VSR-NRC, upgrade the VSR-NRC as described in the VSR-NRC documentation. |
85 |
If you are including an existing NFM-P system in the deployment, perform one of the following.
Note: An NFM-P system upgrade procedure includes steps for upgrading the following components in an orderly fashion: |
86 |
If the NSP system includes the WS-NOC, perform the appropriate procedure in WS-NOC and NSP integration to enable WS-NOC integration with the upgraded NSP system. |
Purge Kubernetes image files | |
87 |
Note: Perform this and the following step only after you verify that the NSP system is operationally stable and that an upgrade rollback is not required. Enter the following on the NSP deployer host: # cd /opt/nsp/nsp-k8s-deployer-new-release-ID/bin ↵ |
88 |
Enter the following: # ./nspk8sctl purge-registry -e ↵ The images are purged. |
Purge NSP image files | |
89 |
Note: Perform this and the following step only after you verify that the NSP system is operationally stable and that an upgrade rollback is not required. Enter the following on the NSP deployer host: # cd /opt/nsp/NSP-CN-DEP-new-release-ID/bin ↵ |
90 |
Enter the following: # ./nspdeployerctl purge-registry -e ↵ The charts and images are purged. |
Restore SELinux enforcing mode | |
91 |
If either of the following is true, perform “How do I switch between SELinux modes on NSP system components?” in the NSP System Administrator Guide on the NSP deployer host and each NSP cluster VM.
|
92 |
Close the open console windows. |
Remove path-control subscriptions | |
93 |
If you are upgrading a Release 23.4 or later system that has path-control telemetry flow integration enabled, you must remove the older subscriptions, which can no longer be used. Issue the following REST API call: Note: In order to issue a REST API call, you require a token; see the My First NSP API Client tutorial on the Network Developer Portal for information. POST https://address:8443/rest/flow-collector-controller/rest/api/v1/export/unsubscribe where address is the NSP advertised address The message body is the following: { "subscription" : "nrcp-sub" } The subscriptions are removed. |
Restore classic telemetry collection | |
94 |
Telemetry data collection for classically mediated NEs does not automatically resume after an upgrade to NSP Release 24.4. Manual action is required to restore the data collection. If your NSP system collects telemetry data from classically mediated NEs, restore the telemetry data collection.
Note: The subscription processing begins after the execution of a discovery rule, and may take 15 minutes or more. End of steps |