Microsoft MVP성태의 닷넷 이야기
VS.NET IDE: 91. Visual Studio에서 32/64비트 IIS Express 실행하는 방법 [링크 복사], [링크+제목 복사],
조회: 20990
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

Visual Studio에서 32/64비트 IIS Express 실행하는 방법

다음의 질문에 첨부된 웹 프로젝트를 보면,

오라클 db 사용관련 문의입니다.
; https://www.sysnet.pe.kr/3/0/1287

ODP.NET 어셈블리 및 그와 관련있는 64비트 Native DLL을 참조하고 있습니다. 그런데 Visual Studio에서 해당 프로젝트를 로드하고 F5키로 실행해 보면 다음과 같은 예외가 발생합니다.

Could not load file or assembly 'Oracle.DataAccess, Version=2.112.4.0, Culture=neutral, PublicKeyToken=89b483f429c47342' or one of its dependencies. An attempt was made to load a program with an incorrect format.
Description: An unhandled exception occurred during the execution of the current web request. Please review the stack trace for more information about the error and where it originated in the code.

Exception Details: System.BadImageFormatException: Could not load file or assembly 'Oracle.DataAccess, Version=2.112.4.0, Culture=neutral, PublicKeyToken=89b483f429c47342' or one of its dependencies. An attempt was made to load a program with an incorrect format.


System.BadImageFormatException 예외는 예전에도 설명했었지요. ^^

System.BadImageFormatException
; https://www.sysnet.pe.kr/2/0/519

supportedRuntime 옵션과 System.BadImageFormatException 예외
; https://www.sysnet.pe.kr/2/0/1233

사실 거의 대부분 BadImageFormatException이 발생하는 것은 32/64비트 DLL 충돌 문제입니다. 위의 Oracle.DataAccess 관련 예외는 해당 웹 프로젝트가 AnyCPU 설정이고 참조된 DLL들도 64비트 DLL이지만 아쉽게도 Visual Studio에서 웹 프로젝트를 호스팅하는 IIS Express가 32비트로 실행되기 때문에 발생하는 문제입니다.

Visual Studio 2012까지는 이를 레지스트리 설정으로 해결했는데,

Debugging VS2013 Websites Using 64-bit IIS Express
; http://blogs.msdn.com/b/rob/archive/2013/11/14/debugging-vs2013-websites-using-64-bit-iis-express.aspx

경로: HKEY_CURRENT_USER\Software\Microsoft\VisualStudio\12.0\WebProjects 
이름: Use64BitIISExpress
형식: REG_DWORD
값: 1

Visual Studio 2013부터는 "Tools" / "Option" 창의 "Projects and Solutions" / "Web Projects" 범주에 "Use the 64 bit version of IIS Express for web sites and projects" 옵션을 내장하게 됩니다. 따라서 그것만 설정하고 실행해 주면 됩니다.




가끔 저는 웹 애플리케이션 실행 중에 C/C++ 모듈을 디버깅해야 할 때가 있어서 'Native' 모드로 붙일 때가 있는데요. 이럴 때는 IIS Express를 선택할 수 있는 한가지 옵션이 더 있습니다. 일단 IIS Express가 정상적으로 실행되게 만들고 "Process Explorer"를 통해 해당 환경(Path, Command Line 인자, Current Directory) 값을 알아낸 후,

iisexpress_64_1.png

이제 웹 애플리케이션 프로젝트에 가서 디버깅 시작을 iisexpress.exe로 직접 지정하는 것입니다.

iisexpress_64_2.png

이렇게 설정하고 F5 키를 누르면 원하는 iisexpress.exe로 네이티브 디버깅을 할 수 있습니다. 물론 "오라클 db 사용관련 문의입니다." 질문에서는 관리 환경을 디버깅하는 것이므로 이 방법을 써 먹을 수는 없습니다.




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 7/8/2014]

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

비밀번호

댓글 작성자
 




... 46  47  48  49  50  51  52  53  54  55  [56]  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12242정성태6/23/20209518오류 유형: 623. AADSTS90072 - User account '...' from identity provider 'live.com' does not exist in tenant 'Microsoft Services'
12241정성태6/23/202012811.NET Framework: 914. C# - Task.Yield 사용법파일 다운로드1
12240정성태6/23/202014074오류 유형: 622. 소켓 바인딩 시 "System.Net.Sockets.SocketException: An attempt was made to access a socket in a way forbidden by its access permissions" 오류 발생
12239정성태6/21/202010585Linux: 30. (윈도우라면 DLL에 속하는) .so 파일이 텍스트로 구성된 사례 [1]
12238정성태6/21/202010501.NET Framework: 913. C# - SharpDX + DXGI를 이용한 윈도우 화면 캡처 라이브러리
12237정성태6/20/202010266.NET Framework: 912. 리눅스 환경의 .NET Core에서 "test".IndexOf("\0")가 0을 반환
12236정성태6/19/202010594오류 유형: 621. .NET Standard 대상으로 빌드 시 dynamic 예약어에서 컴파일 오류 - error CS0656: Missing compiler required member 'Microsoft.CSharp.RuntimeBinder.CSharpArgumentInfo.Create'
12235정성태6/19/202010273오류 유형: 620. Windows 10 - Inaccessible boot device 블루 스크린
12234정성태6/19/20209907개발 환경 구성: 494. NuGet - nuspec의 패키지 스키마 버전(네임스페이스) 업데이트 방법
12233정성태6/19/20209657오류 유형: 619. SQL 서버 - The transaction log for database '...' is full due to 'LOG_BACKUP'. - 두 번째 이야기
12232정성태6/19/20208559오류 유형: 618. SharePoint - StoreBusyRetryLater 오류
12231정성태6/15/202011074.NET Framework: 911. Console/Service Application을 위한 SynchronizationContext - AsyncContext
12230정성태6/15/202010420오류 유형: 617. IMetaDataImport::GetMethodProps가 반환하는 IL 코드 주소(RVA) 문제
12229정성태6/13/202012268.NET Framework: 910. USB/IP PROJECT를 이용해 C#으로 USB Keyboard + Mouse 가상 장치 만들기 [1]
12228정성태6/12/202012366.NET Framework: 909. C# - Source Generator를 적용한 XmlCodeGenerator파일 다운로드1
12227정성태6/12/202016351오류 유형: 616. Visual Studio의 느린 업데이트 속도에 대한 원인 분석 [5]
12226정성태6/11/202013612개발 환경 구성: 493. OpenVPN의 네트워크 구성 [4]파일 다운로드1
12225정성태6/11/202012615개발 환경 구성: 492. 윈도우에 OpenVPN 설치 - 클라이언트 측 구성
12224정성태6/11/202020566개발 환경 구성: 491. 윈도우에 OpenVPN 설치 - 서버 측 구성 [1]
12223정성태6/9/202014513.NET Framework: 908. C# - Source Generator 소개 [10]파일 다운로드2
12222정성태6/3/202010312VS.NET IDE: 146. error information: "CryptQueryObject" (-2147024893/0x80070003)
12221정성태6/3/202010063Windows: 170. 비어 있지 않은 디렉터리로 symbolic link(junction) 연결하는 방법
12220정성태6/3/202012558.NET Framework: 907. C# DLL로부터 TLB 및 C/C++ 헤더 파일(TLH)을 생성하는 방법
12219정성태6/1/202011633.NET Framework: 906. C# - lock (this), lock (typeof(...))를 사용하면 안 되는 이유파일 다운로드1
12218정성태5/27/202011580.NET Framework: 905. C# - DirectX 게임 클라이언트 실행 중 키보드 입력을 감지하는 방법 [3]
12217정성태5/24/202010010오류 유형: 615. Transaction count after EXECUTE indicates a mismatching number of BEGIN and COMMIT statements. Previous count = 0, current count = 1.
... 46  47  48  49  50  51  52  53  54  55  [56]  57  58  59  60  ...