Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

Windows 7 SP1의 IIS에서 사용자 프로파일을 로드하는 방법

SQL 서버 Express 버전의 "User Instance" 기능을 오랜만에 테스트해 보았는데, SqlConnection.Open 시에 다음과 같은 오류가 발생했습니다.

A network-related or instance-specific error occurred while establishing a connection to SQL Server. The server was not found or was not accessible. Verify that the instance name is correct and that SQL Server is configured to allow remote connections. (provider: SQL Network Interfaces, error: 0 - [x89C50120])


위의 테스트를 하는 시점의 IIS는 "Network Service" 계정으로 구동되었는데, 반면에 "Local System"으로 바꾼 경우에는 정상적으로 SqlConnection.Open 기능이 되었습니다.

"User Instance" 기능이 "사용자 프로파일"을 요구하기 때문일 텐데요. 이상한 것은, AppPool의 옵션을 아래와 같이 바꿔봐도 여전히 "Network Service" / "Local Service" 계정에서는 오류가 계속되었습니다.

load_user_profile_on_win7sp1_1.png

Microsoft의 Connect 사이트를 통해 오류 보고를 했는데... 부끄럽게도 ^^ 이미 이에 대해 공개된 KB 자료를 알려주더군요.

Windows 7 SP1 causes IntelliTrace Collection to fail on IIS
; http://support.microsoft.com/kb/2547655

위의 해결 방법을 따라서, %windir%\system32\inetsrv\config\applicationHost.config 파일을 '관리자 권한'으로 실행시킨 메모장에서 열어 <applicationPools> 내의 해당 AppPool 노드에 setProfileEnvironment="true" 값을 추가해 주었습니다.

<applicationPools>
    <add name="DefaultAppPool" />
    <add name="Classic .NET AppPool" enable32BitAppOnWin64="true" managedRuntimeVersion="v2.0" managedPipelineMode="Integrated" />
    <add name="ASP.NET v4.0" managedRuntimeVersion="v4.0" />
    <add name="ASP.NET v4.0 Classic" managedRuntimeVersion="v4.0" managedPipelineMode="Classic" />
    <add name="WebApp" autoStart="true" managedRuntimeVersion="v2.0" managedPipelineMode="Classic" />
    <add name="WoLoadProfile" autoStart="true" managedRuntimeVersion="v4.0">
        <processModel identityType="NetworkService" loadUserProfile="true" setProfileEnvironment="true" />
    </add>
    <applicationPoolDefaults>
        <processModel identityType="ApplicationPoolIdentity" loadUserProfile="true" setProfileEnvironment="false" />
    </applicationPoolDefaults>
</applicationPools>

제가 해본 바로는, iisreset 후에야 정상적으로 "User Instance" 기능이 동작하는 것을 확인했습니다. ^^

setProfileEnvironment 이름만 들어도 대충 '환경 변수' 설정까지 모두 처리해 주는 옵션이라는 것을 알 수 있는데요. 굳이 이렇게 분리하게 된 원인에 대해서는 다음의 글에서 Access 사례를 들어서 설명해 주고 있습니다.

Windows 7 SP1, IIS and IntelliTrace 
; http://continuouslyintegrating.blogspot.com/2011/05/windows-7-sp1-iis-and-intellitrace.html




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 8/27/2021]

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

비밀번호

댓글 작성자
 




... 106  107  [108]  109  110  111  112  113  114  115  116  117  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11261정성태8/4/201722187디버깅 기술: 91. windbg - 풀 덤프 파일로부터 강력한 이름의 어셈블리 추출 후 사용하는 방법
11260정성태8/3/201720836.NET Framework: 670. C# - 실행 파일로부터 공개키를 추출하는 방법
11259정성태8/2/201719224.NET Framework: 669. 지연 서명된 어셈블리를 sn.exe -Vr 등록 없이 사용하는 방법
11258정성태8/1/201720530.NET Framework: 668. 지연 서명된 DLL과 서명된 DLL의 차이점파일 다운로드1
11257정성태7/31/201720173.NET Framework: 667. bypassTrustedAppStrongNames 옵션 설명파일 다운로드1
11256정성태7/25/201722056디버깅 기술: 90. windbg의 lm 명령으로 보이지 않는 .NET 4.0 ClassLibrary를 명시적으로 로드하는 방법 [1]
11255정성태7/18/201724680디버깅 기술: 89. Win32 Debug CRT Heap Internals의 0xBAADF00D 표시 재현 [1]파일 다운로드3
11254정성태7/17/201721034개발 환경 구성: 322. "Visual Studio Emulator for Android" 에뮬레이터를 "Android Studio"와 함께 쓰는 방법
11253정성태7/17/201721715Math: 21. "Coding the Matrix" 문제 2.5.1 풀이 [1]파일 다운로드1
11252정성태7/13/201719374오류 유형: 411. RTVS 또는 PTVS 실행 시 Could not load type 'Microsoft.VisualStudio.InteractiveWindow.Shell.IVsInteractiveWindowFactory2'
11251정성태7/13/201718947디버깅 기술: 88. windbg 분석 - webengine4.dll의 MgdExplicitFlush에서 발생한 System.AccessViolationException의 crash 문제 (2)
11250정성태7/13/201722632디버깅 기술: 87. windbg 분석 - webengine4.dll의 MgdExplicitFlush에서 발생한 System.AccessViolationException의 crash 문제 [1]
11249정성태7/12/201720275오류 유형: 410. LoadLibrary("[...].dll") failed - The specified procedure could not be found.
11248정성태7/12/201726787오류 유형: 409. pip install pefile - 'cp949' codec can't decode byte 0xe2 in position 208687: illegal multibyte sequence
11247정성태7/12/201721195오류 유형: 408. SqlConnection 객체 생성 시 무한 대기 문제파일 다운로드1
11246정성태7/11/201719042VS.NET IDE: 118. Visual Studio - 다중 폴더에 포함된 파일들에 대한 "Copy to Output Directory"를 한 번에 설정하는 방법
11245정성태7/10/201724860개발 환경 구성: 321. Visual Studio Emulator for Android 소개 [2]
11244정성태7/10/201725179오류 유형: 407. Visual Studio에서 ASP.NET Core 실행할 때 dotnet.exe 프로세스의 -532462766 오류 발생 [1]
11243정성태7/10/201721971.NET Framework: 666. dotnet.exe - 윈도우 운영체제에서의 .NET Core 버전 찾기 규칙
11242정성태7/8/201721413제니퍼 .NET: 27. 제니퍼 닷넷 적용 사례 (7) - 노후된 스토리지 장비로 인한 웹 서비스 Hang (멈춤) 현상
11241정성태7/8/201719994오류 유형: 406. Xamarin 빌드 에러 XA5209, APT0000
11240정성태7/7/201723926.NET Framework: 665. ClickOnce를 웹 브라우저를 이용하지 않고 쿼리 문자열을 전달하면서 실행하는 방법 [3]파일 다운로드1
11239정성태7/6/201724480.NET Framework: 664. Protocol Handler - 웹 브라우저에서 데스크톱 응용 프로그램을 실행하는 방법 [5]파일 다운로드1
11238정성태7/6/201721943오류 유형: 405. NT 서비스 시작 시 "Error 1067: The process terminated unexpectedly." 오류 발생 [2]
11237정성태7/5/201723656.NET Framework: 663. C# - PDB 파일 경로를 PE 파일로부터 얻는 방법파일 다운로드1
11236정성태7/4/201727433.NET Framework: 662. C# - VHD/VHDX 가상 디스크를 마운트하지 않고 파일을 복사하는 방법파일 다운로드1
... 106  107  [108]  109  110  111  112  113  114  115  116  117  118  119  120  ...