Last active
February 23, 2016 19:58
-
-
Save richardsonlima/fadfb91d524aac1bfb21 to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# Created by Richardson Lima | |
# Create a file e.g: Run.bat and put this | |
# powershell -command "& {C:\Env\Script\WinServerReport.ps1 .\ServerList.txt}" | |
# | |
$date = Get-Date | |
$d = $date.day | |
$m = $date.month | |
$y = $date.year | |
$hoje = "$d$m$y" | |
$path = "C:\Env\Relatorio\$hoje" | |
New-Item -Path $path -ItemType directory -Force | |
############################################################### | |
$pw = Get-Content C:\Env\Credencial.txt | ConvertTo-SecureString | |
$cred = New-Object System.Management.Automation.PsCredential("user", $pw) | |
############################################################### | |
#Variables | |
$list = $args[0] | |
$computers = get-content $list | |
$thresholdspace = 20 | |
[int]$EventNum = 5 | |
[int]$ProccessNumToFetch = 10 | |
$ListOfAttachments = @() | |
$Report = @() | |
$CurrentTime = Get-Date | |
Function Get-HostUptime { | |
param ([string]$ComputerName) | |
$Uptime = Get-WmiObject -Class Win32_OperatingSystem -ComputerName $ComputerName | |
$LastBootUpTime = $Uptime.ConvertToDateTime($Uptime.LastBootUpTime) | |
$Time = (Get-Date) - $LastBootUpTime | |
Return '{0:00} Days, {1:00} Hours, {2:00} Minutes, {3:00} Seconds' -f $Time.Days, $Time.Hours, $Time.Minutes, $Time.Seconds | |
} | |
# Assemble the HTML Header and CSS | |
$HTMLHeader = @" | |
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Frameset//EN" "http://www.w3.org/TR/html4/frameset.dtd"> | |
<html><head><title>ATI - Relatório diário Windows Server</title> | |
<style type="text/css"> | |
<!-- | |
body { | |
font-family: Verdana, Geneva, Arial, Helvetica, sans-serif; | |
} | |
#report { width: 835px; } | |
table{ | |
border-collapse: collapse; | |
border: none; | |
font: 10pt Verdana, Geneva, Arial, Helvetica, sans-serif; | |
color: black; | |
margin-bottom: 10px; | |
} | |
table td{ | |
font-size: 12px; | |
padding-left: 0px; | |
padding-right: 20px; | |
text-align: left; | |
} | |
table th { | |
font-size: 12px; | |
font-weight: bold; | |
padding-left: 0px; | |
padding-right: 20px; | |
text-align: left; | |
} | |
h2{ clear: both; font-size: 130%; } | |
h3{ | |
clear: both; | |
font-size: 115%; | |
margin-left: 20px; | |
margin-top: 30px; | |
} | |
p{ margin-left: 20px; font-size: 12px; } | |
table.list{ float: left; } | |
table.list td:nth-child(1){ | |
font-weight: bold; | |
border-right: 1px grey solid; | |
text-align: right; | |
} | |
table.list td:nth-child(2){ padding-left: 7px; } | |
table tr:nth-child(even) td:nth-child(even){ background: #CCCCCC; } | |
table tr:nth-child(odd) td:nth-child(odd){ background: #F2F2F2; } | |
table tr:nth-child(even) td:nth-child(odd){ background: #DDDDDD; } | |
table tr:nth-child(odd) td:nth-child(even){ background: #E5E5E5; } | |
div.column { width: 320px; float: left; } | |
div.first{ padding-right: 20px; border-right: 1px grey solid; } | |
div.second{ margin-left: 30px; } | |
table{ margin-left: 20px; } | |
--> | |
.logo { | |
width: 290px; | |
height: 63px; | |
background: url() no-repeat; | |
} | |
</style> | |
</head> | |
<body> | |
"@ | |
foreach ($computer in $computers) { | |
$DiskInfo= Get-WMIObject -ComputerName $computer Win32_LogicalDisk | Where-Object{$_.DriveType -eq 3} | Where-Object{ ($_.freespace/$_.Size)*100 -lt $thresholdspace} ` | |
| Select-Object SystemName, DriveType, VolumeName, Name, @{n='Size (GB)';e={"{0:n2}" -f ($_.size/1gb)}}, @{n='FreeSpace (GB)';e={"{0:n2}" -f ($_.freespace/1gb)}}, @{n='PercentFree';e={"{0:n2}" -f ($_.freespace/$_.size*100)}} | ConvertTo-HTML -fragment | |
#region System Info | |
$OS = (Get-WmiObject Win32_OperatingSystem -computername $computer).caption | |
$AVGProc = Get-WmiObject -computername $computer win32_processor | Measure-Object -property LoadPercentage -Average | Select Average | |
$OS2 = gwmi -Class win32_operatingsystem -computername $computer | Select-Object @{Name = "MemoryUsage"; Expression = {"{0:N2}" -f ((($_.TotalVisibleMemorySize - $_.FreePhysicalMemory)*100)/ $_.TotalVisibleMemorySize) }} | |
$CPULoad = "$($AVGProc.Average)%" | |
$MemLoad = "$($OS2.MemoryUsage)%" | |
$SystemInfo = Get-WmiObject -Class Win32_OperatingSystem -computername $computer | Select-Object Name, TotalVisibleMemorySize, FreePhysicalMemory | |
$TotalRAM = $SystemInfo.TotalVisibleMemorySize/1MB | |
$FreeRAM = $SystemInfo.FreePhysicalMemory/1MB | |
$UsedRAM = $TotalRAM - $FreeRAM | |
$RAMPercentFree = ($FreeRAM / $TotalRAM) * 100 | |
$TotalRAM = [Math]::Round($TotalRAM, 2) | |
$FreeRAM = [Math]::Round($FreeRAM, 2) | |
$UsedRAM = [Math]::Round($UsedRAM, 2) | |
$RAMPercentFree = [Math]::Round($RAMPercentFree, 2) | |
#endregion | |
$TopProcesses = Get-Process -ComputerName $computer | Sort WS -Descending | Select ProcessName, Id, WS -First $ProccessNumToFetch | ConvertTo-Html -Fragment | |
#region Services Report | |
$ServicesReport = @() | |
$Services = Get-WmiObject -Class Win32_Service -ComputerName $computer | Where {($_.StartMode -eq "Auto") -and ($_.State -eq "Stopped")} | |
foreach ($Service in $Services) { | |
$row = New-Object -Type PSObject -Property @{ | |
Name = $Service.Name | |
Status = $Service.State | |
StartMode = $Service.StartMode | |
} | |
$ServicesReport += $row | |
} | |
$ServicesReport = $ServicesReport | ConvertTo-Html -Fragment | |
#endregion | |
#region Event Logs Report | |
$SystemEventsReport = @() | |
$SystemEvents = Get-EventLog -ComputerName $computer -LogName System -EntryType Error,Warning -Newest $EventNum | |
foreach ($event in $SystemEvents) { | |
$row = New-Object -Type PSObject -Property @{ | |
TimeGenerated = $event.TimeGenerated | |
EntryType = $event.EntryType | |
Source = $event.Source | |
Message = $event.Message | |
} | |
$SystemEventsReport += $row | |
} | |
$SystemEventsReport = $SystemEventsReport | ConvertTo-Html -Fragment | |
$ApplicationEventsReport = @() | |
$ApplicationEvents = Get-EventLog -ComputerName $computer -LogName Application -EntryType Error,Warning -Newest $EventNum | |
foreach ($event in $ApplicationEvents) { | |
$row = New-Object -Type PSObject -Property @{ | |
TimeGenerated = $event.TimeGenerated | |
EntryType = $event.EntryType | |
Source = $event.Source | |
Message = $event.Message | |
} | |
$ApplicationEventsReport += $row | |
} | |
$ApplicationEventsReport = $ApplicationEventsReport | ConvertTo-Html -Fragment | |
$SecurityEventsReport = @() | |
$SecurityEvents = Get-EventLog -ComputerName $computer security -EntryType Error,Warning -Newest $EventNum | |
foreach ($event in $SecurityEvents) { | |
$row = New-Object -Type PSObject -Property @{ | |
TimeGenerated = $event.TimeGenerated | |
EntryType = $event.EntryType | |
Source = $event.Source | |
Message = $event.Message | |
} | |
$SecurityEventsReport += $row | |
} | |
$SecurityEventsReport = $SecurityEventsReport | ConvertTo-Html -Fragment | |
#endregion | |
#region Uptime | |
# Fetch the Uptime of the current system using our Get-HostUptime Function. | |
$SystemUptime = Get-HostUptime -ComputerName $computer | |
#endregion | |
# HTML Report | |
$CurrentSystemHTML = @" | |
<div id="logo"> | |
<img alt="" <div class="logo"/> | |
</a> | |
</div> | |
<hr noshade size=3 width="100%"> | |
<div id="report"> | |
<p><h2>Relatório do Servidor $computer - ORG</p></h2> | |
<h3>Informações do Sistema</h3> | |
<table class="list"> | |
<tr> | |
<td>Uptime</td> | |
<td>$SystemUptime</td> | |
</tr> | |
<tr> | |
<td>Hostname</td> | |
<td>$GetHostname</td> | |
<td>$Hostname</td> | |
</tr> | |
<tr> | |
<td>Sistema Operacional</td> | |
<td>$OS</td> | |
</tr> | |
<tr> | |
<td>Total RAM (GB)</td> | |
<td>$TotalRAM</td> | |
</tr> | |
<tr> | |
<td>RAM Livre (GB)</td> | |
<td>$FreeRAM</td> | |
</tr> | |
<tr> | |
<td>Percentual de RAM Livre</td> | |
<td>$RAMPercentFree</td> | |
</tr> | |
<tr> | |
<td>Carga CPU</td> | |
<td>$CPULoad</td> | |
</tr> | |
<tr> | |
<td>Carga RAM</td> | |
<td>$MemLoad</td> | |
</tr> | |
</table> | |
<!-- <IMG SRC="chart-$computer.png" ALT="$computer Chart"> --> | |
<h3>Informações de disco</h3> | |
<p>O(s) disco(s) listados abaixo tem menos que $thresholdspace % de espaço livre. Discos acima do valor de threshold não seram listados aqui.</p> | |
<p>Obs: A ausência de qualquer informação relativa ao item acima, evidência que não ocorreram eventos no período da coleta.</p> | |
<table class="normal">$DiskInfo</table> | |
<br></br> | |
<div class="first column"> | |
<h3>Processos do sistema - Top $ProccessNumToFetch - Maior uso de memória</h3> | |
<p>Os $ProccessNumToFetch processos abaixo estão com um valor muito alto de consumo de Working Set (WS) Memory (bytes) no servidor $computer</p> | |
<p>Obs: A ausência de qualquer informação relativa ao item acima, evidência que não ocorreram eventos no período da coleta.</p> | |
<table class="normal">$TopProcesses</table> | |
</div> | |
<div class="second column"> | |
<h3>Serviços do sistema - Habilitados automaticamente, mas não estão funcionando</h3> | |
<p>Os serviços abaixo estão definidos para inicialização automática, mas ainda não estão em execução no servidor $computer</p> | |
<p>Obs: A ausência de qualquer informação relativa ao item acima, evidência que não ocorreram eventos no período da coleta.</p> | |
<table class="normal">$ServicesReport</table> | |
</div> | |
<h3>Log de eventos - Ultimos $EventNum logs de eventos de System/Application que contém Warnings ou Errors</h3> | |
<p>Veja abaixo a lista dos ultimos $EventNum <b>eventos de log de sistema</b> que tiveram como característica Warning ou Error no servidor $computer</p> | |
<p>Obs: A ausência de qualquer informação relativa ao item acima, evidência que não ocorreram eventos no período da coleta.</p> | |
<table class="normal">$SystemEventsReport</table> | |
<p>Veja abaixo a lista dos ultimos $EventNum <b>eventos de log de aplicação</b> que tiveram como característica Warning ou Error no servidor $computer</p> | |
<p>Obs: A ausência de qualquer informação relativa ao item acima, evidência que não ocorreram eventos no período da coleta.</p> | |
<table class="normal">$ApplicationEventsReport</table> | |
<p>Veja abaixo a lista dos ultimos $EventNum <b>eventos de log de segurançca</b> que tiveram como característica Warning ou Error no servidor $computer</p> | |
<p>Obs: A ausência de qualquer informação relativa ao item acima, evidência que não ocorreram eventos no período da coleta.</p> | |
<table class="normal">$SecurityEventsReport</table> | |
"@ | |
# Add the current System HTML Report into the final HTML Report body | |
$HTMLMiddle += $CurrentSystemHTML | |
} | |
# Assemble the closing HTML . | |
$HTMLEnd = @" | |
</div> | |
</body> | |
</html> | |
"@ | |
# Assemble the final report from all our HTML sections | |
$HTMLmessage = $HTMLHeader + $HTMLMiddle + $HTMLEnd | |
# Save the report out to a file in the current path | |
$HTMLmessage | Out-File ((Get-Location).Path + "\RelatorioDiarioATIWindowsServer-$hoje.html") | |
$pathcopy = "C:\Env\Relatorio\$hoje" | |
Copy-Item -Path C:\Env\Script\RelatorioDiarioATIWindowsServer-$hoje.html -Destination $pathcopy -Force |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment