Azure Web App에서 Azure SQL Database 접근 오류 해결

  • 4 minutes to read

소개

Azure 환경에서 ASP.NET Core Web AppAzure SQL Database에 접속하려 할 때, SQL 서버에 대한 IP 접근 권한이 설정되어 있지 않으면 연결이 차단됩니다. 이 문제는 주로 아래와 같은 에러 메시지로 나타납니다.

Cannot open server <server-name> requested by the login. Client with IP address <your-ip> is not allowed to access the server.

이 가이드는 해당 문제를 해결하기 위한 3단계를 기술 문서 형식으로 안내합니다.

따라하기

1단계: ASP.NET Core Web App에서 오류 발생 확인

웹 앱에서 Azure SQL Database에 연결을 시도할 때, 아래와 같은 오류가 로그에 표시될 수 있습니다.

Web App에서 오류 발생 확인

Microsoft.Data.SqlClient.SqlException (0x80131904): Cannot open server 'mydbserver' requested by the login. Client with IP address '123.45.67.89' is not allowed to access the server.

이 오류는 SQL Database에 대한 방화벽 설정이 현재 IP 주소를 허용하지 않기 때문에 발생합니다. Azure SQL Database는 기본적으로 외부 접근을 차단하고 있어, 허용된 IP만 연결이 가능합니다.

2단계: Azure Portal에서 SQL Database로 이동

문제를 해결하기 위해 다음 절차를 따릅니다.

SQL Database로 이동

  1. https://portal.azure.com 에 로그인합니다.

  2. SQL databases를 선택한 후, 연결하려는 데이터베이스를 클릭합니다.

  3. 좌측 메뉴에서 Set server firewall 또는 Networking을 클릭합니다.

    • Azure UI에 따라 메뉴 이름이 달라질 수 있습니다.
    • Set server firewall 메뉴는 예전 UI, Networking은 최신 UI에서 사용됩니다.
  4. 해당 SQL 서버의 방화벽 설정 페이지로 이동합니다.

이 페이지에서는 서버에 접근을 허용할 IP 주소를 직접 추가할 수 있습니다.

3단계: 현재 클라이언트 IP 주소 추가

방화벽 설정 페이지에서 다음 단계를 수행합니다.

현재 클라이언트 IP 주소 추가

  1. 상단의 Add client IP 버튼을 클릭합니다.

    • 현재 사용 중인 클라이언트(브라우저)의 공인 IP가 자동으로 입력됩니다.
  2. 자동 입력된 IP 주소를 확인한 후 Save 버튼을 클릭합니다.

    • 저장 후 몇 초 내에 설정이 반영됩니다.
  3. Web App을 다시 실행하여 SQL Database 연결이 성공하는지 확인합니다.

참고: Azure Web App에서 실행 중인 애플리케이션이 SQL에 접근하려면 Web App의 Outbound IP 주소들도 방화벽에 등록해야 할 수 있습니다. 이 경우 Web App의 Properties 탭에서 Outbound IP 목록을 확인하고 수동으로 추가할 수 있습니다.

마무리

Azure Web App에서 Azure SQL Database에 접근하기 위해서는 SQL 서버 방화벽에 IP 주소를 명시적으로 허용해야 합니다. 본 문서에서 소개한 3단계를 따르면, 다음과 같은 문제를 빠르게 해결할 수 있습니다.

  1. ASP.NET Core Web App에서의 접속 오류 확인
  2. SQL Database의 방화벽 또는 네트워킹 설정 메뉴 진입
  3. 클라이언트 IP 추가 및 저장

이 설정은 개발 단계뿐 아니라 운영 환경에서도 반드시 고려되어야 하며, 보안상 IP 범위를 최소화하여 설정하는 것이 좋습니다.

더 깊이 공부하고 싶다면
DevLec에서는 실무 중심의 C#, .NET, ASP.NET Core, Blazor, 데이터 액세스 강좌를 단계별로 제공합니다. 현재 수강 가능한 강좌 외에도 더 많은 과정이 준비되어 있습니다.
DevLec.com에서 자세한 커리큘럼을 확인해 보세요.
DevLec 공식 강의
C# Programming
C# 프로그래밍 입문
프로그래밍을 처음 시작하는 입문자를 위한 C# 기본기 완성 과정입니다.
ASP.NET Core 10.0
ASP.NET Core 10.0 시작하기 MVC Fundamentals Part 1 MVC Fundamentals Part 2
웹 애플리케이션의 구조와 MVC 패턴을 ASP.NET Core로 실습하며 익힐 수 있습니다.
Blazor Server
풀스택 웹개발자 과정 Part 1 풀스택 웹개발자 과정 Part 2 풀스택 웹개발자 과정 Part 3
실무에서 바로 활용 가능한 Blazor Server 기반 관리자·포털 프로젝트를 만들어 봅니다.
Data & APIs
Entity Framework Core 시작하기 ADO.NET Fundamentals Blazor Server Fundamentals Minimal APIs
데이터 액세스와 Web API를 함께 이해하면 실무 .NET 백엔드 개발에 큰 도움이 됩니다.
VisualAcademy Docs의 모든 콘텐츠, 이미지, 동영상의 저작권은 박용준에게 있습니다. 저작권법에 의해 보호를 받는 저작물이므로 무단 전재와 복제를 금합니다. 사이트의 콘텐츠를 복제하여 블로그, 웹사이트 등에 게시할 수 없습니다. 단, 링크와 SNS 공유, Youtube 동영상 공유는 허용합니다. www.VisualAcademy.com
박용준 강사의 모든 동영상 강의는 데브렉에서 독점으로 제공됩니다. www.devlec.com