Check physical memory usage. Email report if ram usage exceeds 90%. Write the top ten processes by memory usage to report.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 | ###########################################################
# Check physical memory usage.
# Email alert if ram usage exceeds 90%.
# Display the top ten processes by memory usage.
###########################################################
puts "\n executing [info script]\n"
# make script drive independent.
set drive [lindex [file split [info nameofexecutable]] 0 ]
puts "\n proclib = $drive/scripts/TCL/proclib"
########################################################
# Source utility procs.
########################################################
source [ file join $drive scripts/TCL/proclib/checkFile_proc.tcl ]
source [ file join $drive scripts/TCL/proclib/smtp_proc.tcl ]
source [ file join $drive scripts/TCL/proclib/reportHeader_proc.tcl ]
source [ file join $drive scripts/TCL/proclib/printColumns.tcl ]
source [ file join $drive scripts/TCL/proclib/convertToMb.tcl ]
########################################################
# Source packages.
########################################################
package require twapi
package require winutils
package require Tclx
package require math::fuzzy
######################################
# Proc - check memory usage.
######################################
proc checkMem {} {
puts "\n checkMem \n"
while {1} {
# pause for 30 seconds
after 30000
# check physical memory utilization over a ten second interval.
array set meminfo [twapi::get_memory_info -all]
set totalPhysicalMem $meminfo(-totalphysical)
set availPhysicalMem $meminfo(-availphysical)
set totalCommit $meminfo(-totalcommit)
set availCommit $meminfo(-availcommit)
set swapFiles $meminfo(-swapfiles)
set physicalMemUsage [ expr { (double ($totalPhysicalMem - $availPhysicalMem)/$totalPhysicalMem ) } ]
set usedPerc [ expr { [math::fuzzy::troundn $physicalMemUsage 2] *100 } ]
# if memory usage is > 90% and alert has not been generated send error report.
if { ![ info exist report ] } {
set report false
}
if { $usedPerc > 90 && [ string is false $report ] } {
set report true
writeReport meminfo $usedPerc
} else {
set continue true
}
# if memory usage is < 90% and alert has been generated send OK report.
if { $usedPerc < 90 && [ string is true $report ] } {
set report false
writeReport meminfo $usedPerc
} else {
set continue true
}
}
}
######################################
# Proc - write report
######################################
proc writeReport { meminfo usedPerc } {
global reportFile
global reportFileId
upvar $meminfo a
set header "$::env(COMPUTERNAME) - Check Memory Usage"
reportHeader $reportFileId $header $reportFile
set s "*****************************************"
set t1 [ format "%-15s %s" " " $s ]
set s "The End"
set t2 [ format "%-35s %s" " " $s ]
set t3 "$::env(COMPUTERNAME) - Memory utilization is $usedPerc\%\. "
puts $reportFileId \n$t3\n
set s "*****************************************"
set t1 [ format "%-15s %s" " " $s ]
foreach e [ memDetails a ] {
puts $reportFileId [ format "%-15s %s" " " $e ]
}
set t9 "Memory utilization - Top Ten"
puts $reportFileId \n$t1
puts $reportFileId [ format "%-15s %s" " " $t9 ]
puts $reportFileId $t1\n
set spaces " "
set w1 [ string length "ProcessName" ]
set w2 [ string length "ProcessId" ]
set w3 [ string length "WorkingSet" ]
set w4 [ string length "WorkingsetPeak" ]
puts $reportFileId [ format "%-15s %-20s %${w2}s %${w3}s %${w4}s\n" $spaces \
"ProcessName" \
"ProcessId" \
"WorkingSet" \
"WorkingsetPeak" ]
foreach e [ processDetails ] {
set processName [ lindex $e 0 ]
set processId [ lindex $e 1 ]
set workingset [ toMB [ lindex $e 2 ] ]
set workingsetpeak [ toMB [ lindex $e 3 ] ]
set width [ string length $processId ]
puts $reportFileId [ format "%-15s %-20s %${w2}s %${w3}s %${w4}s" $spaces \
$processName \
"$processId" \
"$workingset mb" \
"$workingsetpeak mb" ]
}
puts $reportFileId \n$t1
puts $reportFileId $t2
puts $reportFileId $t1
emailReport $usedPerc
ftruncate -fileid $reportFileId 0
}
######################################
# Proc - get memory details.
######################################
proc memDetails { meminfo } {
upvar $meminfo a
set totalPhysicalMem $a(-totalphysical)
set availPhysicalMem $a(-availphysical)
set totalCommit $a(-totalcommit)
set availCommit $a(-availcommit)
set swapFiles $a(-swapfiles)
set width 30
catch { puts_tabular $width "Physical memory:" "Total [toMB $a(-totalphysical)] MB, Available [toMB $a(-availphysical)] MB" } r
set t1 $r
catch { puts_tabular $width "Commit:" "Total [toMB $a(-totalcommit)] MB, Available [toMB $a(-availcommit)] MB" } r
set t2 $r
catch { puts_tabular $width "Swap files:" "[join $a(-swapfiles) {, }]" } r
set t3 $r
# allocated swap file space = (total commit memory - total physical memory)
set swapFileSpace [ expr { $totalCommit - $totalPhysicalMem } ]
catch { puts_tabular $width "Allocated swap file space:" "[toMB $swapFileSpace] MB" } r
set t4 $r
# available swap file space = (available commit memory - available physical memory)
set availSwapFileSpace [ expr { $availCommit - $availPhysicalMem } ]
catch { puts_tabular $width "Available swap file space:" "[toMB $availSwapFileSpace] MB" } r
set t5 $r
return [ list $t1 $t2 $t3 $t4 $t5 ]
}
##################################################
# Proc - get memory usage by top ten processes.
##################################################
proc processDetails {} {
# puts "\n processDetails \n"
set processList [ lsort [ winutils::processes ] ]
# calculate the cpu utilization for each process then sort and select the top ten.
foreach e $processList {
set processName [ lindex $e 0 ]
set processId [ lindex $e 1 ]
array set meminfo [ twapi::get_process_info $processId -workingset -workingsetpeak]
lappend usageList [ list $processName $processId $meminfo(-workingset) $meminfo(-workingsetpeak) ]
}
set x [ lsort -decreasing -integer -index 2 $usageList ]
set topTen [ lrange [ lsort -decreasing -integer -index 2 $usageList ] 0 9 ]
return $topTen
}
###########################################
# Email Report
###########################################
proc emailReport { usedPerc } {
global reportFile
global reportFileId
flush $reportFileId
set computerName $::env(COMPUTERNAME)
if { $usedPerc < 90 } {
set subject "$computerName - Memory Alert Over."
} else {
set subject "$computerName - Memory Alert."
}
sendSimpleMessage you@youremail.com $subject $reportFile
}
######################################
# Control Section.
######################################
######################################
# Set Variables
######################################
set processId [ twapi::get_current_process_id ]
set eventId [ twapi::eventlog_open -write ]
set data "CHECKMEM STARTING"
twapi::eventlog_write $eventId 1 -type information -loguser -data $data
twapi::eventlog_close $eventId
set reportFile [ file join $drive reports/notify/checkMem.txt ]
#########################################
# Check if files exist.
#########################################
checkFile [file dirname $reportFile]
######################################
# Open output files.
######################################
set reportFileId [open $reportFile w]
###################################
# Global variables.
###################################
global reportFile
global reportFileId
checkMem
|
Tags: windows