Update guest IP address discovery for hyper-v guests.

Powershell helper script now returns error when guest IP address
cannot be discovered. When reading addresses from a network
device both IPv4 and IPv6 are stored and the IPv4 address has
precedence on returned address.
This commit is contained in:
Chris Roberts 2017-07-28 10:18:26 -07:00
parent a7b228eb69
commit 38fed54697
2 changed files with 38 additions and 19 deletions

View File

@ -23,6 +23,7 @@ module VagrantPlugins
return if env[:interrupted] return if env[:interrupted]
# Try to get the IP # Try to get the IP
begin
network_info = env[:machine].provider.driver.read_guest_ip network_info = env[:machine].provider.driver.read_guest_ip
guest_ip = network_info["ip"] guest_ip = network_info["ip"]
@ -35,7 +36,10 @@ module VagrantPlugins
@logger.warn("Invalid IP address returned: #{guest_ip}") @logger.warn("Invalid IP address returned: #{guest_ip}")
end end
end end
rescue Errors::PowerShellError
# Ignore, continue looking.
@logger.warn("Failed to read guest IP.")
end
sleep 1 sleep 1
end end
end end

View File

@ -7,21 +7,36 @@ Param(
$Dir = Split-Path $script:MyInvocation.MyCommand.Path $Dir = Split-Path $script:MyInvocation.MyCommand.Path
. ([System.IO.Path]::Combine($Dir, "utils\write_messages.ps1")) . ([System.IO.Path]::Combine($Dir, "utils\write_messages.ps1"))
$ip_address = ""
$vm = Get-VM -Id $VmId -ErrorAction "Stop" $vm = Get-VM -Id $VmId -ErrorAction "Stop"
$networks = Get-VMNetworkAdapter -VM $vm $networks = Get-VMNetworkAdapter -VM $vm
foreach ($network in $networks) { foreach ($network in $networks) {
if ($network.IpAddresses.Length -gt 0) { if ($network.IpAddresses.Length -gt 0) {
$ip_address = $network.IpAddresses[0] foreach ($ip_address in $network.IpAddresses) {
if (-Not ([string]::IsNullOrEmpty($ip_address))) { if ($ip_address.Contains(".")) {
$ip4_address = $ip_address
} elseif ($ip_address.Contains(":")) {
$ip6_address = $ip_address
}
if (-Not ([string]::IsNullOrEmpty($ip4_address)) -Or -Not ([string]::IsNullOrEmpty($ip6_address))) {
# We found our IP address! # We found our IP address!
break break
} }
} }
} }
}
if (-Not ([string]::IsNullOrEmpty($ip4_address))) {
$guest_ipaddress = $ip4_address
} elseif (-Not ([string]::IsNullOrEmpty($ip6_address))) {
$guest_ipaddress = $ip6_address
}
if (-Not ([string]::IsNullOrEmpty($guest_ipaddress))) {
$resultHash = @{ $resultHash = @{
ip = "$ip_address" ip = $guest_ipaddress
} }
$result = ConvertTo-Json $resultHash $result = ConvertTo-Json $resultHash
Write-Output-Message $result Write-Output-Message $result
} else {
Write-Error-Message "Failed to determine IP address"
}