Criei um script que monta (anexa) um VHD usando o Diskpart , limpa alguns arquivos do sistema e desmonta (desanexa). Ele usa um loop foreach e deve limpar vários VHD usando a mesma letra de unidade. No entanto, após o 1º VHD, ele falha. Também notei que, quando tento anexar manualmente um VHD com diskpart, diskpart com êxito, o Disk Manager mostra o disco com a letra da unidade correta, mas na mesma instância PoSH não consigo conectar (local do conjunto) a essa unidade. Se eu fizer um diskpart manual ao abrir o PoSH pela primeira vez, posso anexar e desanexar tudo o que quero e recebo a letra da unidade sempre. Existe algo que preciso fazer para redefinir o diskpart no script? Aqui está um trecho do script que estou usando.
function Mount-VHD {
[CmdletBinding()]
param (
[Parameter(Position=0,Mandatory=$true,ValueFromPipeline=$false)]
[string]$Path,
[Parameter(Position=1,Mandatory=$false,ValueFromPipeline=$false)]
[string]$DL,
[string]$DiskpartScript = "$env:SystemDrive\DiskpartScript.txt",
[switch]$Rescan
)
begin {
function InvokeDiskpart {
Diskpart.exe /s $DiskpartScript
}
## Validate Operating System Version ##
if (Get-WmiObject win32_OperatingSystem -Filter "Version < '6.1'") {throw "The script operation requires at least Windows 7 or Windows Server 2008 R2."}
}
process{
## Diskpart Script Content ## Here-String statement purposefully not indented ##
@"
$(if ($Rescan) {'Rescan'})
Select VDisk File="$Path" `nAttach VDisk
Exit
"@ | Out-File -FilePath $DiskpartScript -Encoding ASCII -Force
InvokeDiskpart
Start-Sleep -Seconds 3
@"
Select VDisk File="$Path"`nSelect partition 1 `nAssign Letter="$DL"
Exit
"@ | Out-File -FilePath $DiskpartScript -Encoding ASCII -Force
InvokeDiskpart
}
end {
Remove-Item -Path $DiskpartScript -Force ; ""
Write-Host "The VHD ""$Path"" has been successfully mounted." ; ""
}
}
function Dismount-VHD {
[CmdletBinding()]
param (
[Parameter(Position=0,Mandatory=$true,ValueFromPipeline=$false)]
[string]$Path,
[switch]$Remove,
[switch]$NoConfirm,
[string]$DiskpartScript = "$env:SystemDrive\DiskpartScript.txt",
[switch]$Rescan
)
begin {
function InvokeDiskpart {
Diskpart.exe /s $DiskpartScript
}
function RemoveVHD {
switch ($NoConfirm) {
$false {
## Prompt for confirmation to delete the VHD file ##
"" ; Write-Warning "Are you sure you want to delete the file ""$Path""?"
$Prompt = Read-Host "Type ""YES"" to continue or anything else to break"
if ($Prompt -ceq 'YES') {
Remove-Item -Path $Path -Force
"" ; Write-Host "VHD ""$Path"" deleted!" ; ""
} else {
"" ; Write-Host "Script terminated without deleting the VHD file." ; ""
}
}
$true {
## Confirmation prompt suppressed ##
Remove-Item -Path $Path -Force
"" ; Write-Host "VHD ""$Path"" deleted!" ; ""
}
}
}
## Validate Operating System Version ##
if (Get-WmiObject win32_OperatingSystem -Filter "Version < '6.1'") {throw "The script operation requires at least Windows 7 or Windows Server 2008 R2."}
}
process{
## DiskPart Script Content ## Here-String statement purposefully not indented ##
@"
$(if ($Rescan) {'Rescan'})
Select VDisk File="$Path"`nDetach VDisk
Exit
"@ | Out-File -FilePath $DiskpartScript -Encoding ASCII -Force
InvokeDiskpart
Start-Sleep -Seconds 10
}
end {
if ($Remove) {RemoveVHD}
Remove-Item -Path $DiskpartScript -Force ; ""
}
}
Respostas:
Não consigo ver o ponto exato em que seu script está falhando; no entanto, o teste Set-Location que você mencionou me lembra um problema que tive no PoSH ao tentar mapear / desmapear / mapear repetidamente locais em um script.
/programming/10994979/net-use-only-works-once-in-powershell
Em uso curto
FILESYSTEM::X:\
ao invés de
X:\
EDIT: Ok, então eu realmente passei 30 segundos lendo seu script. eu colocaria
$Path = FILESYSTEM::$Path
No to de cada função.
fonte
Eu sei que isso não é diretamente uma resposta, mas você tentou não montá-lo em uma letra de unidade? Use a
assign mount=<PATH>
opção e monte seu script mais limpo para trabalhar nesse subdiretório.fonte