Microsoft MVP성태의 닷넷 이야기
글쓴 사람
홈페이지
첨부 파일
 

ASP.NET Core (EXE) 프로세스가 IIS에서 호스팅되는 방법 - ASP.NET Core Module(AspNetCoreModule)

ASP.NET Core 웹 사이트가 IIS에서 호스팅될 때 AspNetCoreModule를 이용해 연결된다는 것을 전에도 언급한 적이 있습니다.

"ASP.NET Core Web Application (.NET Core)"와 "ASP.NET Core Web Application (.NET Framework)" 차이점
; https://www.sysnet.pe.kr/2/0/11121

그런데 사실 AspNetCoreModule은 새로운 모듈이 아닌, 기존 HttpPlatformHandler의 개량형에 불과합니다.

사용자 정의 웹 서버(EXE)를 IIS에서 호스팅하는 방법 - HttpPlatformHandler (Reverse Proxy)
; https://www.sysnet.pe.kr/2/0/11434

이에 대해서는 다음의 이슈에서 확인할 수 있습니다.

HttpPlatformHandler has been replaced by ASP.NET Core Module
; https://github.com/aspnet/IISIntegration/issues/105

즉, ASP.NET Core 초기에만 해도 AspNetCoreModule이 아닌 HttpPlatformHandler로 연동되었지만 ASP.NET만을 위한 몇 가지 기능 추가를 위해 AspNetCoreModule로 넘어온 것입니다.

실제로 HttpPlatformHandler의 경우 자식 프로세스로 "HTTP_PLATFORM_PORT" 환경 변수만을 이용해 동적 포트 번호를 넘겨주는 반면, AspNetCoreModule은 다음과 같이 5개의 환경 변수를 자식 프로세스에게 제공합니다.

  • ASPNETCORE_APPL_PATH
  • ASPNETCORE_HOSTINGSTARTUPASSEMBLIES
  • ASPNETCORE_IIS_HTTPAUTH
  • ASPNETCORE_PORT
  • ASPNETCORE_TOKEN

이 즈음에서 우리가 습관적으로 호출했던 UseIISIntegration의 역할을 짐작할 수 있습니다. 즉, 해당 확장 메서드는 부모 프로세스(w3wp.exe)로부터 전달받은 동적 포트 관련한 환경 구성을 맡고 있는 것입니다. 현재 UseIISIntegration은 Program.cs 파일의 WebHost.CreateDefaultBuilder 메서드 호출 내에서,

using Microsoft.AspNetCore;
using Microsoft.AspNetCore.Hosting;

namespace core_webapi
{
    public class Program
    {
        public static void Main(string[] args)
        {
            BuildWebHost(args).Run();
        }

        public static IWebHost BuildWebHost(string[] args) =>
            WebHost.CreateDefaultBuilder(args)
                .UseStartup<Startup>()
                .Build();
    }
}

불리고 있어 개발자가 별도로 호출할 일은 없게 되었습니다.




HttpPlatformHandler와 AspNetCoreModule이 사실 거의 다르지 않기 때문에 AspNetCoreModule을 이용해서도 지난번 소켓 서버 EXE를 연동하는 것이 가능합니다. 즉, 다음과 같이 web.config을 만들고,

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <system.webServer>
    <handlers>
      <add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModule" resourceType="Unspecified" />
    </handlers>
    <aspNetCore processPath=".\ConsoleApp1.exe" stdoutLogEnabled="false" stdoutLogFile=".\logs\stdout" />
  </system.webServer>
</configuration>

ConsoleApp1.exe를 지난 예제 소스 코드에서 구해,

사용자 정의 웹 서버(EXE)를 IIS에서 호스팅하는 방법 - HttpPlatformHandler (Reverse Proxy)
; https://www.sysnet.pe.kr/2/0/11434

다음의 환경 변숫값만 변경해서 빌드 후 배포하면 정상적으로 동작합니다.

string value = Environment.GetEnvironmentVariable("ASPNETCORE_PORT");




혹시나 관심 있으신 분들은 ^^ AspNetCoreModule의 소스 코드를 직접 살펴볼 수도 있습니다.

aspnet/AspNetCoreModule 
; https://github.com/aspnet/AspNetCoreModule




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

[연관 글]





[최초 등록일: ]
[최종 수정일: 1/16/2018 ]

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

비밀번호

댓글 쓴 사람
 



2018-03-22 07시08분
정성태

1  2  3  4  5  6  7  8  9  10  11  12  13  14  [15]  ...
NoWriterDateCnt.TitleFile(s)
11909정성태5/25/20191824.NET Framework: 837. C# - PLplot 사용 예제 [1]파일 다운로드1
11908정성태5/22/20191202.NET Framework: 836. C# - Python range 함수 구현파일 다운로드1
11907정성태6/4/2019989오류 유형: 541. msbuild - MSB4024 The imported project file "...targets" could not be loaded
11906정성태5/21/2019843.NET Framework: 835. .NET Core/C# - 리눅스 syslog에 로그 남기는 방법
11905정성태5/21/20191206.NET Framework: 834. C# - 폴더 경로 문자열에서 "..", "." 표기를 고려한 최종 문자열을 얻는 방법 - 두 번째 이야기
11904정성태5/21/20192398.NET Framework: 833. C# - Open Hardware Monitor를 이용한 CPU 온도 정보파일 다운로드1
11903정성태5/21/20191324오류 유형: 540. .NET Core - System.PlatformNotSupportedException: The named version of this synchronization primitive is not supported on this platform.
11902정성태5/21/2019919오류 유형: 539. mstest 실행 시 "The directory name is invalid." 오류 발생
11901정성태5/21/20191527오류 유형: 538. msbuild 오류 - Could not find a part of the path '%LOCALAPPDATA%\Temp\2\.NETFramework,Version=v4.0.AssemblyAttributes.cs'
11900정성태3/12/20201461오류 유형: 537. "sfc /scannow" 실행 중 시스템이 부팅되는 현상
11899정성태5/17/20191532Linux: 9. Linux에서 윈도우의 OutputDebugString 대신 사용할 수 있는 syslog [1]
11898정성태5/20/20191594VC++: 130. C++ string의 c_str과 data 함수의 차이점 [3]
11897정성태5/16/20192854오류 유형: 536. Visual Studio - "Developer Pack"을 설치했는데도 "대상 프레임워크" 목록에 나오지 않는 경우 [1]
11896정성태5/15/20192231개발 환경 구성: 440. C#, C++ - double의 Infinity, NaN 표현 방식파일 다운로드1
11895정성태5/12/20191556.NET Framework: 832. ML.NET Model Builder - 회귀(Regression), 다중 분류(Multi-class classification) 예제파일 다운로드1
11894정성태5/12/20192070VS.NET IDE: 135. Visual Studio - ML.NET Model Builder 소개 [1]
11893정성태5/10/20191639오류 유형: 535. C# 6.0 이상의 문법을 컴파일 시 오류가 발생한다면?
11892정성태5/10/20191094웹: 38. HTTP Cookie의 expires 시간 형식(RFC7231)
11891정성태5/9/20191385.NET Framework: 831. (번역글) .NET Internals Cookbook Part 12 - Memory structure, attributes, handles
11890정성태5/8/20191116개발 환경 구성: 439. "Visual Studio Enterprise is required to execute the test." 메시지와 관련된 코드 기록
11889정성태5/8/20191244개발 환경 구성: 438. mstest, QTAgent의 로그 파일 설정 방법
11888정성태5/8/20192339.NET Framework: 830. C# - 비동기 호출을 취소하는 CancellationToken의 간단한 예제 코드파일 다운로드1
11887정성태5/8/20191550.NET Framework: 829. C# - yield 문을 사용할 수 있는 메서드의 조건
11886정성태5/8/20191576오류 유형: 534. mstest.exe 실행 시 "Visual Studio Enterprise is required to execute the test." 오류 [2]
11885정성태5/7/20191022오류 유형: 533. mstest.exe 실행 시 "File extension specified '.loadtest' is not a valid test extension." 오류 발생
11884정성태5/5/20191837.NET Framework: 828. C# DLL에서 Win32 C/C++처럼 dllexport 함수를 제공하는 방법 - 두 번째 이야기
1  2  3  4  5  6  7  8  9  10  11  12  13  14  [15]  ...