File Backup Script

In this post, we share a PowerShell script designed to automate the backup of files from a specified source directory to a target backup directory. This script is essential for maintaining data safety and ensuring that you have copies of important files.
If you are looking for robust solutions to manage your server infrastructure, check out our software, ServerEngine, at https://serverengine.co. Let’s dive into the steps of the script.
### Step 1: Define the Source and Target Directories
The first step is to specify the source directory from which files will be backed up and the target directory where the backups will be stored.

$sourceDirectory = 'C:\ImportantFiles'
$backupDirectory = 'D:\Backup'

### Step 2: Create the Backup Directory if it Doesn’t Exist
Before backing up the files, we need to ensure that the target backup directory exists. If it does not exist, the script will create it.

if (-Not (Test-Path -Path $backupDirectory)) {
    New-Item -ItemType Directory -Path $backupDirectory
    Write-Host "Created backup directory: $backupDirectory"
}

### Step 3: Copy Files from Source to Backup
Next, we will copy files from the source directory to the backup directory. The script will overwrite existing files in the backup directory that have the same name.

Get-ChildItem -Path $sourceDirectory -File | ForEach-Object {
    $targetFilePath = Join-Path -Path $backupDirectory -ChildPath $_.Name
    Copy-Item -Path $_.FullName -Destination $targetFilePath -Force
    Write-Host "Backed up: $($_.Name) to $backupDirectory"
}

### Step 4: Confirm Completion of the Backup Process
Finally, we display a message to confirm that the backup process has been completed successfully, giving users assurance that their files are now safely backed up.

Write-Host "Backup process completed. All files from '$sourceDirectory' have been backed up to '$backupDirectory'."

Feel free to modify the source and backup paths as needed. This script is a vital part of any data management strategy, ensuring that your important files are always protected. Stay tuned for more useful PowerShell scripts on our website!