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
}

相关文章

vue阻止冒泡事件 阻止点击事件的执行 <div @click=&a...
尝试过使用网友说的API接口获取 找到的都是失效了 暂时就使用...
后台我拿的数据是这样的格式: [ {id:1 , parentId: 0, name:...
JAVA下载文件防重复点击,防止多次下载请求,Cookie方式快速简...
Mip是什么意思以及作用有哪些