domain-name-system – 在Active Directory中使用PowerShell,如何将具有给定IP的所有DNS A记录更改为新IP?

前端之家收集整理的这篇文章主要介绍了domain-name-system – 在Active Directory中使用PowerShell,如何将具有给定IP的所有DNS A记录更改为新IP?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我们一直在移动数据中心,我有很多旧记录不正确,但在DNS中作为CNAME记录,但A记录具有直接IP(例如192.168.100.n)并且它们都转移到了新子网(10.19.100.n).

我只需编写一个powershell脚本来更改所有这些记录.我找到了这个网站:

http://www.indented.co.uk/index.php/2008/12/30/administering-microsoft-dns-in-powershell/

从中我创建了这个简单的脚本:

$dnsServer = "meldc2"

$scope = New-Object Management.ManagementScope("\\$dnsServer\root\MicrosoftDNS")
$path = New-Object Management.ManagementPath("MicrosoftDNS_Zone")
$options = New-Object Management.ObjectGetOptions($Null,[System.TimeSpan]::MaxValue,$True)
$ZoneClass= New-Object Management.ManagementClass($scope,$path,$options)
$Zones = Get-WMIObject -Computer $dnsServer -Namespace "root\MicrosoftDNS" -Class "MicrosoftDNS_Zone"
$Zones | Get-Member
foreach($Z in $Zones) {
  $Z | Select-Object Name,DsIntegrated,ZoneType,Reverse,Data
}

但这只能让我得到一个根区域列表.我不明白如何迭代每个区域中的所有条目.此外,我看到的所有示例都涉及添加新区域,但是在修改现有A记录时没有任何示例.

解决方法

我会使用 dnscmd修改DNS记录:
dnscmd meldc2.example.com /recorddelete example.com A host.example.com
dnscmd meldc2.example.com /recordadd example.com host A 10.19.100.n

这可以在批处理或PowerShell中循环包装,例如像这样:

$domain = "example.com"
dnscmd /enumrecords $domain `@ /type A | % {
  $name = $_.split(" ")[0]
  $ip = $_.split("`t")[-1] -replace "192.168.100","10.19.100"
  dnscmd /recorddelete $domain A "$name.$domain"
  dnscmd /recordadd $domain $name A $ip
}

猜你在找的HTML相关文章