Skip to content

A Windows command line application to backup your local files to an AWS S3 Bucket written in C# .net

License

Notifications You must be signed in to change notification settings

sconnellcom/BackupToS3

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 

Repository files navigation

BackupToS3

A Windows command line application to backup your local files to an AWS S3 Bucket written in C# .net

Sample Usage

  • Update the App.config (or the BackupToS3.exe.config) with your AWS Access Key, Secret Key, and region.
  • Update the BackupDocumentsToS3.bat with the path to the folder on your computer that you would like to backup along with any other backup settings.
  • Run the BackupDocumentsToS3.bat to begin the backup process.
  • Use the Windows Task Scheduler to schedule future backups. (Add the arguments to the "Add arguments(optional)" field in the Task Scheduler. Do not place quotes arround all of the arguments. Do place quotes arroud your folder paths if they have spaces.

Arguments

  • -bucketname followed by the AWS bucket name to send the files to.
  • -localpath followed by the local path of the folder to send to S3.
  • -bucketfolder followed by the folder in the AWS bucket to add the files/folders to.
  • -subfolders If this argument exists, the sub folders in your localpath will be sent to S3.
  • -checkmd5 If this argument exists, an MD5 of the local file will be created and checked against the MD5 available from AWS. Leaving this feature enabled takes significantly longer but ensures that your local files match the files on S3.
  • -pause If this argument exists, the console app will wait for a keypress before exiting.
  • -debug If this argument exists, additional information will be logged to the console/log file.
  • -pushdeletes If this argument exists, files in your S3 bucket that do not exist locally will be deleted.
  • -excludecachefolders If this argument exists, folders that match the listed cache folder names will not be pushed to S3, if they exist in S3, they will be removed.
  • -logfilepath followed by the local path of a text file that you would like to save a log of the actions performed by this application.

Features to Add

  • Catch exceptions, log issues, example: access denied
  • Test date modified, and S3 time zone
  • gzip before upload, set status in metadata
  • Support for a .S3BackupIgnore file or similar to prevent folders from being backed up
  • Add the ability to throttle bandwidth usage. (Not a problem when backing up servers or at the office but on my home internet connection, no one else can use the internet while large files are being backed up)
  • Multi thread?

About

A Windows command line application to backup your local files to an AWS S3 Bucket written in C# .net

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published