1. 程式人生 > >powershell遠程管理服務器磁盤空間的實現代碼

powershell遠程管理服務器磁盤空間的實現代碼

master rdquo const 組策略 logical subject 註冊表 ssi wds

一、啟用遠程管理

1、將管理服務器的trusthost列表改為*

運行Set-item wsman:localhostclienttrustedhosts ?value *

2、在遠程服務器上運行Enable-PSremoting

註:

在本地服務器上以Administrator運行“Enable-Psremoting 、 Winrm Quickconfig 、 Set-WSManQuickConfig”,均提示“訪問被拒絕”,可能的原因如下:

1.在工作組計算機上,確認組策略: secpol.msc > Local Policies > Security Options > Network Access: Sharing and security model for local accounts - change to classic

2.修改註冊表:Set-ItemProperty ?Path HKLM:SOFTWAREMicrosoftWindowsCurrentVersionPoliciesSystem ?Name LocalAccountTokenFilterPolicy ?Value 1 ?Type DWord
3.確認WinRM服務是否正在運行,Windows Firewall服務是否正在運行,網絡位置是否不是“公用”,如果要啟用PS遠程管理,此時網絡位置不能被設置為public,因為Windows 防火墻例外不能在網絡位置是public時被啟用。
4.Telnet localhost 47001是否可以連通
5.運行 winrm get winrm/config 是否會提示“訪問被拒絕”
6.Administrator密碼不能為空

遠程啟用開啟之後可以在cmd命令窗口輸入wbemtest測試是否可以連接遠程服務器,如圖:

技術分享圖片

連接成功的狀態如下所示:

技術分享圖片

下面就可以來取每個服務器的磁盤空間了

二、腳本

$server = "."
$uid = "sa"
$db="master"
$pwd="數據庫sa密碼"
$mailprfname = "test" ---需要跟select name FROM msdb.dbo .sysmail_profile一致
$recipients = "接收郵箱,多個用;隔開" 
$subject = "郵件標題"
$computernamexml = "E:powershellcomputername.xml"
$alter_xml = "E:powershellcpdisk.xml"
$pwd_xml = "E:powershellpwd.xml"
function GetServerName($xmlpath)
{
  $xml = [xml] (Get-Content $xmlpath)
  $return = New-Object Collections.Generic.List[string]
  for($i = 0;$i -lt $xml.computernames.ChildNodes.Count;$i++)
  {
    if ( $xml.computernames.ChildNodes.Count -eq 1)
    {
      $cp = [string]$xml.computernames.computername
    }
    else
    {
      $cp = [string]$xml.computernames.computername[$i]
    }
    $return.Add($cp.Trim())
  }
  $return
}
function GetAlterCounter($xmlpath)
{
  $xml = [xml] (Get-Content $xmlpath)
  $return = New-Object Collections.Generic.List[string]
  $list = $xml.counters.Counter
  $list
}
function Getpwd($xmlpath)
{
  $xml = [xml] (Get-Content $xmlpath)
  $returnpwd = New-Object Collections.Generic.List[string]
  for($i = 0;$i -lt $xml.pwd.ChildNodes.Count;$i++)
  {
    if ( $xml.pwds.ChildNodes.Count -eq 1)
    {
      $pw = [string]$xml.pwd.password
    }
    else
    {
      $pw = [string]$xml.pwd.password[$i]
    }
    $returnpwd.Add($pw.Trim())
  }
  $returnpwd
}
function CreateAlter($message)
{
  $SqlConnection = New-Object System.Data.SqlClient.SqlConnection 
  $CnnString ="Server = $server; Database = $db;User Id = $uid; Password = $pwd"
  $SqlConnection.ConnectionString = $CnnString 
  $CC = $SqlConnection.CreateCommand(); 
  if (-not ($SqlConnection.State -like "Open")) { $SqlConnection.Open() } 
  
  $cc.CommandText=
      " EXEC msdb..sp_send_dbmail 
       @profile_name = ‘$mailprfname‘
      ,@recipients = ‘$recipients‘
      ,@body = ‘$message‘
      ,@subject = ‘$subject‘
      "
  $cc.ExecuteNonQuery()|out-null 
  $SqlConnection.Close();
}
$names = GetServerName($computernamexml)
$pfcounters = GetAlterCounter($alter_xml)
$upwd = Getpwd($pwd_xml)
$report = ""
for($m=0;$m -lt $names.count;$m++)
{
$cp=$names[$m]
$p=New-Object -TypeName System.Collections.ArrayList
$uname="administrator"--因為取的服務器用戶名都是administrator,如果每臺機器不一樣,可以放在XML等文件中讀取
$pw=$upwd[$m]
$upassword=convertto-securestring $pw -AsplainText -force;
foreach ($pfc in $pfcounters)
{
  $filter="deviceID=‘"+$pfc.get_InnerText().Trim()+"‘" 
  #$Disk =get-wmiobject win32_logicaldisk -computername $cp -Filter $filter
  #$counter=$Disk.Freespace/1024MB
  $cred=new-object system.management.automation.PSCredential($uname,$upassword);
  $counter=(get-wmiobject -credential $cred -class win32_logicaldisk -computername $cp -filter $filter).Freespace/1024MB
  $total=(get-wmiobject -credential $cred -class win32_logicaldisk -computername $cp -filter $filter).Size/1024MB
  #$pfc = $pfcounters[$i]
  $path = "機器名:"+$cp+"; 盤符:"+$pfc.get_InnerText()
  $diskFree=";總磁盤空間大小為:"+[math]::truncate($total).ToString()+"G;當前剩余空間大小為:"+[math]::truncate($counter).ToString()+"G!"      
  $item = "{0} {1} " -f $path,$diskFree
  $report += $item + "`n"        
}  
   
}
$report
if($report -ne "")
{
  CreateAlter $report
}

效果:

技術分享圖片

附:

xml文件格式:

1、computername.xml

<computername>
    <computername>
    test
    </computername>
</computernames>

2、cpdisk.xml

<Counters>
    <Counter>C:</Counter>
    <Counter>D:</Counter>
</Counters>

3、pwd.xml

<pwd>
    <password>
     helloworld 
    </password>
<pwd>

完畢,歡迎拍磚!大笑

powershell遠程管理服務器磁盤空間的實現代碼