Создание сценария PowerShell для резервного копирования файла и добавления даты

StackOverflow https://stackoverflow.com/questions/3671657

  •  01-10-2019
  •  | 
  •  

Вопрос

В настоящее время у меня есть один файл пакетных файлов для резервного копирования файла. Я бегу вручную, когда мне нужно создать резервную копию файла. Единственное, что я хотел бы добавить к ней текущая дата. Вот что у меня есть:

Xcopy / W / Y Active.db Active.db.backup

Файл назначения должен просто быть Active.db.backup.yyyymmdd. Как бы я пошел по созданию сценария, который позволит мне дважды щелкнуть его из Windows Explorer и сделать XCopy?

Это было полезно?

Решение

Вы можете настроить ваше имя файла, встраивая отформатированный [datetime]::now В имени файла в PowerShell вроде так:

xcopy /W /Y ACTIVE.DB "ACTIVE.DB.BACKUP.$([datetime]::now.ToString('yyyy-MM-dd'))"

Если линия чувствует себя занятым и ненаправленным, вы можете ревертировать его на несколько строк:

$now = [datetime]::now.ToString('yyyy-MM-dd')
xcopy /W /Y ACTIVE.DB "ACTIVE.DB.BACKUP.$now"

Чтобы получить дважды щелчок выполнения, я обычно делаю пакетный файл, который запускает команду PowerShell, как описано здесь:

Настройка скрипта PowerShell для автоматического выполнения

Другие советы

Просто чтобы указать, что вы можете сделать это с элементом копирования, например:

Set-Location $path
Copy-Item ACTIVE.DB "ACTIVE.DB.$(get-date -f yyyyMMdd)" -Force -Confirm

Если вы собираетесь надежно, тогда я бы использовал robocopy.exe.

Я только что сделал ежедневный / еженедельный / ежемесячный / ежедневный / ежегодный резервный сценарий в PowerShell в этом месяце, и надеюсь, что это поможет.

Этот сценарий резервного копирования DWMQY предназначен для Zip исходной папки в файл ZIP с именем даты, затем сохраняйте Zips:

  • Последние 7 дней
  • 4 недели (каждая пятница)
  • 6 месяцев (последняя пятница каждого месяца)
  • 4 квартала (последний месяц четверти)
  • 2 года (последняя четверть года).

Работает как запланированное задание на ежедневной основе, он помещает Zips в целевую папку, которая также является локальной папкой Microsoft OneDrive, поэтому Zips также удаленно синхронизируется на OneDrive Server. Те, кто устарел (не пятница ежедневно или без последних DWMQY), будут перемещены в папку без удаленного синхронизации.

Сегодня 5 марта 2016 года следующие ссылки должны быть в целевой папке:

  • 7 дней: 160304-160229-160227
  • 4 недели: 160304, 160226, 160219 160212
  • 6 месяцев: 160226, 160129, 161225, 151127, 151025, 150925
  • 4 квартала: 151225, 150925150626 150327
  • 2 года: 151225, 141226

Таким образом, будет 23 молнии (на самом деле меньше, так как Dups среди DWMQY) наши файлы представляют собой 250 текстовых документов, который составляет 0,4 ГБ после застенчивания, поэтому в общей сложности 23 * 0,4 = 9,2 ГБ, что меньше, чем OneDrive Free 15 GB квоты.

Для больших исходных данных можно использовать 7-zip, что обеспечивает максимальный размер 16-ми MIL TB. Для непосредственного резервного копирования папок вместо Zips не пробовал. Угадая это передаваемая процедура из текущего уровня ZIP.

# Note: there are following paths:
# 1. source path: path to be backed up. 
# 2. target path: current zips stored at, which is also a remote-sync pair's local path.
# 3. moved-to path: outdated zips to be moved in this non-sync'able location.
# 4. temp path: to copy the source file in to avoid zip.exe failing of compressing them if they are occupied by some other process.
# Function declaration
. C:\Source\zipSaveDated\Functions.ps1 
# <1> Zip data
$sourcePath = '\\remoteMachine1\c$\SourceDocs\*'
$TempStorage = 'C:\Source\TempStorage'
$enddate = (Get-Date).tostring("yyyyMMdd")
$zipFilename = '\\remoteMachine2\d$\DailyBackupRemote\OneDrive\DailyBackupRemote_OneDrive\' + $enddate + '_CompanyDoc.zip'
Remove-Item ($TempStorage + '\*') -recurse -Force
Copy-Item $sourcePath $TempStorage -recurse -Force

Add-Type -A System.IO.Compression.FileSystem
[IO.Compression.ZipFile]::CreateFromDirectory($TempStorage, $zipFilename) 

# <2> Move old files
$SourceDir = "\\remoteMachine2\d$\DailyBackupRemote\OneDrive\DailyBackupRemote_OneDrive"
$DestinationDir = "\\remoteMachine2\d$\DailyBackupRemote\bak" # to store files moved out of the working folder (OneDrive)
$KeepDays = 7
$KeepWeeks = 4
$KeepMonths = 6
$KeepQuarters = 4
$KeepYears = 2
# <2.1>: Loop files
$Directory = $DestinationDir
if (!(Test-Path $Directory))
{
    New-Item $directory -type directory -Force
}
$files = get-childitem $SourceDir *.*
foreach ($file in $files) 
{ # L1
    # daily removal will not remove weekly copy, 7 
    If($file.LastWriteTime -lt (Get-Date).adddays(-$KeepDays).date  `
        -and $file.LastWriteTime.DayOfWeek -NotMatch "Friday"  `
        )
        {
        Move-Item $file.fullname $Directory -force
        }
} # L1 >>
$files = get-childitem $SourceDir *.*
foreach ($file in $files) 
{ # L1
    # weekly removal will not remove monthly copy, 4
    If($file.LastWriteTime -lt (Get-Date).adddays(-$KeepWeeks * 7).date  `
        -and (Get-LastFridayOfMonth ($file.LastWriteTime)).Date.ToString("yyyyMMdd") -NotMatch $file.LastWriteTime.Date.ToString("yyyyMMdd")
        )
        {
        Move-Item $file.fullname $Directory -force
        }
} # L1 >>
$files = get-childitem $SourceDir *.*
foreach ($file in $files) 
{ # L1
    # monthly removal will not remove quarterly copy, 6
    If($file.LastWriteTime.Month -lt ((Get-Date).Year - $file.LastWriteTime.Year) * 12 + (Get-Date).Month - $KeepMonths `
        -and $file.LastWriteTime.Month -NotIn 3, 6, 9, 12
        )
        {
        Move-Item $file.fullname $Directory -force
        }
} # L1 >>
$files = get-childitem $SourceDir *.*
foreach ($file in $files) 
{ # L1
    # quarterly removal will not remove yearly copy, 4
    If($file.LastWriteTime.Month -lt ( (Get-Date).Year - $file.LastWriteTime.Year) * 12 + (Get-Date).Month - $KeepQuarters * 3 `
        -and $file.LastWriteTime.Month -NotIn 12
        )
        {
        Move-Item $file.fullname $Directory -force
        }
} # L1 >>
$files = get-childitem $SourceDir *.*
foreach ($file in $files) 
{ # L1
    # yearly removal will just go straight ahead. 2
    If($file.LastWriteTime.Year -lt (Get-Date).Year - $KeepYears )
        {
        Move-Item $file.fullname $Directory -force
        }
} # L1 >>


<Functions.ps1>
function Get-TimesResult3 
    {
    Param ([int]$a,[int]$b)
    $c = $a * $b
    Write-Output $c
    }

function Get-Weekday {
    param(
        $Month = $(Get-Date -format 'MM'),
        $Year = $(Get-Date -format 'yyyy'),
        $Days = 1..5
    )
$MaxDays = [System.DateTime]::DaysInMonth($Year, $Month)
1..$MaxDays | ForEach-Object {
        Get-Date -day $_ -Month $Month -Year $Year |
          Where-Object { $Days -contains $_.DayOfWeek }  
    }
}

function Get-LastFridayOfMonth([DateTime] $d) {    
    $lastDay = new-object DateTime($d.Year, $d.Month, [DateTime]::DaysInMonth($d.Year, $d.Month))
    $diff = ([int] [DayOfWeek]::Friday) - ([int] $lastDay.DayOfWeek)

    if ($diff -ge 0) {
        return $lastDay.AddDays(- (7-$diff))
    }
    else {
        return $lastDay.AddDays($diff)
    }    
}
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top