성태의 닷넷 이야기
홈 주인
모아 놓은 자료
프로그래밍
질문/답변
사용자 관리
사용자
메뉴
아티클
외부 아티클
유용한 코드
온라인 기능
MathJax 입력기
최근 덧글
[정성태] Get Started with Milvus Vector DB i...
[정성태] cyberark/PipeViewer - A tool that...
[정성태] WinForms in a 64-Bit world – our st...
[정성태] 예제에서 SELECT_SQL도 내부적으로는 SqlCommand/...
[victor] SELECT_LINQ SELECT_SQL 같은 쿼리인...
[victor] 답변 갑사합니다. 예외(Exception)가 났습니다. ...
[정성태] 일단, 위의 방식대로 하면 예외(Exception) 없이 잘 동...
[정성태] Windows 10 (버전 1809)에 이런 기능이 ^^ 추가되...
[정성태] pde windbg extension ; https://lea...
[정성태] // GetEnumerator extensions for Ran...
글쓰기
제목
이름
암호
전자우편
HTML
홈페이지
유형
제니퍼 .NET
닷넷
COM 개체 관련
스크립트
VC++
VS.NET IDE
Windows
Team Foundation Server
디버깅 기술
오류 유형
개발 환경 구성
웹
기타
Linux
Java
DDK
Math
Phone
Graphics
사물인터넷
부모글 보이기/감추기
내용
<div style='display: inline'> <h1 style='font-family: Malgun Gothic, Consolas; font-size: 20pt; color: #006699; text-align: center; font-weight: bold'>파일 잠금이 바로 안 풀린다면? - The process cannot access the file '...' because it is being used by another process.</h1> <p> 이상하군요, 예를 들어 "tempfile.ps1" 파일을 생성해 다음과 같은 스크립트를 포함하면,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > function Start-Test { <span style='color: blue; font-weight: bold'>mkdir vendor</span> cd vendor <span style='color: blue; font-weight: bold'>echo "test" > "test.txt"</span> cd .. <span style='color: blue; font-weight: bold'>rmdir -r vendor</span> } For ($i=0; $i -le 10; $i++) { Start-Test } </pre> <br /> 실행 시 몇 번에 한 번은 꼭 잠금 오류가 발생합니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > E:\temp> powershell -File test.ps1 Directory: E:\temp Mode LastWriteTime Length Name ---- ------------- ------ ---- d----- 2020-03-20 오후 4:44 vendor <span style='color: blue; font-weight: bold'>rmdir : Cannot remove item E:\temp\vendor: The process cannot access the file 'E:\temp\vendor' because it is being used by another process.</span> At E:\temp\test.ps1:7 char:1 + rmdir -r vendor + ~~~~~~~~~~~~~~~ + CategoryInfo : WriteError: (E:\temp\vendor:DirectoryInfo) [Remove-Item], IOException + FullyQualifiedErrorId : RemoveFileSystemItemIOError,Microsoft.PowerShell.Commands.RemoveItemCommand </pre> <br /> 오류 메시지로 보면 분명히 "test.txt" 파일 자원이 열려 있기 때문으로 보이는데요, <a target='tab' href='https://www.sysnet.pe.kr/2/0/12205'>echo가 "Write-Output"의 alias</a>임을 감안할 때 다음과 같이 변경해도 결과는 마찬가지입니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > mkdir vendor cd vendor <span style='color: blue; font-weight: bold'>Write-Output "test" > test.txt</span> cd .. rmdir -r vendor </pre> <br /> PowerShell의 파이프라인 작업에 자원 해제 문제가 있는 걸까요? 확인을 위해, 자원이 확실하게 정리되는 닷넷 메서드를 호출해 봤는데도 역시 동일한 오류가 발생합니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > function Start-Test { if (!(Test-Path vendor)) { mkdir vendor } cd vendor <span style='color: blue; font-weight: bold'>$currentDir = Get-Location $filePath = [System.IO.Path]::Combine($currentDir, "test.txt") [System.IO.File]::WriteAllText($filePath, "test")</span> cd .. rmdir -r vendor } For ($i=0; $i -le 10; $i++) { Start-Test } </pre> <br /> <hr style='width: 50%' /><br /> <br /> 이쯤 되면, 이제 환경적인 요인을 살펴봐야 합니다. 그러고 보니, 해당 테스트를 수행한 경로가 dropbox의 하위 폴더라는 점이 눈에 띕니다. 맞습니다. dropbox가 관리하는 폴더는 변경된 파일들을 열어 동기화를 하느라 저런 식의 예외가 운에 따라 발생하게 됩니다. (물론, 이번 경우에는 dropbox였지만 다른 도구가 설치된 상황에서도 저런 오류가 발생할 수 있습니다.)<br /> <br /> 예전에도 관련 경험들이 있었지만,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > C# - 프로세스의 모든 핸들을 열람 ; <a target='tab' href='https://www.sysnet.pe.kr/2/0/12080'>https://www.sysnet.pe.kr/2/0/12080</a> 비주얼 스튜디오 - Unspecified error (Exception from HRESULT: 0x80004005 (E_FAIL)) ; <a target='tab' href='https://www.sysnet.pe.kr/2/0/10862'>https://www.sysnet.pe.kr/2/0/10862</a> </pre> <br /> dropbox 하나로 인해 헤매게 되는 경우가 종종 있군요.<br /> </p><br /> <br /><hr /><span style='color: Maroon'>[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]</span> </div>
첨부파일
스팸 방지용 인증 번호
2604
(왼쪽의 숫자를 입력해야 합니다.)