Skip to main content

PowerShell Script to Check If Files Have Stopped Coming in

Introduction

I am currently working in an environment where database backup files are generated on production servers and it gets replicated across to another data centre.

The replication is done via a scheduled task in Windows Task Scheduler. The scheduled task merely runs the robocopy command with the appropriate parameters.


Detecting if the Files Have Stopped Replicating

One of the things I've learnt all these years is that if you forget to check if something is working, it ends up being that that's when it stops working.

I have created a PowerShell script which will read a text file containing a list of folders it needs to check to determine if the latest backup files have come in or not. It will send an e-mail to the appropriate administrators.

You can modify the PowerShell script to meet your needs, but I will use it as a way to demonstrate PowerShell programming.

DISCLAIMER:

It is NOT implied that it will work in your environment and that it will suit your particular purpose. You should review and modify it to suit your own needs.


Script Listing


## Start of Script
#########################################################################################################
##
##
## This script checks the backup folders as listed in listofbackupdirs.txt
##
## and test to see if the last backup file to have come in for that folder is within the specified number of hours as specified in the file
##
## 
## 
## 
##
##

## Clears the screen

clear-host


## Initializes variables

$ScriptsFolder="F:\PowerShell\Scripts\CheckBackupFilesFlow"
$listofbackupdirs="listofbackupdirs.txt"
$haserrored=$false
$emailToAddress="Admin Nistrator1<ANistrator1@myorg.com.au>","Admin Nistrator2<ANistrator2@myorg.com.au>"

$mydate=get-date -uformat %Y%m%d%H%M
$report="$ScriptsFolder\ErrorLog-" + $mydate+".log";


## Get current date and time

$a=get-date

  
write-output "Checking Backup Folders ....."
write-output "Checking Backup Folders ....." > $report ;
write-output $a >> $report ;

set-location -Path $ScriptsFolder


## reads the list of backup directories and the specified number of hours

Import-Csv $listofbackupdirs | foreach-object -process {
  [int64]$offsethours=$_.OffsetHours;
  $backuppath=$_.BackupPath;

  write-output $backuppath;


  ## Finds the last file that have come in in that backup folder by sorting the files by creation time. It will also sort by file names if there are 
  ## different sets of file names in the same folder - so be careful here, as the last file to come in may not be what you are expecting. 

$b=get-childitem $backuppath  | where-object {$_.Mode -ne "d----"} | 
                                      sort-object -property $_.CreationTime -Descending | 
                                                     select-object -Index 0


## Calculates the offset timeframe between the current time and the timestamp of the last file that is found by the sort-object cmdlet in the directory

  $timedelta = New-Timespan -Start  $b.CreationTime  -End $a


## Checks to see if the calculated offset (timedelta) is greater than what is specified in the file

  If ($timedelta.Ticks -ge $offsethours * 36000000000 ) {
   
    $haserrored=$true;

    $outputmessage = "Backups are not coming in for " + $backuppath 
     
    write-output $outputmessage;
    write-output $outputmessage >> $report;

    write-output "Last file that came in was $b ";
    write-output "Last file that came in was $b " >> $report ;

    write-output $b;
    write-output $b >> $report ;

    write-output "";

  }

}

if ($haserrored -eq $true) {

send-mailmessage -To $emailToAddress -Subject "ALERT: Backup files failed to come in" -From "SERVERA Backup Server<donotreply@myorg.com.au>" -Body "Please see attached report." -SmtpServer "smtp" -Attachment $report

## NOTE: The above line highlighted in blue for clarity is one PowerShell cmdlet statement with parameters. They need to be on one line
## in the script and 
## cannot extend over multiple lines without explicitly using the grave accent (or backtick) i.e. `  . Some other character elements i.e. | or {  } 
## naturally allow multiple lines
}

## You may wish to add an else clause and send an e-mail where no errors are found. That's entirely up to you, depending on the
## frequency of your checks.

## End of Script


Contents of ListOfBackupDirs.txt
The below, including the header row, needs to be saved in a file called ListOfBackupDirs.txt and placed in the same location as the script. Put your own folder locations in, and a time in hours. The folders to be checked must be on separate lines, and you can have as many as you want (as much as PowerShell will allow).


BackupPath,OffsetHours
F:\SQLBackups\SQLServer1,2
F:\SQLBackups\SQLServer2,2
F:\SQLBackups\SQLServer3,4




Comments

Popular posts from this blog

How to Schedule an Exchange PowerShell Script in Task Scheduler

Exchange Management Shell Since Exchange 2007, Microsoft has provided the Exchange Management Shell so administrators can manage all aspects of the Exchange server from the command line. The Exchange Management Shell has Exchange specific PowerShell cmdlets. These Exchange cmdlets are not normally available in an ordinary PowerShell command environment. An example of what can be done in the Exchange Management Shell is to run a PowerShell script to list all the mailboxes on the Exchange server to a file. You can output columns based on display name, size of the mailbox, last logon, and other available mailbox attributes. You can also schedule a batch migration of mailboxes from one database to another such as the migration of mailboxes from Exchange 2010 to Exchange 2013. Scheduling the PowerShell Script Once you have written a PowerShell script and utilised the Exchange cmdlets, you can run it with no problems inside the Exchange Management Shell. If you were to try...

How To Migrate Mailboxes from Exchange 2010 to Exchange 2016 using PowerShell

The Scenario Your organisation have decided to migrate from Exchange 2010 to Exchange 2016. The Exchange 2016 server have been installed into your current Exchange Organization. The Mailbox role have been installed on the Exchange 2016 server and you are ready to start moving mailboxes from the Exchange 2010 server to the Exchange 2016 server. Migrating a Mailbox from Exchange 2010 to Exchange 2016 Using New-MoveRequest Migrating a single mailbox involves invoking the cmdlet New-MoveRequest from the Exchange Management Shell on the Exchange 2016 server . Make sure that your user account that you have logged into the server with have the Organization Management role. The common parameters that I use for the New-MoveRequest cmdlet is : New-MoveRequest -Identity 'useralias@somedomain.com' -TargetDatabase "DB02" -BadItemLimit 10 The -Identity parameter identifies the mailbox to be migrated. I usually use the e-mail address of the mailbox for the identity...

Hyper-V - Failover Cluster, Quick Migration and Live Migration

If you are like me and have mainly worked in small businesses then you may not have had the chance to setup a failover clustering environment. We've read all about it and how wonderful it is to have it, but unfortunately a lot of the times, the money is spent on more important things like staff salary and trying to keep the business afloat. Well, I am happy to say with the client I am working for right now, they have a very good failover clustering Hyper-V environment running on top of Windows Server 2012 R2  Datacentre attached to an EMC VNX 5300 SAN. The guy who set it up unfortunately no longer works there. To cut a long story short, I needed to move a VM to another node (another host in the cluster). With failover clustering being used for Hyper-V you need to run the Failover Cluster Manager to manage the VMs. You don't use the Hyper-V Manager, even though you can start it up and see the virtual machines. You can change some settings with Hyper-V Manager, but the reco...