Microsoft MVP성태의 닷넷 이야기
오류 유형: 902. Visual Studio - error MSB3021: Unable to copy file [링크 복사], [링크+제목 복사],
조회: 13498
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

Visual Studio - error MSB3021: Unable to copy file

Visual Studio에서 csproj의 ItemGroup/Content를 이용한 파일 복사를 하다 보면,

<Project Sdk="Microsoft.NET.Sdk">

    <PropertyGroup>
        <OutputType>Exe</OutputType>
        <TargetFramework>net8.0</TargetFramework>
        <ImplicitUsings>enable</ImplicitUsings>
        <Nullable>enable</Nullable>
    </PropertyGroup>

    <ItemGroup>
        <PackageReference Include="IronPython" Version="3.4.1" />
        <PackageReference Include="IronPython.StdLib" Version="3.4.1" />
    </ItemGroup>

    <ItemGroup>
        <Content Include="C:\Python310\**">
            <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
        </Content>
    </ItemGroup>

    <ItemGroup>
        <None Update="test.py">
            <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
        </None>
    </ItemGroup>

</Project>

경우에 따라 이런 복사 오류가 발생할 수 있습니다

C:\Program Files\Microsoft Visual Studio\2022\Enterprise\MSBuild\Current\Bin\amd64\Microsoft.Common.CurrentVersion.targets(5254,5): error MSB3021: Unable to copy file "C:\Python312\tensorflow\python\Lib\site-packages\tensorflow\include\tensorflow\compiler\xla\mlir_hlo\_virtual_includes\shape_component_analysis\mhlo\analysis\shape_component_analysis.h" to "bin\Debug\net8.0\python\Lib\site-packages\tensorflow\include\tensorflow\compiler\xla\mlir_hlo\_virtual_includes\shape_component_analysis\mhlo\analysis\shape_component_analysis.h". Could not find a part of the path 'bin\Debug\net8.0\python\Lib\site-packages\tensorflow\include\tensorflow\compiler\xla\mlir_hlo\_virtual_includes\shape_component_analysis\mhlo\analysis\shape_component_analysis.h'.


메시지에 포함된 "Could not find a part of the path" 문구가 다소 혼란스러운데요, 물론 경로를 찾지 못한 상황에서도 발생할 수 있겠지만 위와 같은 경우에는 경로가 너무 길어서 발생하는 문제입니다.

재미있는 건, 해당 문제는 비주얼 스튜디오와 MSBuild로 빌드할 때만 발생한다는 점입니다. 반면 dotnet으로 직접 빌드하면 오류 없이 잘 복사가 됩니다. ^^;

이상하군요, 원래 dotnet은 내부적으로 MSBuild를 호출하는 것으로 아는데... 어쨌든, 현상이 저렇게 나옵니다.




만약 명령행으로 빌드하는 경우라면, 그냥 msbuild에서 dotnet으로 변경하면 되겠지만 문제는 비주얼 스튜디오에서 빌드 시 저런 문제가 발생한다는 점입니다.

이런 경우 문제 해결이 아닌, 우회 해법으로 그냥 경로가 너무 길지 않도록 OutputPath를 지정하는 방법이 있습니다.

<Project Sdk="Microsoft.NET.Sdk">
    <!-- 생략 -->

    <PropertyGroup Condition="'$(Configuration)' == 'Debug'">
        <OutputPath>c:\temp\Console</OutputPath>
    </PropertyGroup>
</Project>

msbuild ConsoleApp3.csproj -p:Configuration=Debug

또는, Windows 10 이상의 운영체제라면 깔끔하게 레지스트리 설정을 통해 제약을 없앨 수 있습니다.

Enable Long Paths in Windows 10, Version 1607, and Later
; https://learn.microsoft.com/en-us/windows/win32/fileio/maximum-file-path-limitation?tabs=registry
; https://www.backupery.com/how-to-enable-ntfs-long-paths-in-windows/

Windows Registry Editor Version 5.00

[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\FileSystem]
"LongPathsEnabled"=dword:00000001

(과거 버전은 어땠는지 모르겠지만) 현재의 Windows 11 환경에서는 재부팅 필요 없이 바로 반영돼 오류 없이 빌드할 수 있습니다.




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 4/30/2024]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 31  [32]  33  34  35  36  37  38  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
13233정성태1/28/202319934오류 유형: 840. C# - WebClient로 https 호출 시 "The request was aborted: Could not create SSL/TLS secure channel" 예외 발생
13232정성태1/27/202315782스크립트: 43. uwsgi의 --processes와 --threads 옵션
13231정성태1/27/202313895오류 유형: 839. python - TypeError: '...' object is not callable
13230정성태1/26/202315411개발 환경 구성: 660. WSL 2 내부로부터 호스트 측의 네트워크로 UDP 데이터가 1개의 패킷으로만 제한되는 문제
13229정성태1/25/202318278.NET Framework: 2090. C# - UDP Datagram의 최대 크기
13228정성태1/24/202319769.NET Framework: 2089. C# - WMI 논리 디스크가 속한 물리 디스크의 정보를 얻는 방법 [2]파일 다운로드1
13227정성태1/23/202317979개발 환경 구성: 659. Windows - IP MTU 값을 바꿀 수 있을까요? [1]
13226정성태1/23/202315135.NET Framework: 2088. .NET 5부터 지원하는 GetRawSocketOption 사용 시 주의할 점
13225정성태1/21/202316232개발 환경 구성: 658. Windows에서 실행 중인 소켓 서버를 다른 PC 또는 WSL에서 접속할 수 없는 경우
13224정성태1/21/202315314Windows: 221. Windows - Private/Public/Domain이 아닌 네트워크 어댑터 단위로 방화벽을 on/off하는 방법
13223정성태1/20/202314606오류 유형: 838. RDP 연결 오류 - The two computers couldn't connect in the amount of time allotted
13222정성태1/20/202315157개발 환경 구성: 657. WSL - DockerDesktop.vhdx 파일 위치를 옮기는 방법
13221정성태1/19/202315875Linux: 57. C# - 리눅스 프로세스 메모리 정보파일 다운로드1
13220정성태1/19/202316479오류 유형: 837. NETSDK1045 The current .NET SDK does not support targeting .NET ...
13219정성태1/18/202315178Windows: 220. 네트워크의 인터넷 접속 가능 여부에 대한 판단 기준
13218정성태1/17/202314869VS.NET IDE: 178. Visual Studio 17.5 (Preview 2) - 포트 터널링을 이용한 웹 응용 프로그램의 외부 접근 허용
13217정성태1/13/202315997디버깅 기술: 185. windbg - 64비트 운영체제에서 작업 관리자로 뜬 32비트 프로세스의 덤프를 sos로 디버깅하는 방법
13216정성태1/12/202314308디버깅 기술: 184. windbg - 32비트 프로세스의 메모리 덤프인 경우 !peb 명령어로 나타나지 않는 환경 변수
13215정성태1/11/202318763Linux: 56. 리눅스 - /proc/pid/stat 정보를 이용해 프로세스의 CPU 사용량 구하는 방법 [1]
13214정성태1/10/202319156.NET Framework: 2087. .NET 6부터 SourceGenerator와 통합된 System.Text.Json [1]파일 다운로드1
13213정성태1/9/202315416오류 유형: 836. docker 이미지 빌드 시 "RUN apt install ..." 명령어가 실패하는 이유
13212정성태1/8/202318274기타: 85. 단정도/배정도 부동 소수점의 정밀도(Precision)에 따른 형변환 손실
13211정성태1/6/202318122웹: 42. (https가 아닌) http 다운로드를 막는 웹 브라우저
13210정성태1/5/202316651Windows: 219. 윈도우 x64의 경우 0x00000000`7ffe0000 아래의 주소는 왜 사용하지 않을까요?
13209정성태1/4/202314353Windows: 218. 왜 윈도우에서 가상 메모리 공간은 64KB 정렬이 된 걸까요?
13208정성태1/3/202316780.NET Framework: 2086. C# - Windows 운영체제의 2MB Large 페이지 크기 할당 방법파일 다운로드1
... 31  [32]  33  34  35  36  37  38  39  40  41  42  43  44  45  ...