C# - WebActivatorEx / System.Web의 PreApplicationStartMethod 특성
지난 글에서,
C# - ASP.NET Web Application + OpenAPI(Swashbuckle) 스펙 제공
; https://www.sysnet.pe.kr/2/0/13511
특이한 점이 있다면, Swashbuckle 패키지 참조 후 자동으로 추가된 SwaggerConfig.cs 파일의 SwaggerConfig.Register를 호출하는 코드가 어디에도 없다는 점입니다.
그래도 작동할 수 있었던 것은 바로 PreApplicationStartMethod 특성 덕분입니다. (동일한 파일의 상단에 추가돼 있습니다.)
[assembly: PreApplicationStartMethod(typeof(SwaggerConfig), "Register")]
이 특성은 닷넷에 속한 것이 아닌,
WebActivatorEx 내에서 정의된 것입니다. 아니... 그런데 어떻게 저 특성을 명시한 메서드가 웹 애플리케이션이 시작하는 시점, 엄밀히는 Application_Start가 호출하기 이전에 실행되는 것일까요? 게다가 웹 사이트의 소스코드 내에서는 WebActivatorEx의 어떠한 메서드 호출도 없는 대도요.
이것은 WebActivatorEx 스스로 (이번엔 마이크로소프트가 만들어 둔)
System.Web.PreApplicationStartMethod 특성을 포함하고 있기 때문입니다.
[assembly: System.Web.PreApplicationStartMethod(typeof(ActivationManager), "Run")]
문서에도 나오지만, 이 옵션이 의미 있는 것은 ASP.NET 파이프라인이 초기화되기 전, 즉 Application_Start가 호출되기 전에 구성해야 할 것이 있는 경우입니다. 만약, 꼭 그 단계에서 해야 할 작업이 아니라면, 굳이 해당 특성을 연결할 필요 없이 그냥 기존처럼 Application_Start에서 처리해도 무방합니다.
참고로, 아래의 글에서 제가 옵션 2개("Start Automatically", "Start Mode")를 소개했는데요,
IIS 7.5부터 지원되는 웹 사이트 자동 시작 모드
; https://www.sysnet.pe.kr/2/0/1367
현재의 IIS (적어도) 8+ 버전에는 AppPool의 UI 상에서 "Start Automatically" 옵션이 없어졌습니다. 대신 그래도 설정하고자 한다면 applicationHost.config 파일을 직접 편집해 설정하는 것은 가능합니다.
Adding Application Pools <add>
- Configuration / autoStart
; https://learn.microsoft.com/en-us/iis/configuration/system.applicationhost/applicationpools/add/#configuration
...[생략]...
<system.applicationHost>
...[생략]...
<applicationPools>
...[생략]...
<add name="AutoSite" autoStart="true" enable32BitAppOnWin64="true"
managedRuntimeVersion="v4.0" startMode="AlwaysRunning" />
</applicationPools>
...[생략]...
</system.applicationHost>
...[생략]...
(기본값이 true인) autoStart 옵션을 바꾸면 되는데요, 아마도 이것이 UI에서 사라진 것은, "Start Mode" 옵션과 왠지 비슷해 혼란을 가져온다는 점도 있었겠지만 autoStart를 false로 두고 사전 초기화를 할 수 있는 작업들을 PreApplicationStartMethod를 이용해 코딩할 수 있게 되었기 때문도 있을 듯합니다.
또한, 이 옵션은 ASP.NET Core에는 없습니다. 사실 있을 필요가 없는 건데요, ASP.NET Core는
Web Application Builder 단계를 응용 프로그램 내에 포함하고 있기 때문에 Pipeline 과정 이전에도 자유롭게 코드를 추가할 수 있으므로 PreApplicationStartMethod 특성이 있을 이유가 없습니다.
결국 WebActivatorEx 패키지는 ASP.NET Core부터 잊어도 좋을 유산으로만 남게 되었습니다.
[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]