PoshCode Archive  Artifact [be2e8b6812]

Artifact be2e8b6812c026b683e9614776438f4723fff5f0044fd1d25eab2d6b57d8a41d:

  • File Monitor-FileSize.ps1 — part of check-in [8248ea8d09] at 2018-06-10 13:27:49 on branch trunk — This function/script monitors the size of a file and all of its sub-directories. It can also monitor one specific file but the user must specifiy the exact path in that case. Usefull for making sure that disk space on a server doesn’t fill up unexpectedly. (user: Paul Kiri size: 2843)

# encoding: ascii
# api: powershell
# title: Monitor-FileSize
# description: This function/script monitors the size of a file and all of its sub-directories.  It can also monitor one specific file but the user must specifiy the exact path in that case.  Usefull for making sure that disk space on a server doesn’t fill up unexpectedly.
# version: 0.1
# type: function
# author: Paul Kiri
# license: CC0
# function: Monitor-FileSize
# x-poshcode-id: 3576
# x-archived: 2016-04-06T11:20:51
# x-published: 2013-08-13T06:33:00
#
# EDIT:  Syntax errors at the bottom of script fixed.
#
function Monitor-FileSize
{

<#

.Synopsis
    Checks the file size of a given file until it reaches the specified size
.Description
    Checks the file size of a given file until it reaches the specified size.  AT that point, it alerts the user as to what the original file-size-boundry was and what it currently is.  The interval at which the script runs can be specified by the user.
.Parameter FilePath
    Path of the file that will be monitored.  If not pointed to a specific file, the script will montior all sub-directories as well.  ie. if pointed to C:\ drive, will monitor ALL files on C:\ drive
.Parameter Size
    File size is monitored against this value. When file size is equal or greater than this value, user alert is triggered.  Enter size constraints as integer values (ex: -Size 100 NOT -Size 100kb)
.Parameter Interval
    The wait interval between the executions of the function. The value of this parameter is in seconds and default value is 5 seconds
.Example
    Monitor-FileSize -FilePath C:\Test -Size 100
    
    Returns a message to the user alerting them when at least 100kb worth of memory is stored in the selected location.
.Example
    Monitor-FileSize -FilePath C:\Test -Size 100 -Interval 20
    
    Checking the size of the file and all sub-directories every 20 seconds
.Notes
    This script cannot be run as a background job and so must have a separate PowerShell window on which it can be running.

	Author: Paul Kiri.
#>

param
(
[Parameter(mandatory=$true,position=0)]
[string[]]$FilePath
,
[Parameter(mandatory=$true,position=1)]
[int]$Size
,
[Parameter(mandatory=$false)]
[int]$Interval=5
)
if((Test-Path $FilePath))
{
   While($FS -le $Size)
   {
      Start-Sleep -Seconds $Interval
      $FileSize = get-childitem $FilePath -Recurse -Include *.* | foreach-object -Process { $_.length / 1024 } | Measure-Object -Sum | Select-Object -Property Sum
      $FS = $FileSize.Sum
   }
} 

if (Test-Path $FilePath)
{
Write-Output "The files at location, $FilePath , have exceeded $Size kb and are now $('{0:N4}' -f $FileSize.Sum) kb in size."
}

else{"The path '$FilePath' could not be reached or does not exist.  Please check the path name."}

}