Skip to content

Instantly share code, notes, and snippets.

@richardsonlima
Last active February 23, 2016 19:58
Show Gist options
  • Save richardsonlima/fadfb91d524aac1bfb21 to your computer and use it in GitHub Desktop.
Save richardsonlima/fadfb91d524aac1bfb21 to your computer and use it in GitHub Desktop.
# 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