Remove-Item error: Cannot remove item [item path & name]: Access to the path '[item path & name]' is denied
Asked Answered
F

3

5

I'm new to PowerShell.

I'm trying to automate the deployment of dll components from a folder on a source server to multiple folders on the destination server. This seems like it should be simple enough: copy components from source (deployment) folder on source server to folders on destination server, verify copies and finally delete components from deployment folder on source server.

The copying of the files from the source server to the destination server is working without issue. However, when the script moves on to delete the components from the source server, I'm intermittently confronted with the error: "Remove-Item error: Cannot remove item [item path & name]: Access to the path '[item path & name]' is denied."

I've run this script several times; sometimes it completes with no problems, sometimes with the error. The error does not occur for every file to be deleted and seems to occur on different components each time it presents.

Below is the function I have written to remove components and verify deletions:

function DeleteSourceFiles($srcPath) {
    # Announce delete
    OutputToHostAndLog ("Files will be removed from "+$srcPath+"...")
    OutputToHostAndLog "Removing files..."

    # Deletes all file items (i.e. all except folders) in source folder
    $filesToDelete=Get-ChildItem $srcPath | Where-Object {$_ -is [IO.FileInfo]}
    ForEach($item in $filesToDelete) {
        Remove-Item $srcPath\$item -force

        # Verify deletions       
        if(Test-Path($srcPath+"\"+$item)) {
            OutputToHostAndLog ("Delete failed: "+$item.Name)        
            $fail++
        }
        else {
            OutputToHostAndLog ($item.Name+" deleted successfully...")
        }
    }
 }

The use of the -force parameter with the Remove-Item cmdlet does not appear to have any effect on the issue. The files (again, different files with each failure) don't appear to be isReadOnly anyway.

Similarly, running PowerShell as Administrator seems to have no effect, although Get-Acl for the source folder indicates that Administrator should have FullControl.

Is this a permissions issue that I am missing? Any suggestions very much appreciated...

EDIT: I updated my script thus:

function DeleteSourceFiles($srcPath) {
    # Announce delete
    OutputToHostAndLog ("Files will be removed from "+$srcPath+"...")
    OutputToHostAndLog "Removing files..."
    OutputToHostAndLog $gap

    # Delete all file items (i.e. all except folders) in source folder
    $filesToDelete=Get-ChildItem $srcPath | Where-Object {$_ -is [IO.FileInfo]} | ForEach {
        Remove-Item $_.FullName -Force

        # Verify deletions
        if(Test-Path($srcPath+"\"+$_)) {
            OutputToHostAndLog ("Delete failed: "+$_.Name)        
            $fail++
        }
        else {
            OutputToHostAndLog ($_.Name+" deleted successfully...")
        }
    }
}

This seems to work OK although I'm still not sure why this arrangement should produce different results. In the interest of learning, any insights would be greatly appreciated...

Foreconscious answered 8/4, 2014 at 14:17 Comment(1)
I have a similar error (PSv3). I have a hunch that it is the script itself that is maintaining the lock. Your original script stores the files in a variable (creating a lock?). The second one deletes the file before storing in the variable. I'm having difficulty rearranging my script to prove this out.Euphuism
C
7

Intermittent access denied errors likely indicate that one or more of the files you're trying to remove has been locked by another application. It's a really common problem when you're trying to clean up log directories.

The only thing I'd recommend to do is wait for the application with the lock to release the file.

Caddis answered 8/4, 2014 at 14:28 Comment(5)
I had considered the possibility that the files in question were maybe in use by another application but, although the files are copies of actual application .dlls, I created test folders on each server for script testing. Wouldn't this imply that these copies cannot be in use?Foreconscious
That would certainly imply they aren't in use. Are you saying your updated version of the script isn't having any issues?Caddis
So far, so good Jason. Seems strange that with a slight change to the syntactical structure, the script appears to function consistently when the original presented intermittent errors.Foreconscious
Thank you! My files were locked by the PAUSED google drive, telling me my permissions are denied, even as administrator, so I started digging into permissions, etc. Complete red herring, and I just needed to kill Google Drive. You saved me lots of time.Bribery
Waiting for the application lock to release the file seems pretty defeatistRausch
S
1

I fixed this problem by setting the security permissions for users to have 'Modify' and 'Full Control' added for the folder I was trying to delete from

Sanjiv answered 26/11, 2014 at 12:41 Comment(0)
S
0

I had this issue while running PowerShell in a Scheduled Task. I did a few things and it worked on the last one:

  1. Gave the user Full Control over the files in the folder.

  2. Made my group a principal

    a) e.g. New-ScheduledTaskPrincipal -GroupId "BUILTIN\Administrators" -RunLevel Highest

  3. Set the Task to use Highest Privileges:

scheduled task highest privileges

Skillful answered 2/4, 2021 at 15:55 Comment(0)

© 2022 - 2025 — McMap. All rights reserved.