Share via


Key Vault에서 자동으로 비밀 및 인증서 다시 로드

App Configuration 및 Key Vault는 많은 애플리케이션에서 함께 사용되는 보완 서비스입니다. 앱 구성은 Key Vault에 저장된 비밀 또는 인증서를 참조하는 App Configuration 저장소에 키를 만들어 서비스를 함께 사용하는 데 도움이 됩니다. Key Vault는 인증서의 공개 및 프라이빗 키 쌍을 비밀로 저장하므로 애플리케이션은 Key Vault에서 모든 인증서를 비밀로 검색할 수 있습니다.

우수한 보안 방법으로 비밀인증서를 주기적으로 교체해야 합니다. Key Vault에서 순환된 후에는 애플리케이션이 최신 비밀 및 인증서 값을 선택하기를 원할 것입니다. 애플리케이션을 다시 시작하지 않고 이를 수행할 수 있는 두 가지 방법이 있습니다.

  • Sentinel 키-값을 업데이트하여 전체 구성 새로 고침을 트리거함으로써 모든 Key Vault 비밀 및 인증서를 다시 로드합니다. 자세한 내용은 ASP.NET Core 앱에서 동적 구성 사용 방법을 참조하세요.
  • Key Vault에서 일부 또는 모든 비밀 및 인증서를 주기적으로 다시 로드합니다.

첫 번째 옵션에서는 Key Vault에서 비밀 및 인증서를 교체할 때마다 앱 구성에서 Sentinel 키-값을 업데이트해야 합니다. 이 접근 방식은 애플리케이션에서 비밀 및 인증서를 즉시 다시 로드하려는 경우에 적합합니다. 그러나 Key Vault에서 비밀과 인증서가 자동으로 순환될 때 Sentinel 키-값을 제때 업데이트하지 않으면 애플리케이션에 오류가 발생할 수 있습니다. 두 번째 옵션을 사용하면 이 프로세스를 완전히 자동화할 수 있습니다. 순환 시간으로부터 허용 가능한 대기 시간 내에 Key Vault에서 비밀 및 인증서를 다시 로드하도록 애플리케이션을 구성할 수 있습니다. 이 자습서에서는 두 번째 옵션을 안내합니다.

필수 조건

Key Vault에 자동 순환 인증서 추가

자습서: Key Vault에서 인증서 자동 순환 구성에 따라 이전 자습서에서 만든 Key Vault에 ExampleCertificate라는 자동 순환 인증서를 추가합니다.

앱 구성에서 Key Vault 인증서에 대한 참조 추가

  1. Azure Portal에서 모든 리소스를 선택한 다음 이전 자습서에서 만든 App Configuration 저장소 인스턴스를 선택합니다.

  2. 구성 탐색기를 선택합니다.

  3. + 만들기>Key Vault 참조를 선택하고 다음 값을 지정합니다.

    • : TestApp:Settings:KeyVaultCertificate를 선택합니다.
    • 레이블: 이 값은 비워 둡니다.
    • 구독, 리소스 그룹Key Vault: 이전 자습서에서 만든 Key Vault에 해당하는 값을 입력합니다.
    • 비밀: 이전 섹션에서 만든 ExampleCertificate라는 보안 비밀을 선택합니다.
    • 비밀 버전: 최신 버전입니다.

참고 항목

특정 버전을 참조하는 경우 Key Vault에서 비밀 또는 인증서를 다시 로드하면 항상 동일한 값이 반환됩니다.

Key Vault 비밀 및 인증서를 다시 로드하도록 코드 업데이트

Program.cs 파일에서 AddAzureAppConfiguration 메서드를 업데이트하여 SetSecretRefreshInterval 메서드를 통해 Key Vault 인증서의 새로 고침 간격을 설정합니다. 이 변경으로 애플리케이션은 12시간마다 ExampleCertificate에 대한 공개-프라이빗 키 쌍을 다시 로드합니다.

config.AddAzureAppConfiguration(options =>
{
    options.Connect(settings["ConnectionStrings:AppConfig"])
            .ConfigureKeyVault(kv =>
            {
                kv.SetCredential(new DefaultAzureCredential());
                kv.SetSecretRefreshInterval("TestApp:Settings:KeyVaultCertificate", TimeSpan.FromHours(12));
            });
});

SetSecretRefreshInterval 메서드의 첫 번째 인수는 앱 구성의 Key Vault 참조 키입니다. 이 인수는 선택 사항입니다. 키 매개 변수를 생략하면 새로 고침 간격이 개별 새로 고침 간격이 없는 모든 비밀 및 인증서에 적용됩니다.

새로 고침 간격은 Key Vault 또는 앱 구성의 값 변경에 관계없이 비밀 및 인증서가 Key Vault에서 다시 로드되는 빈도를 정의합니다. 앱 구성에서 값이 변경될 때 비밀과 인증서를 다시 로드하려면 ConfigureRefresh 메서드를 사용하여 모니터링할 수 있습니다. 자세한 내용은 ASP.NET Core 앱에서 동적 구성 사용 방법을 참조하세요.

Key Vault에서 비밀 및 인증서가 업데이트된 후 허용 가능한 대기 시간에 따라 새로 고침 간격을 선택합니다. 제한되지 않도록 Key Vault 서비스 제한을 고려하는 것도 중요합니다.

리소스 정리

이 문서에서 만든 리소스를 계속 사용하지 않으려면 여기서 만든 리소스 그룹을 삭제하여 요금이 부과되지 않도록 합니다.

Important

리소스 그룹을 삭제하면 다시 되돌릴 수 없습니다. 리소스 그룹 및 포함된 모든 리소스가 영구적으로 삭제됩니다. 잘못된 리소스 그룹 또는 리소스를 자동으로 삭제하지 않도록 합니다. 유지하려는 다른 리소스가 포함된 리소스 그룹 내에서 이 문서에 대한 리소스를 만든 경우 리소스 그룹을 삭제하는 대신 해당 창에서 각 리소스를 개별적으로 삭제합니다.

  1. Azure Portal에 로그인하고 리소스 그룹을 선택합니다.
  2. 이름으로 필터링 상자에서 리소스 그룹의 이름을 입력합니다.
  3. 결과 목록에서 리소스 그룹 이름을 선택하여 개요를 확인합니다.
  4. 리소스 그룹 삭제를 선택합니다.
  5. 리소스 그룹 삭제를 확인하는 메시지가 표시됩니다. 리소스 그룹의 이름을 입력하여 확인하고 삭제를 선택합니다.

잠시 후, 리소스 그룹 및 모든 해당 리소스가 삭제됩니다.

다음 단계

이 자습서에서는 Key Vault에서 비밀 및 인증서를 자동으로 다시 로드하도록 애플리케이션을 설정하는 방법을 알아보았습니다. 관리 ID를 사용하여 App Configuration 및 Key Vault에 대한 액세스를 간소화하는 방법을 알아보려면 다음 자습서를 계속 진행하세요.