Powershell PSCX Write-Zip работает медленно - PullRequest
0 голосов
/ 20 февраля 2012

Может кто-нибудь помочь мне разобраться, почему этот командлет PSCX 'Write-Zip' такой медленный? Требуется 1,5 часа, чтобы библиотека DotNetZip могла заархивировать те же папки примерно за 20 минут. (Проблема с библиотекой DotNetZip заключается в том, что она задыхается от больших файлов, поэтому я переключился на PSCX, который является отличным, классным небольшим индикатором выполнения, и он на самом деле тоже работает, только очень медленно).

Вот пример кода, дайте мне знать, если вам нужно что-то еще увидеть.

    $ElapsedTime = [System.Diagnostics.Stopwatch]::StartNew()

    Write-Host "Script Started at $(get-date)"

    Import-Module Pscx
    Import-Module BitsTransfer

    Write-Host "Just imported the BitsTransfer and Pscx modules"

    Write-Host "*** Starting backup portion of script ***"

    foreach($i in $appServers) {

            if (!(Test-Path -path \\$i\c$\newDeploy)) {
                New-Item \\$i\c$\newDeploy -type directory
                Write-Host "Just created newDeploy folder on $i"
            }
            if (!(Test-Path -path \\$i\c$\newDeploy\backup)) {
                New-Item \\$i\c$\newDeploy\backup -type directory
                Write-Host "Just created newDeploy\backup folder on $i"
            }
            if(!(Test-Path \\$i\c$\newDeploy\zipper.ps1)) {
                Start-BitsTransfer -Source \\$appDeployServer\c$\newDeploy\zipper.ps1 -Destination \\$i\c$\newDeploy
                Write-host "Just added zipper.ps1 to $i"
            }

    }

    foreach($i in $appServers) {

        $sessionForI = New-PSSession -computername $i
        Invoke-Command -Session $sessionForI -ArgumentList  $aosFolder, $i, $ElapsedTime -ScriptBlock {
            param ($aosFolder, $i, $ElapsedTime)

            Import-Module Pscx
            Write-Host "Just imported Pscx module for $i"

            if ((Test-Path C:\\newDeploy\\backup\\$aosFolder.zip)) {
                Remove-Item C:\\newDeploy\\backup\\$aosFolder.zip
                Write-Host "Just removed newDeploy\backup\$aosFolder.zip on $i"
            }

            Write-Host "Just started creating new ZIP file backup created on $i"
            Write-Host "   Elapsed Time: $($ElapsedTime.Elapsed.ToString())"

            cd "C:\Program Files (x86)\Folder\$aosFolder"
            Get-ChildItem "C:\Program Files (x86)\Folder\$aosFolder" -Recurse -Exclude *.e2e | Write-Zip -OutputPath "C:\newDeploy\backup\$aosFolder.zip" -NoClobber -Level 1

            write-host "   Elapsed Time: $($ElapsedTime.Elapsed.ToString())"
            Write-Host "Just finished creating new ZIP file backup created on $i"
        }
        remove-PSSession -session $sessionForI

    }

    Write-Host "Just ran second foreach loop to ZIP all folders to backup on each server"

    foreach($i in $appServers) {
        if(!(Test-Path -path C:\newDeploy\backup\$i)) {
            New-Item C:\newDeploy\backup\$i -type directory
            Write-Host "Just created DEPLOY SERVER's newDeploy\backup\$i folder for backups"
        }
        Start-BitsTransfer -Source \\$i\c$\newDeploy\backup\$aosFolder.zip -Destination C:\newDeploy\backup\$i
        Write-Host "$i backup ZIP transferred to deploy server"
    }

    Write-Host "Just ran third foreach loop to move all ZIP files to the backup server for each remote server"

    foreach($i in $appServers) {
        Remove-Item \\$i\c$\newDeploy\backup\$aosFolder.zip
        Write-Host "Just removed newDeploy\backup\$aosFolder.zip on $i"
    }

    Write-Host "Just ran forth foreach loop to delete all backup ZIP files to cleanup"

    $date = get-date -format "M-d-yyyy"
    Write-Zip -Path "C:\newDeploy\backup" -OutputPath "C:\newDeploy\backup\$date APPbackup.zip" -NoClobber -Level 1
    Write-Host "Just ran final ZIP command to put all server's backups into one neat ZIP"

    foreach($i in $appServers) {
        if((Test-Path -path C:\newDeploy\backup\$i)) {
            Remove-Item -Force -Recurse C:\newDeploy\backup\$i
            Write-Host "Just removed DEPLOY SERVER's newDeploy\backup\$i folder"
        }
    }
    Write-Host "Just ran fifth foreach loop to delete each server's backup folder on the local server to cleanup"

    Write-Host "*** Finished with backup portion of script ***"

    Write-Host "*** Starting deploy preparation portion of script ***"



    Write-Host "*** Finished with deploy preparation portion of script ***"

    Write-Host "Script Ended at $(get-date)"

Ответы [ 2 ]

3 голосов
/ 22 февраля 2012

Я бы порекомендовал вам использовать инструменты архива командной строки 7zip. Они довольно быстрые и могут работать с различными архивами.

http://downloads.sourceforge.net/sevenzip/7za920.zip

0 голосов
/ 18 февраля 2016

Вот как я это сделал:

set-alias sz "$env:C:\7za920\7za.exe"
sz a -mx9 -tzip -r $FileName $SourceFolder
...