Microsoft MVP성태의 닷넷 이야기
Windows: 3. IIS 7.0 다중 바인딩 설정하는 방법 [링크 복사], [링크+제목 복사],
조회: 36653
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

IIS 7.0 다중 바인딩 설정하는 방법


"[WCF 07] IIS 6.0: 다중 Endpoint 제공" 토픽에서 잠깐 언급했지만, WCF는 다양한 유형의 바인딩 형식을 지원하고, 이를 Console EXE / WinForm EXE / NT Service EXE 유형의 프로세스에서 제공할 수가 있습니다. 하지만, 일반 EXE 프로세스와는 달리 IIS 6.0에서는 Transport 유형이 "HTTP"인 경우의 바인딩만 지원한다고 했습니다. 말씀드린 이러한 제한이 IIS 7.0에서는 "Windows Activation Service"(이하, WAS)라는 서비스를 통해서 해결이 되었고, 이번 토픽은 어떻게 그러한 설정을 할 수 있는지에 대한 방법을 살펴보겠습니다.

아시는 것처럼, IIS 7.0은 Vista와 Longhorn 서버에 설치되어져 있습니다. 롱혼 서버의 경우에는 아래의 토픽을 참고해서 IIS 6.0과 .NET 3.0을 설치할 수 있습니다.

[Longhorn] 서버(build 5600)에 IIS 7.0 서비스와 .NET 3.0 설치 방법
; https://www.sysnet.pe.kr/2/0/365

Vista의 경우에는 "Control Panel" / "Programs" / "Programs and Features"를 선택하면 다음과 같이 구성요소 설치 대화창이 뜨게 됩니다. 보시는 것처럼, IIS 서비스와 "ASP.NET", "Microsoft .NET Framework 3.0", "WIndows Communication Foundation (Non-)HTTP Activation"을 선택해서 설치를 해줍니다.

Vista에 IIS 구성요소 설치

Longhorn / Vista에 위와 같이 환경 설정을 했으면 마지막으로 "서비스 관리자"에서 다음과 같이 "Net.Tcp Listener Adapter", "Net.Tcp Port Sharing Service"가 정상적으로 "Started" 상태에 있는지 확인합니다.

관련 서비스 확인



자, 이제 원하는 "Web Site"에 대해서 "net.tcp" 바인딩을 추가해 보도록 하겠습니다. Vista와 Longhorn이 거의 비슷한 방식으로 적용이 되므로, 단일하게 Longhorn 서버를 기준으로 설명을 해나가겠습니다.

1. "Start" / "All Programs" / "Administrative Tools" / "Internet Information Services(IIS) Manager"를 실행시킵니다. 기본적으로 다음과 같은 창이 뜨게 됩니다.

IIS 관리자

2. "Default Web Site" 노드를 마우스 오른쪽 버튼으로 눌러서 "Edit Bindings..." 메뉴를 선택하거나, 위의 화면에서 오른쪽 "Actions" 패널에 보면 "Edit Site" 범주 하위에 있는 "Bindings..." 링크를 클릭하면 다음과 같은 대화창이 뜨게 됩니다.

바인딩 정보

보시는 것처럼, 현재는 "HTTP" 유형의 바인딩만을 제공해 주고 있는데, 여기에 "net.tcp" 유형을 추가해 보는 것이 이번 토픽의 목적입니다. 직관적으로 위의 화면을 보고 판단을 해보면 "Add..." 버튼을 눌러서 쉽게 "net.tcp" 유형을 추가할 수도 있을 것 같은데, 아쉽게도 (향후에는 바뀔지 모르겠지만) 현재는 지원하지 않고 있습니다.

3. 현재로서는, "바인딩 정보"를 추가/삭제하기 위해서는 오직 "C:\Windows\system32\inetsrv" 폴더에 있는 "appcmd.exe" 실행 파일을 통해서만 가능합니다. 예를 들어, "net.tcp" 바인딩으로 "8000" 포트 대기를 지원하기 위해서는 아래와 같이 실행해 주셔야 합니다.

c:\temp>C:\Windows\system32\inetsrv\appcmd.exe set site "Default Web Site" -+bindings.[protocol='net.tcp',bindingInformation='8000:*']
SITE object "Default Web Site" changed

위의 내용은 실제 실행한 모습을 보여주고 있습니다.

4. 위와 같이 실행하고 나서, "IIS 관리자"의 "Default Web Site"를 새로 고침하게 되면 다음과 같이 바인딩에 관한 정보를 추가해서 보여주게 됩니다. (아래의 화면에서 바인딩 정보를 포트와 IP에 대해서 "Host Header"에 보여주는 것은 버그가 아닌가 생각됩니다.)

새로 추가된 바인딩 정보

5. 등록하는 방법을 알았으니, 그럼 삭제하는 방법도 아셔야 겠지요. ^^ 아래와 같은 명령문으로 이것이 가능합니다.

c:\temp>C:\Windows\system32\inetsrv\appcmd.exe set site "Default Web Site" --bindings.[protocol='net.tcp',bindingInformation='8000:*']




하지만 이렇게 했다고 해서 "사용이 가능"한 것은 아닙니다. 명시적으로 이러한 바인딩이 사용될 수 있다는 것을 지정해 주어야만 됩니다. 이것 역시 현재는 IIS 관리자를 통해서 할 수 없고, "appcmd.exe"를 통해서만 가능합니다.

1. 테스트를 위해서 "Application"을 하나 추가해 볼 텐데, 그 Application에 매핑될 테스트 폴더를 하나 만들어 둡니다. 여기서는 "C:\temp\WcfSite" 폴더를 만들었다고 가정하겠습니다.

2. "Default Web Site"를 마우스 오른쪽 버튼으로 클릭해서 "Add Application..." 메뉴를 선택합니다. 나오는 대화창에 다음과 같이 입력해 줍니다. (자신의 상황에 맞게 입력합니다.)

새로운 Application 등록

3. 확인을 하고 나면, "WcfSite"라는 Application 노드가 생성된 것을 확인할 수 있습니다. 이제 이 "WcfSite" Application에 "net.tcp" 바인딩이 허용되도록 appcmd.exe를 다음과 같이 실행시켜 줍니다.

c:\temp>C:\Windows\system32\inetsrv\appcmd.exe set app "Default Web Site/WcfSite" /enabledProtocols:http,net.tcp

아쉽게도, 현재는 위의 설정이 정상적으로 적용이 되었는지 IIS 관리자를 통해서 확인할 방법이 없습니다.

4. 역시, 설정을 했다면 복원하는 방법도 소개해야 겠지요. 그냥 다음과 같이 "http"만을 설정해 주시면 됩니다.

c:\temp>C:\Windows\system32\inetsrv\appcmd.exe set app "Default Web Site/WcfSite" /enabledProtocols:http




마치기 전에, "applicationHost.config" 파일에 대해서 소개를 드리겠습니다. 위에서 설정한 모든 내용들은 바로 이 파일에 반영이 되는데요. 이 파일은 "C:\Windows\System32\InetSrv\Config" 폴더에 위치해 있고, 메모장으로 열어보면 위에서 설정했던 내용들이 다음과 같이 반영되어 있는 것을 확인할 수 있습니다.

<sites>
    <site name="Default Web Site" id="1" serverAutoStart="true">
        <application path="/">
            <virtualDirectory path="/" physicalPath="%SystemDrive%\inetpub\wwwroot" />
        </application>
        <application path="/WcfSite" enabledProtocols="http,net.tcp">
            <virtualDirectory path="/" physicalPath="C:\temp\WcfSite" />
        </application>
        <bindings>
            <binding protocol="http" bindingInformation="*:80:" />
            <binding protocol="net.tcp" bindingInformation="8000:*" />
        </bindings>
    </site>
    <siteDefaults>
        <logFile customLogPluginClsid="{FF160663-DE82-11CF-BC0A-00AA006111E0}" directory="%SystemDrive%\inetpub\logs\LogFiles" />
        <traceFailedRequestsLogging directory="%SystemDrive%\inetpub\logs\FailedReqLogFiles" />
    </siteDefaults>
    <applicationDefaults applicationPool="DefaultAppPool" />
    <virtualDirectoryDefaults allowSubDirConfig="true" />
</sites>




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/22/2021]

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

비밀번호

댓글 작성자
 



2010-03-06 05시26분
kevin25

1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13868정성태1/17/20253121Windows: 277. Hyper-V - Windows 11 VM의 Enhanced Session 모드로 로그인을 할 수 없는 문제
13867정성태1/17/20254074오류 유형: 943. Hyper-V에 Windows 11 설치 시 "This PC doesn't currently meet Windows 11 system requirements" 오류
13866정성태1/16/20254281개발 환경 구성: 739. Windows 10부터 바뀐 device driver 서명 방법
13865정성태1/15/20253947오류 유형: 942. C# - .NET Framework 4.5.2 이하의 버전에서 HttpWebRequest로 https 호출 시 "System.Net.WebException" 예외 발생
13864정성태1/15/20253919Linux: 114. eBPF를 위해 필요한 SELinux 보안 정책
13863정성태1/14/20253370Linux: 113. Linux - 프로세스를 위한 전용 SELinux 보안 문맥 지정
13862정성태1/13/20253630Linux: 112. Linux - 데몬을 위한 SELinux 보안 정책 설정
13861정성태1/11/20253918Windows: 276. 명령행에서 원격 서비스를 동기/비동기로 시작/중지
13860정성태1/10/20253628디버깅 기술: 216. WinDbg - 2가지 유형의 식 평가 방법(MASM, C++)
13859정성태1/9/20253985디버깅 기술: 215. Windbg - syscall 이후 실행되는 KiSystemCall64 함수 및 SSDT 디버깅
13858정성태1/8/20254108개발 환경 구성: 738. PowerShell - 원격 호출 시 "powershell.exe"가 아닌 "pwsh.exe" 환경으로 명령어를 실행하는 방법
13857정성태1/7/20254159C/C++: 187. Golang - 콘솔 응용 프로그램을 Linux 데몬 서비스를 지원하도록 변경파일 다운로드1
13856정성태1/6/20253740디버깅 기술: 214. Windbg - syscall 단계까지의 Win32 API 호출 (예: Sleep)
13855정성태12/28/20244472오류 유형: 941. Golang - os.StartProcess() 사용 시 오류 정리
13854정성태12/27/20244561C/C++: 186. Golang - 콘솔 응용 프로그램을 NT 서비스를 지원하도록 변경파일 다운로드1
13853정성태12/26/20244026디버깅 기술: 213. Windbg - swapgs 명령어와 (Ring 0 커널 모드의) FS, GS Segment 레지스터
13852정성태12/25/20244502디버깅 기술: 212. Windbg - (Ring 3 사용자 모드의) FS, GS Segment 레지스터파일 다운로드1
13851정성태12/23/20244254디버깅 기술: 211. Windbg - 커널 모드 디버깅 상태에서 사용자 프로그램을 디버깅하는 방법
13850정성태12/23/20244755오류 유형: 940. "Application Information" 서비스를 중지한 경우, "This file does not have an app associated with it for performing this action."
13849정성태12/20/20244898디버깅 기술: 210. Windbg - 논리(가상) 주소를 Segmentation을 거쳐 선형 주소로 변경
13848정성태12/18/20244835디버깅 기술: 209. Windbg로 알아보는 Prototype PTE파일 다운로드2
13847정성태12/18/20244860오류 유형: 939. golang - 빌드 시 "unknown directive: toolchain" 오류 빌드 시 이런 오류가 발생한다면?
13846정성태12/17/20245071디버깅 기술: 208. Windbg로 알아보는 Trans/Soft PTE와 2가지 Page Fault 유형파일 다운로드1
13845정성태12/16/20244535디버깅 기술: 207. Windbg로 알아보는 PTE (_MMPTE)
13844정성태12/14/20245227디버깅 기술: 206. Windbg로 알아보는 PFN (_MMPFN)파일 다운로드1
13843정성태12/13/20244393오류 유형: 938. Docker container 내에서 빌드 시 error MSB3021: Unable to copy file "..." to "...". Access to the path '...' is denied.
1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...