Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)
(시리즈 글이 3개 있습니다.)
개발 환경 구성: 703. Visual Studio - launchSettings.json을 이용한 HTTP/HTTPS 포트 바인딩
; https://www.sysnet.pe.kr/2/0/13539

VS.NET IDE: 188. launchSettings.json의 useSSL 옵션
; https://www.sysnet.pe.kr/2/0/13541

닷넷: 2212. ASP.NET Core - 우선순위에 따른 HTTP/HTTPS 호스트:포트 바인딩 방법
; https://www.sysnet.pe.kr/2/0/13545




ASP.NET Core - 우선순위에 따른 HTTP/HTTPS 호스트:포트 바인딩 방법

지난 글에 소개한 "launchSettings.json" 파일은,

Visual Studio - launchSettings.json을 이용한 HTTP/HTTPS 포트 바인딩
; https://www.sysnet.pe.kr/2/0/13539

보통 개발 시점에만 사용하게 됩니다. 반면, 배포 시에는 다른 방법으로 제어를 할 수 있는데요, 이에 대해 다음의 글에서 자세하게 소개하고 있습니다.

5 ways to set the URLs for an ASP.NET Core app
; https://andrewlock.net/5-ways-to-set-the-urls-for-an-aspnetcore-app/

우선 기본 상태로 Publish를 하면 (지난 글에 설명한 것처럼 아무런 프로파일도 지정이 안 되었으므로 기본값인) HTTP 5000으로만 대기를 합니다.

C:\temp\...[생략]...\net8.0\publish> WebApplication3.exe
info: Microsoft.Hosting.Lifetime[14]
      Now listening on: http://localhost:5000
info: Microsoft.Hosting.Lifetime[0]
      Application started. Press Ctrl+C to shut down.
info: Microsoft.Hosting.Lifetime[0]
      Hosting environment: Production
info: Microsoft.Hosting.Lifetime[0]
      Content root path: C:\temp\...[생략]...\net8.0\publish

이것을 바꾸기 위한 가장 낮은 우선순위의 방법은 ASPNETCORE_URLS 환경변수를 설정하는 것입니다.

C:\temp\...[생략]...\net8.0\publish> set ASPNETCORE_URLS=https://localhost:5015;http://localhost:5014

C:\temp\...[생략]...\net8.0\publish> WebApplication3.exe
info: Microsoft.Hosting.Lifetime[14]
      Now listening on: https://localhost:5015
info: Microsoft.Hosting.Lifetime[14]
      Now listening on: http://localhost:5014
info: Microsoft.Hosting.Lifetime[0]
      Application started. Press Ctrl+C to shut down.
info: Microsoft.Hosting.Lifetime[0]
      Hosting environment: Production
info: Microsoft.Hosting.Lifetime[0]
      Content root path: C:\temp\...[생략]...\net8.0\publish

이 값은 launchSettings.json에서도 종종 환경변수 란에 설정된 것을 볼 수 있습니다.

"Docker": {
    "commandName": "Docker",
    "launchBrowser": true,
    "launchUrl": "{Scheme}://{ServiceHost}:{ServicePort}",
    "environmentVariables": {
        "ASPNETCORE_URLS": "http://+:80"
    },
}

그다음 높은 순위는 명령행에 지정하는 건데요, 즉 환경변수를 설정했어도 이 값이 적용됩니다.

C:\temp\...[생략]...\net8.0\publish> set ASPNETCORE_URLS=https://localhost:5015;http://localhost:5014

C:\temp\...[생략]...\net8.0\publish> WebApplication3.exe --urls "https://localhost:5025;http://localhost:5024"
info: Microsoft.Hosting.Lifetime[14]
      Now listening on: https://localhost:5025
info: Microsoft.Hosting.Lifetime[14]
      Now listening on: http://localhost:5024
info: Microsoft.Hosting.Lifetime[0]
      Application started. Press Ctrl+C to shut down.
info: Microsoft.Hosting.Lifetime[0]
      Hosting environment: Production
info: Microsoft.Hosting.Lifetime[0]
      Content root path: C:\temp\...[생략]...\net8.0\publish

이 옵션은 dotnet run 명령어로 실행할 때도 그대로 적용할 수 있습니다.

dotnet run --urls "https://localhost:5025;http://localhost:5024"

위의 2가지 방법을 무시하고 싶다면 코딩으로 명시해야 하는데요, WebHost.UseUrls 메서드를 호출하면 됩니다.

namespace WebApplication3;

public class Program
{
    public static void Main(string[] args)
    {
        var builder = WebApplication.CreateBuilder(args);

        builder.WebHost.UseUrls("http://localhost:5034", "https://localhost:5035");

        // Add services to the container.
        builder.Services.AddRazorPages();

        var app = builder.Build();

        // Configure the HTTP request pipeline.
        if (!app.Environment.IsDevelopment())
        {
            app.UseExceptionHandler("/Error");
            // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
            app.UseHsts();
        }

        app.UseHttpsRedirection();
        app.UseStaticFiles();

        app.UseRouting();

        app.UseAuthorization();

        app.MapRazorPages();

        app.Run();
    }
}

그럼 환경변수가 적용됐어도, --urls 명령행 옵션을 줬어도 코드의 값이 반영됩니다.

C:\temp\...[생략]...\net8.0\publish> set ASPNETCORE_URLS=https://localhost:5015;http://localhost:5014

C:\temp\...[생략]...\net8.0\publish> WebApplication3.exe --urls "https://localhost:5025;http://localhost:5024"
info: Microsoft.Hosting.Lifetime[14]
      Now listening on: http://localhost:5034
info: Microsoft.Hosting.Lifetime[14]
      Now listening on: https://localhost:5035
info: Microsoft.Hosting.Lifetime[0]
      Application started. Press Ctrl+C to shut down.
info: Microsoft.Hosting.Lifetime[0]
      Hosting environment: Production
info: Microsoft.Hosting.Lifetime[0]
      Content root path: C:\temp\...[생략]...\net8.0\publish

마지막으로, ConfigureKestrel 설정은 위에서 설정한 모든 값을 무시하는 가장 높은 우선순위를 갖습니다.

builder.WebHost.UseUrls("http://localhost:5034", "https://localhost:5035");

builder.WebHost.ConfigureKestrel((options) =>
{
    options.ListenLocalhost(5044);
    options.ListenLocalhost(5045, opts => opts.UseHttps());
});

호출 순서를 바꿔도 마찬가지입니다.

builder.WebHost.ConfigureKestrel((options) =>
{
    options.ListenLocalhost(5044);
    options.ListenLocalhost(5045, opts => opts.UseHttps());
});

builder.WebHost.UseUrls("http://localhost:5034", "https://localhost:5035");

한 가지 특이한 점은, ConfigureKestrel로 인한 재정의를 했을 때는 이 사실을 알리는 메시지를 함께 출력한다는 점입니다.

C:\temp\...[생략]...\net8.0\publish> set ASPNETCORE_URLS=https://localhost:5015;http://localhost:5014

C:\temp\...[생략]...\net8.0\publish> WebApplication3.exe --urls "https://localhost:5025;http://localhost:5024"
warn: Microsoft.AspNetCore.Server.Kestrel[0]
      Overriding address(es) 'http://localhost:5034, https://localhost:5035'. Binding to endpoints defined via IConfiguration and/or UseKestrel() instead.
info: Microsoft.Hosting.Lifetime[14]
      Now listening on: http://localhost:5044
info: Microsoft.Hosting.Lifetime[14]
      Now listening on: https://localhost:5045
info: Microsoft.Hosting.Lifetime[0]




만약, 환경변수, 입력 인자 및 코드 등으로 저렇게 변경하는 것을 비주얼 스튜디오로 개발하는 중에 적용한다면 Properties\launchSettings.json 파일도 그에 맞게 바꿔줘야 디버깅을 편하게 할 수 있습니다.

또한, ASPNETCORE_URLS 환경 설정의 경우 값을 설정할 때 따옴표를 쓰면 안 됩니다.

set ASPNETCORE_URLS="https://localhost:5035;http://localhost:5034"

위와 같이 설정하게 되면 이후 실행 시 이런 예외가 발생합니다.

System.InvalidOperationException: Unrecognized scheme in server address '"https://localhost:5035'. Only 'http://' and 'https://' are supported.




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 1/31/2024]

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

비밀번호

댓글 작성자
 




... 121  122  123  124  125  126  [127]  128  129  130  131  132  133  134  135  ...
NoWriterDateCnt.TitleFile(s)
2879정성태3/3/201526668개발 환경 구성: 259. Visual Studio 없이 Visual C++ 컴파일하는 방법
2878정성태2/28/201527497.NET Framework: 503. == 연산자보다는 Equals 메서드의 호출이 더 권장됩니다. [3]파일 다운로드1
2877정성태2/28/201521737.NET Framework: 502. 연산자 재정의(operator overloading)와 메서드 재정의(method overriding)의 다른 점 - 가상 함수 호출 여부 [3]파일 다운로드1
2876정성태2/27/201524213VS.NET IDE: 98. IntegraStudio - Visual Studio에서 Java 프로그램 개발
2875정성태2/26/201522811디버깅 기술: 72. Visual Studio 2013에서의 sos.dll 사용 제한
2874정성태2/26/201519566디버깅 기술: 71. windbg + 닷넷 디버깅 (2) - null 체크 패턴
2873정성태2/25/201537019.NET Framework: 501. FtpWebRequest 타입을 이용해 FTP 파일 업로드 [4]파일 다운로드1
2872정성태2/25/201521188디버깅 기술: 70. windbg + 닷넷 디버깅 (1) - 배열 인덱스 사용 패턴
2871정성태2/24/201525195개발 환경 구성: 258. 윈도우 8.1에서 방화벽과 함께 FTP 서버 여는 (하지만, 권장하지 않는) 방법 [1]
2870정성태2/24/201526304개발 환경 구성: 257. 윈도우 8.1에서 방화벽과 함께 FTP 서버 여는 방법
2869정성태2/23/201520298.NET Framework: 500. struct로 정의한 값 형식(Value Type)의 경우 Equals 재정의를 권장합니다.파일 다운로드1
2868정성태2/23/201524797VS.NET IDE: 97. Visual C++ 프로젝트 디버깅 시에 Step-Into(F11) 동작이 원치 않는 함수로 진입하는 것을 막는 방법 [2]
2867정성태2/23/201518446오류 유형: 273. File History - Failed to initiate user data backup (error 80070005)
2866정성태2/23/201520307오류 유형: 272. WAT080 : Failed to locate the Windows Azure SDK. Please make sure the Windows Azure SDK v2.1 is installed.
1868정성태2/20/201517617오류 유형: 271. The type '...' cannot be used as type parameter 'TContext' in the generic type or method 'System.ServiceModel.DomainServices.EntityFramework.LinqToEntitiesDomainService<T>
1866정성태2/20/201518515오류 유형: 270. "aspnet_regiis -i" 실행 시 0x00000006 오류 해결 방법
1865정성태2/20/201519830.NET Framework: 499. 특정 닷넷 프레임워크 버전 이후부터 제공되는 타입을 사용해야 한다면?
1864정성태2/18/201524824.NET Framework: 498. C#으로 간단하게 만들어 본 ASCII Art 프로그램 [2]파일 다운로드1
1862정성태2/18/201528665.NET Framework: 497. .NET Garbage Collection에 대한 정리 [6]
1861정성태2/18/201524017.NET Framework: 496. 마우스 커서가 놓인 지점의 문자열 얻는 방법 [1]파일 다운로드1
1860정성태2/18/201523847.NET Framework: 495. CorElementType의 요소 값 설명파일 다운로드1
1859정성태2/17/201524239Windows: 106. 컴퓨터를 재부팅하면 절전(Power Saver) 전원 모드로 돌아가는 경우
1858정성태2/16/201534261Windows: 105. 자동으로 로그아웃/잠김 화면 상태로 전환된다면? [2]
1857정성태2/16/201522265.NET Framework: 494. 값(struct) 형식의 제네릭(Generic) 타입이 박싱되는 경우의 메타데이터 토큰 값파일 다운로드1
1856정성태2/15/201521248.NET Framework: 493. TypeRef 메타테이블에 등록되는 타입의 조건파일 다운로드1
1855정성태2/10/201520795개발 환경 구성: 256. WebDAV Redirector - Sysinternals 폴더 연결 시 "The network path was not found" 오류 해결 방법
... 121  122  123  124  125  126  [127]  128  129  130  131  132  133  134  135  ...