Microsoft MVP성태의 닷넷 이야기
VS.NET IDE: 91. Visual Studio에서 32/64비트 IIS Express 실행하는 방법 [링크 복사], [링크+제목 복사],
조회: 28076
글쓴 사람
정성태 (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

비밀번호

댓글 작성자
 




... 76  [77]  78  79  80  81  82  83  84  85  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
12044정성태10/27/201917678오류 유형: 575. mstest.exe - System.Resources.MissingSatelliteAssemblyException: The satellite assembly named "Microsoft.VisualStudio.ProductKeyDialog.resources.dll, ..."
12043정성태10/27/201919696오류 유형: 574. Windows 10 설치 시 오류 - 0xC1900101 - 0x4001E
12042정성태10/26/201918701오류 유형: 573. OneDrive 하위에 위치한 Documents, Desktop 폴더에 대한 권한 변경 시 "Unable to display current owner"
12041정성태10/23/201920252오류 유형: 572. mstest.exe - The load test results database could not be opened.
12040정성태10/23/201920837오류 유형: 571. Unhandled Exception: System.Net.Mail.SmtpException: Transaction failed. The server response was: 5.2.0 STOREDRV.Submission.Exception:SendAsDeniedException.MapiExceptionSendAsDenied
12039정성태10/22/201917739스크립트: 16. cmd.exe의 for 문에서는 ERRORLEVEL이 설정되지 않는 문제
12038정성태10/17/201918316오류 유형: 570. SQL Server 2019 RC1 - SQL Client Connectivity SDK 설치 오류
12037정성태10/15/201925915.NET Framework: 867. C# - Encoding.Default 값을 바꿀 수 있을까요?파일 다운로드1
12036정성태10/14/201927252.NET Framework: 866. C# - 고성능이 필요한 환경에서 GC가 발생하지 않는 네이티브 힙 사용파일 다운로드1
12035정성태10/13/201920571개발 환경 구성: 461. C# 8.0의 #nulable 관련 특성을 .NET Framework 프로젝트에서 사용하는 방법 [2]파일 다운로드1
12034정성태10/12/201920116개발 환경 구성: 460. .NET Core 환경에서 (프로젝트가 아닌) C# 코드 파일을 입력으로 컴파일하는 방법 [1]
12033정성태10/11/201924553개발 환경 구성: 459. .NET Framework 프로젝트에서 C# 8.0/9.0 컴파일러를 사용하는 방법
12032정성태10/8/201920146.NET Framework: 865. .NET Core 2.2/3.0 웹 프로젝트를 IIS에서 호스팅(Inproc, out-of-proc)하는 방법 - AspNetCoreModuleV2 소개
12031정성태10/7/201918096오류 유형: 569. Azure Site Extension 업그레이드 시 "System.IO.IOException: There is not enough space on the disk" 예외 발생
12030정성태10/5/201925177.NET Framework: 864. .NET Conf 2019 Korea - "닷넷 17년의 변화 정리 및 닷넷 코어 3.0" 발표 자료 [1]파일 다운로드1
12029정성태9/27/201925380제니퍼 .NET: 29. Jennifersoft provides a trial promotion on its APM solution such as JENNIFER, PHP, and .NET in 2019 and shares the examples of their application.
12028정성태9/26/201921005.NET Framework: 863. C# - Thread.Suspend 호출 시 응용 프로그램 hang 현상을 해결하기 위한 시도파일 다운로드1
12027정성태9/26/201915638오류 유형: 568. Consider app.config remapping of assembly "..." from Version "..." [...] to Version "..." [...] to solve conflict and get rid of warning.
12026정성태9/26/201921964.NET Framework: 862. C# - Active Directory의 LDAP 경로 및 정보 조회
12025정성태9/25/201920265제니퍼 .NET: 28. APM 솔루션 제니퍼, PHP, .NET 무료 사용 프로모션 2019 및 적용 사례 (8) [1]
12024정성태9/20/201922206.NET Framework: 861. HttpClient와 HttpClientHandler의 관계 [2]
12023정성태9/18/201922641.NET Framework: 860. ServicePointManager.DefaultConnectionLimit와 HttpClient의 관계파일 다운로드1
12022정성태9/12/201926183개발 환경 구성: 458. C# 8.0 (Preview) 신규 문법을 위한 개발 환경 구성 [3]
12021정성태9/12/201942271도서: 시작하세요! C# 8.0 프로그래밍 [4]
12020정성태9/11/201925234VC++: 134. SYSTEMTIME 값 기준으로 특정 시간이 지났는지를 판단하는 함수
12019정성태9/11/201918952Linux: 23. .NET Core + 리눅스 환경에서 Environment.CurrentDirectory 접근 시 주의 사항
... 76  [77]  78  79  80  81  82  83  84  85  86  87  88  89  90  ...