For configuring Hyper-V replica, we have two authentication choice: Kerberos or Certificate. If use Kerberos authentication, the data transmitted from the primary to the replica server is not encrypted. For the date to be encrypted, we will use Certificate authentication and the certificate type has X.509v3 or self-signed. In this moment, we will introduce you how to deploy Hyper-V replica with self-signed certificate.
Due to Hyper-V Replica use machine level mutual authentication, we have to do the prerequisites of the certificate except for the steps about Kerberos authentication.
Add DNS suffix on Primary & Replica Node
To use the command “NetDom computername” with parameter “/enumerate” (# 1) to realize what the computer name is.
On Primary Node
To add a new alternate by using the following command and the name must be a fully qualified DNS name (FQDN)
netdom computername vw-hyperv-04
/Add:vw-hyperv-04.xxx.mooo.com
data:image/s3,"s3://crabby-images/97a67/97a67f3476d13a2056cc818c5e7d566e5b3aa73e" alt="ScreenHunter_04 ScreenHunter_04"
data:image/s3,"s3://crabby-images/ad695/ad6958adba806af381df5bd2b0ce87ec094d08c4" alt="ScreenHunter_05 ScreenHunter_05"
To make an existing alternate name into the primary name and the name must be a fully qualified DNS name (FQDN)
netdom computername vw-hyperv-04
/MakePrimary:vw-hyperv-04.xxx.mooo.com
data:image/s3,"s3://crabby-images/e073c/e073c421fe437fa12972f57000d989c0a97e6f28" alt="ScreenHunter_06 ScreenHunter_06"
After reboot the system, the change will take effect and we can confirm by using the command “NetDom computername” with parameter "/enumerate” again.
data:image/s3,"s3://crabby-images/ba1ee/ba1eeeaaa8454770aa1b554988fba71e0a312db3" alt="ScreenHunter_09 ScreenHunter_09"
The “AS-IS” status of the DNS suffix
data:image/s3,"s3://crabby-images/059ab/059ab179060e83823d70f0cfde192fe71654353a" alt="ScreenHunter_02 ScreenHunter_02"
The “TO-BE” status of the DNS suffix
On Replica Node
To add a new alternate by using the following command and the name must be a fully qualified DNS name (FQDN)
netdom computername vw-hyperv-05
/Add:vw-hyperv-05.xxx.mooo.com
data:image/s3,"s3://crabby-images/19af9/19af9bc127b201c4bf54f448d26eccdf213038e6" alt="ScreenHunter_08 ScreenHunter_08"
To make an existing alternate name into the primary name and the name must be a fully qualified DNS name (FQDN)
netdom computername vw-hyperv-05
/MakePrimary:vw-hyperv-05.xxx.mooo.com
Open TCP 443 port on Primary & Replica NodesOn Primary Node
To enable HTTPS (port 443) replica traffic, we can run the following from an elevated command-prompt:
netsh advfirewall firewall set rule group="Hyper-V Replica HTTPS" new enable=yesdata:image/s3,"s3://crabby-images/0bf28/0bf286a360f1eef87ce16946f59d4ab8bbdd51b4" alt="ScreenHunter_11 ScreenHunter_11"
The “AS-IS” status of the firewall
data:image/s3,"s3://crabby-images/9b06d/9b06dbefe081a9b1d3f5691a8b25586e7909e2d1" alt="ScreenHunter_10 ScreenHunter_10"
The “TO-BE” status of the firewall
On Replica Node
To enable HTTPS (port 443) replica traffic, we can run the following from an elevated command-prompt:
netsh advfirewall firewall set rule group="Hyper-V Replica HTTPS" new enable=yes
Create self-signed certificate on Primary & Replica Nodes
On Primary Node
For creating a self-signed root authority certificate, we can run the following from an elevated command-prompt to install a Test certificate in the root store of the local machine and be saved as a file locally.
makecert -pe -n “CN=PrimaryTestRootCA
” -ss root -sr LocalMachine –sky signature -r “PrimaryTestRootCA.cer
”data:image/s3,"s3://crabby-images/37c3b/37c3b60dc60bbff5564cc80cc0d31e8ea71708e5" alt="ScreenHunter_13 ScreenHunter_13"
For creating a new Test certificate, we can run the following elevated command to install a Client and Server certificate in the Personal store of the local machine and be saved as a file locally.
makecert -pe -n “CN=vw-hyperv-04.xxx.mooo.com
” -ss my –sr LocalMachine -sky exchange –eku 1.3.6.1.5.5.7.3.1,1.3.6.1.5.5.7.3.2 –in “PrimaryTestRootCA
” -is root -ir LocalMachine -sp “Microsoft RSA SChannel Cryptographic Provider” -sy 12 PrimaryTestCert.cer
On Replica Node
For creating a self-signed root authority certificate, we can run the following from an elevated command-prompt to install a Test certificate in the root store of the local machine and be saved as a file locally.
makecert -pe -n “CN=ReplicaTestRootCA
” -ss root -sr LocalMachine –sky signature -r “ReplicaTestRootCA.cer
”data:image/s3,"s3://crabby-images/c4952/c49522c0e3c30259a02c5c0b5c5a2c0c08ebf591" alt="ScreenHunter_13 ScreenHunter_13"
The “AS-IS” status of the certificate
data:image/s3,"s3://crabby-images/dde96/dde968ce17f0f5d5020d78a535c15faa53842f38" alt="ScreenHunter_12 ScreenHunter_12"
The “TO-BE” status of the certificate
data:image/s3,"s3://crabby-images/40fe2/40fe29063ade02975a4ee668963aaffca5ff50b0" alt="ScreenHunter_14 ScreenHunter_14"
For creating a new Test certificate, we can run the following elevated command to install a Client and Server certificate in the Personal store of the local machine and be saved as a file locally.
makecert -pe -n “CN=vw-hyperv-05.xxx.mooo.com
” -ss my –sr LocalMachine -sky exchange –eku 1.3.6.1.5.5.7.3.1,1.3.6.1.5.5.7.3.2 –in “ReplicaTestRootCA
” -is root -ir LocalMachine -sp “Microsoft RSA SChannel Cryptographic Provider” -sy 12 ReplicaTestCert.cer
data:image/s3,"s3://crabby-images/93d37/93d37b2ef6a0e4fe1cff3973c601e0e0b9b6377a" alt="ScreenHunter_15 ScreenHunter_15"
The “AS-IS” status of the certificate
data:image/s3,"s3://crabby-images/a0b4a/a0b4a3326125989dd2165398378d4904bc9e006d" alt="ScreenHunter_03 ScreenHunter_03"
The “TO-BE” status of the certificate
Import a self-signed root CA into each node
On Primary Node
Copy “ReplicaTestRootCA.cer” from the Replica server to the Primary server next to import self-signed Root CA by running the following command.
certutil -addstore -f Root “ReplicaTestRootCA.cer”data:image/s3,"s3://crabby-images/1ece8/1ece8542025020dff1d16b585c24f16bd88333c3" alt="ScreenHunter_07 ScreenHunter_07"
The “AS-IS” status of the root certificate
data:image/s3,"s3://crabby-images/8c54f/8c54feb5a54aec82a8b3e4c837528bc5f81dd902" alt="ScreenHunter_06 ScreenHunter_06"
The “TO-BE” status of the root certificate
On Replica Node
Copy “PrimaryTestRootCA.cer” from the Primary server to the Replica server next to import self-signed Root CA by running the following command.
certutil -addstore -f Root “PrimaryTestRootCA.cer”
Disable CRL check on each node
Due to the self-signed certificate doesn’t support Revocation check, we have to modify the following registry key on each node for disabling the CRL check and reboot it.
reg add “HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Virtualization\Replication” /v DisableCertRevocationCheck /d 1 /t REG_DWORD /fdata:image/s3,"s3://crabby-images/41b79/41b79e5048e56097625564ca7d5ab70d96b5d28e" alt="ScreenHunter_11 ScreenHunter_11"
The “AS-IS” status of the registry key
data:image/s3,"s3://crabby-images/ca38b/ca38b4846a4b81fd4e34c3a799508c9a7c6feff9" alt="ScreenHunter_10 ScreenHunter_10"
The “TO-BE” status of the registry key
Validate certificate on each node
We can run the following command to realize whether this certificate validates on primary & replica server such as “Encryption test passed.
certutil –store my
data:image/s3,"s3://crabby-images/44563/44563818ef2fa6b402c31db4b23ecaf5710e7b6a" alt="ScreenHunter_13 ScreenHunter_13"
Until now, we have already prepared the related prerequisite for certificate implement. In next article, we will begin to enable replication by using certificate based authentication.
Reference :
(# 1) The command “NetDom computername” is that manage the primary or alternate name for one Computer. A syntax is "
NetDom computername Computer
/enumerate[:{ALTERNATENAMES | PRIMARYNAME | ALLNAMES}]”
Parameters: /enumerate
ALTERNATENAMES Lists the alternate names only.
PRIMARYNAME Lists the primary name only.
ALLNAMES Lists the primary and any alternate names. This is the default.
(# 2) About where to get Makecert.exe, we can download/install
Windows SDK for Windows 7 on Windows 7 from Microsoft
data:image/s3,"s3://crabby-images/436a1/436a11a1c5188506217a1bba236169ba429bf004" alt="ScreenHunter_14 ScreenHunter_14"
and find it on Microsoft sdks directory “C:\Program Files (x86)\Microsoft SDKs\Windows\v7.xA\Bin\makecert.exe”
data:image/s3,"s3://crabby-images/12be9/12be97c1abb04884e84ded5158447e034082893a" alt="ScreenHunter_15 ScreenHunter_15"
or directly download it from
http://www.inventec.ch/chdh/notes/makecert_5_131_3790_0.zip
When got this file, please Copy this File (makecert.exe) to C:\Windows\System32 or C:\Windows\sysWOW64 depending on the OS.
If want to realize this command in detail, please refer to
Makecert.exe (Certificate Creation Tool)
<<<
Hyper-V 3.0 --- Create VM that its virtual hard disk (VHDX) with parent-child relationship (part 8)