During my latest deployment of VCF in my lab environment I ran in to the following issue.
data:image/s3,"s3://crabby-images/31dd8/31dd83aa62d058dac6d347ba5a628803b0dba6d5" alt=""
data:image/s3,"s3://crabby-images/25674/25674ddd76b023fa1477a0af8c29ebadc1d80e1c" alt=""
Failed to migrate vmnics of host 192.168.11.12 to DVS sfo-m01-cl01-vds01 . Reason: Failed to migrate vmknic vmk0 to DvSwitch 50 22 42 8c d5 a1 d4 8f-6d 9e 8a 1e 93 ac 5b 9d Failed to migrate vmnics of host 192.168.11.12 to DVS sfo-m01-cl01-vds01 . Reason: Failed to migrate vmknic vmk0 to DvSwitch 50 22 42 8c d5 a1 d4 8f-6d 9e 8a 1e 93 ac 5b 9d Failed to migrate vmnics of host 192.168.11.12 to DVS sfo-m01-cl01-vds01 . Reason: Failed to migrate vmknic vmk0 to DvSwitch 50 22 42 8c d5 a1 d4 8f-6d 9e 8a 1e 93 ac 5b 9d Failed to migrate vmnics of host 192.168.11.12 to DVS sfo-m01-cl01-vds01 . Reason: Failed to migrate vmknic vmk0 to DvSwitch 50 22 42 8c d5 a1 d4 8f-6d 9e 8a 1e 93 ac 5b 9d
The error is pretty clear, the migration of vmk0 from the standard vSwitch to the Distributed vSwitch failed on esx02. I checked esx01 and on this host the migration was successfull.
data:image/s3,"s3://crabby-images/3c2c7/3c2c7ccad30756ad843e73cb91b69f7dd194668d" alt=""
I tried to manually migrating the vmk0 to the distributed vSwitch also ran in to an error in vCenter.
Right-click dvSwitch -> Add and Manage Hosts -> Manage Host Networking -> Select esx02
data:image/s3,"s3://crabby-images/61307/613076642cf773c0a4adad2488a310503f275d5b" alt=""
Click Next and leave the physical adapters as is, click next again.
On the next screen click on “Assign Port Group” next to vmk0.
data:image/s3,"s3://crabby-images/e885d/e885d973e45d4e381176db84c1c7ada573102b3d" alt=""
Click on ASSIGN next to the management portgroup
data:image/s3,"s3://crabby-images/a1ed1/a1ed1e73205f744540ff714b1c934ceba266e25a" alt=""
Next, Next, Finish…..Task is running and fails after a few seconds.
data:image/s3,"s3://crabby-images/11f30/11f30142871fcec4f2e8f631694571acf34db4f9" alt=""
Checking the Task Details on the ESX host:
data:image/s3,"s3://crabby-images/12f6e/12f6ea8b4f516472e7968adafb537138c02a7c03" alt=""
After some investigation and searching internally within VMware resources and also ran into this blog article: https://mhvmw.wordpress.com/2023/03/17/issue-with-nested-vcf-4-5-deployment-lab-only/
it is a MAC address conflict when the esxi takes the mac of the physical nic for vmk0.
By deleting and recreating the vmk0 interface you generate a new MAC address for vmk0.
Steps to check, delete and recreate vmk0 interface
Login via DCUI
data:image/s3,"s3://crabby-images/188f7/188f77589b59148315983ff491d9ab9b0a1cea95" alt=""
Enable ESXi Shell
data:image/s3,"s3://crabby-images/399ea/399ea634a673d31a3d56e81494fb44693f7adeb6" alt=""
Next, Click ALT+F1 to access ESXi console and login as root.
data:image/s3,"s3://crabby-images/994ad/994ad708292ab3e870463cf0cab68f97cc78c2e0" alt=""
Type the command:esxcli network ip interface list
data:image/s3,"s3://crabby-images/a06db/a06db941179255d06e63c100b3af7e24936904cb" alt=""
Make a note of the portgroup, in this case “Management network” and then remove the vmk0 with the following command:
esxcli network ip interface remove –-interface-name=vmk0
When vmk0 is deleted, we can immediately create a new interface with the same name and portgroup. This is done by the following command:esxcli network ip interface add -–interface-name=vmk0 -p “Management Network”
To check if vmk0 is created again type the command:esxcli network ip interface list
data:image/s3,"s3://crabby-images/8a5fe/8a5fe4231500d5839ead98b14e6e5d5b00bdd2f4" alt=""
Click ALT+F2 to access ESXi DCUI and login to disable the ESXi shell.
Now we can configure the IP settings again via the DCUI
Go to Configure Management Settings -> IPv4 Configuration and set the static IPv4 configuration
data:image/s3,"s3://crabby-images/9b137/9b13750958a02bbe0742aa773a5cc449ed65bff3" alt=""
Hit Enter then Esc and Yes to restart the management network
Now we can try to redeploy via cloudbuilder, after this the deployment went on succesfully