Since I was dealing with VMware NSX Advanced Load Balancer (or NSX ALB aka AVI Loadbalancer, take your pick!) in connection with vSphere with Tanzu in our ITQ Lab environment, I also wanted to make it trustworthy with an “official” certificate and replace the “Self Signed Certificate”.
In the Lab environment, a Windows Certificate Authority (CA) and the CA Web Enrollment already exist on a Windows 2019 VM. I will not go into detail about the installation of the CA; here I followed an article on the VirtuallyThere Blog.
In addition, I have created a Certificate Template according to VMware specifications. In the future, I would like to use this for all VMware product deployments in the lab. I have written another blog article about this (Creating a Microsoft CA Template for vSphere 6.x/7.x), or if you want to read it directly from VMware, here is the KB article: Creating a Microsoft Certificate Authority Template for SSL certificate creation in vSphere 6.x/7.x
Certificate Signing Request
First, a certificate signing request must be created on the AVI controller. To do this, go to Templates >> Security >> SSL/TLS Certificates
, select Create >> Controller Certificate
and create a new certificate of the type “CSR
“.
data:image/s3,"s3://crabby-images/1186b/1186b37811221544dd1c5eba0fec28f0ec4e5e2a" alt="Create a new Controller Certificate"
data:image/s3,"s3://crabby-images/f2631/f2631579380c4b90da441bef52c2efca5c2e17f6" alt=""
When creating the request, make sure that all access addresses are included in the Subject Alternate Names (SANs). In my first attempt, I forgot the cluster IP and had to confirm the browser’s security query for this one address; the rest were excluded meaning they worked fine. Unfortunately, you then have to go through the CSR process again.
data:image/s3,"s3://crabby-images/82c10/82c100319864df49eb4638d72341975932142e0d" alt=""
Quick hint:
How do I come up with 4 entries for the SANs?
- one Node IP
- a corresponding DNS entry
- one Cluster IP (for future use, should I ever want to use more than one node)
- a corresponding DNS entry for the Cluster IP
data:image/s3,"s3://crabby-images/c91a4/c91a438669671dbeb3c1532a21d2e5741d4db724" alt=""
After creating the CSR, it looks like this in AVI:
data:image/s3,"s3://crabby-images/80ebe/80ebebc656831880ff380df87ece97ca7e3847c7" alt=""
Right click on the pencil and copy the CSR to the clipboard:
data:image/s3,"s3://crabby-images/d2063/d2063a04937e488bcb7c5050f151113f2d4b85ff" alt=""
Creating the certificate
Continue in the web interface of the Windows CA (accessible via https://<your-ca>/certsrv
)
Here, navigate via Request a certificate >> advanced certificate request
and paste the previously copied CSR.
data:image/s3,"s3://crabby-images/667cc/667cc5b828725b6765c7632e8fadd55a567643e5" alt=""
data:image/s3,"s3://crabby-images/68b7d/68b7d4c1c8abeee529f1ba5981da642f2d5d46e4" alt=""
data:image/s3,"s3://crabby-images/d21f8/d21f8c3d5aed375b6d1e9d8a0103c4f47657405d" alt=""
In addition, I use my self-created Certificate Template “VMware” here.
The certificate can then be downloaded in Base 64 format:
data:image/s3,"s3://crabby-images/ca247/ca2479016fae3964d012197dce86a653054d19ff" alt=""
data:image/s3,"s3://crabby-images/dedb8/dedb8d012f16fcf01def135140ff7837f849a3fa" alt=""
Using the Certificate in NSX ALB / AVI
Back in the AVI web interface, import the certificates file:
data:image/s3,"s3://crabby-images/aeee5/aeee5861e368dbbe789dff6b506cf8df376d99dd" alt=""
Et viola, the status of the certificate is Green and it is obviously not Self Signed:
data:image/s3,"s3://crabby-images/da371/da3715856bb9ee8f0a413300644c15745d55e337" alt=""
Change NSX ALB / AVI to the new certificate
Now edit the System Access Settings (Administration >> Settings >> Access Settings
) and we are done 🙂
data:image/s3,"s3://crabby-images/7379a/7379aad119bea3c105387a06c470ff2022d7ff66" alt=""
Remove both default certificates…
data:image/s3,"s3://crabby-images/0a2c0/0a2c0e32a248787c878a64edd61a38206d2244c2" alt=""
…and add the new, own certificate granted by the Windows CA:
data:image/s3,"s3://crabby-images/ae675/ae6751a05f1b68a01454d94f31a43832bfc6de6b" alt=""
A check of the four addresses in the web browser (IP and DNS) is successful:
data:image/s3,"s3://crabby-images/9cd28/9cd28e2d07dfcca67c642aced84d9f28a1374ddc" alt=""
A small hint regarding Firefox:
Since we do not use any group policies in our lab that include Firefox, a setting is still necessary so that Firefox relies on the Windows CA (copy/paste from the Mozilla Webseite):
- Enter “about:config” in the address bar and continue to the list of preferences.
- Set the preference “security.enterprise_roots.enabled” to true.
- Restart Firefox.