data:image/s3,"s3://crabby-images/2a57a/2a57af56c0164f389217d8c89d84538dd026e6f2" alt=""
This is part3 of my 3-parts NSX-T series that illustrates the complete step-by-step procedure to replace the self-signed certificates for NSX-T 3.x manager cluster with MS-based CA-signed certificates.
In part1 of this series, I configured a MS-based Certificate Authority server and created the certificate template for NSX-T.
In part2, I prepared the Certificate Signing Request (CSR) files and issue the corresponding certificates based on the NSX-T template from our CA server.
In this part, I will walk you through the steps needed to import the certificates into the NSX-T manager, activate them via REST API, and finally validate the results.
Step1: Import the CA-signed Certificates into the NSX-T manager
Login to the NSX-T manager admin portal and navigate to System > Settings > Certificates.
data:image/s3,"s3://crabby-images/4de87/4de8750073799b0df45a7fc713e618af8e53d2f6" alt=""
First we will upload the CA root certificate. Click on Import > Import CA Certificate.
data:image/s3,"s3://crabby-images/e6a57/e6a57c6e596df72ed8e573550c4b15fba3056a55" alt=""
data:image/s3,"s3://crabby-images/8e059/8e059b9a82309314e5c5bf90299d3a715a245f65" alt=""
Enter a name for the CA root certificate.
Copy the content of the root CA certificates .cer file into the Certificate Contents textbox.
data:image/s3,"s3://crabby-images/a74d6/a74d68c9414519f3d0a4b4cde4765e41ba732be6" alt=""
Toggle off Service Certificate, and click on Import when you are done.
data:image/s3,"s3://crabby-images/386a2/386a2ea107f1d68fcb35ade0a22553f7b762c7a9" alt=""
data:image/s3,"s3://crabby-images/c826b/c826b34c1502e015026e7ec95dec27257bdaeba8" alt=""
Next, we need to import the certificates for the three NSX-T managers and for the cluster VIP. Let’s import the certificate for first manager node.
Click on Import > Import Certificate.
data:image/s3,"s3://crabby-images/969f0/969f0a965c9dae8e9764e0e0eefd96f1bbd02a0d" alt=""
data:image/s3,"s3://crabby-images/39a60/39a6076378192acb2f02c75cac5d9abaadac29e1" alt=""
Enter a name for the CA-signed certificate.
In the Certificate Contents textbox, you need to copy the full chain of NSX-T manager certificate in the below order:
—–BEGIN CERTIFICATE—–
NSX-T Manager or cluster VIP Cert
—–END CERTIFICATE—–
—–BEGIN CERTIFICATE—–
CA Root Cert
—–END CERTIFICATE—–
data:image/s3,"s3://crabby-images/df4a9/df4a99a8cb1f084c909d3a45048346b458198a35" alt=""
In the private key text box, you need to copy the contents of nsxmgr01.key file.
data:image/s3,"s3://crabby-images/83a01/83a0146e8401c1b6c502e145d326d20719b0ecfa" alt=""
Toggle off Service Certificate, and click on Import when you are done.
data:image/s3,"s3://crabby-images/33412/334120de28a76df2533ceac419252013657d8f53" alt=""
data:image/s3,"s3://crabby-images/92af2/92af2b96e46ce5a8e6bf315294aa626f9f039e98" alt=""
Repeat the same steps to import the certificates for nsxmgr02, nsxmgr03, and nsxmgr (cluster VIP FQDN).
data:image/s3,"s3://crabby-images/50cce/50cce2738faaf88f879575a258faf4e17861c6fc" alt=""
Step2: Activate the imported CA-signed Certificates via REST API
Now we have all the certificates available, you need to activate them via REST API calls. I am using Postman REST API client in this demonstration.
First we have to activate the certificate for each of the three NSX-T manager nodes via a POST call using the below request URL:
POST
https://<NSX_mgr_FQDN>/api/v1/node/services/http?action=apply_certificate&certificate_id=<Certificate_ID>
The certificate ID for each certificate can be copied from the portal as shown below.
data:image/s3,"s3://crabby-images/497f7/497f7bf890f7fa69c1954234314ebbccdf39a50b" alt=""
For the first NSX-T manager node, the URL would appear as hereunder:
https://nsxmgr01.lab.local/api/v1/node/services/http?action=apply_certificate&certificate_id=63d20782-7f03-4b2e-bb74-c5aff5d68e9b
Now send a POST call using the above URL to activate the certificate on nsxmgr01.lab.local. You will get a 200 OK response if all went fine.
data:image/s3,"s3://crabby-images/bb57f/bb57fc786ac8b7b0a6afb67d4a237b2b32b1426a" alt=""
Verify and make sure the certificate has been replaced for the first NSX-T manager.
data:image/s3,"s3://crabby-images/c6265/c626599012b95f18305f09d6450383b99f23e262" alt=""
Repeat the same steps to activate the certificate for the remaining two NSX-T manager nodes.
Next we need to activate the certificate for the NSX-T manager cluster VIP FQDN. The request URL is different here as show below:
POST https://<NSX_Manager_FQDN/api/v1/cluster/api-certificate?action=set_cluster_certificate&certificate_id=<Cluster_Certificate_ID>
For my NSX-T manager cluster, the URL would appear as hereunder:
POST https://nsxmgr01.lab.local/api/v1/cluster/api-certificate?action=set_cluster_certificate&certificate_id=ff6a7b87-1d72-41ee-a22d-eddece2644da
Now send a POST call using the above URL to activate the certificate for nsxmgr.lab.local. You will get a 200 OK response if all went fine.
data:image/s3,"s3://crabby-images/cc8b1/cc8b1275565466eb7a65b6ba811ea90994b7a1b6" alt=""
We are done!
Let’s login to the NSX-T manager portal using the cluster FQDN and validate the results. Green is good 🙂
data:image/s3,"s3://crabby-images/75fbe/75fbebde94f522af12bbe177f1e20ce8dbddccc0" alt=""
I hope this post and the entire series were informative.
Many thanks for reading.
data:image/s3,"s3://crabby-images/bf2ac/bf2aca9b1e9995143b7e95146047a55433f444f0" alt=""