Temporary ASP.NET Files Are Not Deleted
Yesterday afternoon, I discovered that there were 64,725 items (consuming 2.41 GB) in the C:\Windows\Microsoft.NET\Framework\v2.0.50727\Temporary ASP.NET Files\root folder of my development VM for Microsoft Office SharePoint Server (MOSS) 2007. Apparently, each time I do an IISRESET or recycle an application pool, a new set of temporary files is generated but the old set is not being deleted.
I don't recall ever encountering this problem in the past, which makes me suspect that it is related to the fact that I am now running Windows Server 2008. Also note that I run SharePoint in "least privileged mode" -- meaning the various service accounts used by SharePoint are not members of the local Administrators group.
Doing a random spot check of the files, I noticed that they are indeed owned by the various SharePoint service accounts (e.g. the identity of the app pool running the Web application itself, or the identity running the SSP app pool). However, I also confirmed that the corresponding service account has been granted Full Control on the containing folder -- and thus it seems like ASP.NET should have no problem deleting these files.
Since this is only happening on my local development environment -- at least for the moment -- I'm not going to spend any more time investigating the issue at this point. In other words, I'll just "punt" it and create another script and add it to my Toolbox so I can periodically purge these files with minimal effort.
Here is my script (C:\NotBackedUp\Public\Toolbox\Scripts\Delete Temporary ASP.NET Files root folder.cmd), in case it might help anyone else out there with the same problem:
@echo off
setlocal
set ROOT_FOLDER=%SystemRoot%\Microsoft.NET\Framework\v2.0.50727\Temporary ASP.NET Files\root
if not exist "%ROOT_FOLDER%" goto RootFolderDoesNotExist
echo Stopping IIS...
iisreset /stop
echo Removing Temporary ASP.NET Files root folder...
rmdir /Q /S "%SystemRoot%\Microsoft.NET\Framework\v2.0.50727\Temporary ASP.NET Files\root"
echo Starting IIS...
iisreset /start
exit
:RootFolderDoesNotExist
echo Root folder does not exist: "%ROOT_FOLDER%"
pause
Now all I need to do is periodically right-click this script, click Run as administrator, wait for the files to be purged, and then get back to whatever I was doing before I noticed that I was running out of disk space ;-)
Note that I tried using %FrameworkDir%
instead of %SystemRoot%\Microsoft.NET\Framework
, but that doesn't work unless you run the script from an Administrator command prompt.
Comments
Anonymous
April 01, 2009
In a previous post , I hinted at some issues that I recently encountered after switching from WindowsAnonymous
April 01, 2009
The comment has been removed