Event Hubs 메시지 예외 - .NET(레거시)
이 섹션에서는 .NET Framework API에 의해 생성된 .NET 예외를 나열합니다.
Important
이 문서에 나열된 일부 예외는 레거시 Event Hubs .NET 라이브러리에만 적용됩니다. 예: Microsoft.ServiceBus.* 예외.
새 .NET 라이브러리에서 발생한 EventHubsException에 대한 정보는 EventHubsException - .NET을 참조하세요.
2026년 9월 30일에 Azure SDK 지침을 따르지 않는 Azure Service Bus SDK 라이브러리 WindowsAzure.ServiceBus, Microsoft.Azure.ServiceBus 및 com.microsoft.azure.servicebus를 사용 중지합니다. 또한 SBMP 프로토콜에 대한 지원이 종료되므로 2026년 9월 30일 이후에는 더 이상 이 프로토콜을 사용할 수 없습니다. 해당 날짜 마이그레이션에 중요한 보안 업데이트와 개선된 기능을 제공하는 최신 Azure SDK 라이브러리로 마이그레이션합니다.
이전 라이브러리는 2026년 9월 30일 이후에도 계속 사용할 수 있지만 더 이상 Microsoft로부터 공식 지원 및 업데이트를 받을 수 없습니다. 자세한 내용은 사용 중지 공지 지원을 참조하세요.
예외 범주
Event Hubs .NET API는 다음 범주에 해당하는 예외와, 해당 예외의 해결을 위해 수행할 수 있는 관련 조치를 함께 생성합니다.
사용자 코딩 오류:
- System.ArgumentException
- System.InvalidOperationException
- System.OperationCanceledException
- System.Runtime.Serialization.SerializationException
일반 조치: 코드를 수정한 후 계속합니다.
설치/구성 오류:
- Microsoft.ServiceBus.Messaging.MessagingEntityNotFoundException
- Microsoft.Azure.EventHubs.MessagingEntityNotFoundException
- System.UnauthorizedAccessException
일반 조치: 구성을 검토하고 필요한 경우 변경합니다.
일시적 예외:
- Microsoft.ServiceBus.Messaging.MessagingException
- Microsoft.ServiceBus.Messaging.ServerBusyException
- Microsoft.Azure.EventHubs.ServerBusyException
- Microsoft.ServiceBus.Messaging.MessagingCommunicationException
일반 조치: 작업을 다시 시도하거나 사용자에게 알립니다.
기타 예외:
- System.Transactions.TransactionException
- System.TimeoutException
- Microsoft.ServiceBus.Messaging.MessageLockLostException
- Microsoft.ServiceBus.Messaging.SessionLockLostException
일반 작업: 예외 형식에 특정됩니다. 다음 섹션의 테이블을 참조하세요.
예외 유형
다음 표에서는 메시징 예외 유형과 원인, 사용자가 수행할 수 있는 제안 조치 참고를 열거합니다.
예외 유형 | 설명/원인/예 | 권장 조치 | 자동/즉시 다시 시도 참고 |
---|---|---|---|
TimeoutException | 서버가 OperationTimeout에서 제어하는 지정된 시간 안에 요청된 작업에 응답하지 않았습니다. 서버가 요청된 작업을 완료했을 수도 있습니다. 이 예외는 네트워크 또는 기타 인프라 지연으로 인해 발생합니다. | 필요한 경우 시스템 상태에서 일관성을 확인하고 다시 시도합니다. TimeoutException을 참조하세요. |
일부 경우 다시 시도하면 문제가 해결될 수 있습니다. 코드에 재시도 논리를 추가합니다. |
InvalidOperationException | 요청한 사용자 작업이 서버 또는 서비스 내에서 허용되지 않습니다. 자세한 내용은 예외 메시지를 참조하세요. 예를 들어 ReceiveAndDelete 모드에서 메시지를 받은 경우 Complete 가 이 예외를 생성합니다. | 코드 및 설명서를 확인합니다. 요청된 작업이 유효한지 확인합니다. | 다시 시도해도 도움이 되지 않습니다. |
OperationCanceledException | 이미 종료, 중단 또는 삭제된 개체에서 작업을 호출하려 시도합니다. 드문 경우지만 앰비언트 트랜잭션이 이미 삭제되었을 수 있습니다. | 코드를 확인하고 삭제된 개체에 대해 작업을 호출하지 않는지 확인합니다. | 다시 시도해도 도움이 되지 않습니다. |
UnauthorizedAccessException | TokenProvider 개체가 토큰을 확보할 수 없거나, 토큰이 유효하지 않거나, 토큰에 작업 수행을 위해 필요한 클레임이 없습니다. | 올바른 값을 사용하여 토큰 공급자를 만드는지 확인합니다. ACS(Access Control Service) 구성을 확인합니다. | 일부 경우 다시 시도하면 문제가 해결될 수 있습니다. 코드에 재시도 논리를 추가합니다. |
ArgumentException ArgumentNullException ArgumentOutOfRangeException |
메서드에 제공된 하나 이상의 인수가 잘못되었습니다. NamespaceManager 또는 Create에 제공된 URI에 경로 세그먼트가 포함됩니다. NamespaceManager 또는 Create에 제공된 URI 스키마가 올바르지 않습니다. 속성 값이 32KB보다 큽니다. | 호출 코드를 확인하고 인수가 정확한지 확인합니다. | 재시도로 해결되지 않습니다. |
Microsoft.ServiceBus.Messaging MessagingEntityNotFoundException Microsoft.Azure.EventHubs MessagingEntityNotFoundException |
작업과 연결된 엔터티가 없거나 삭제되었습니다. | 엔터티가 있는지 확인합니다. | 재시도로 해결되지 않습니다. |
MessagingCommunicationException | 클라이언트가 Event Hubs로 연결을 설정할 수 없습니다. | 제공된 호스트 이름이 정확하며 호스트에 연결할 수 있는지 확인합니다. | 간헐적인 연결 문제라면 재시도로 문제를 해결할 수 있습니다. |
Microsoft.ServiceBus.Messaging ServerBusyException Microsoft.Azure.EventHubs ServerBusyException |
서비스가 지금은 요청을 처리할 수 없습니다. | 클라이언트가 잠시 대기한 후 작업을 다시 시도할 수 있습니다. ServerBusyException을 참조하세요. |
클라이언트가 일정 시간 이후에 다시 시도할 수 있습니다. 재시도에서 다른 예외가 발생한 경우 해당 예외의 재시도 작동을 확인합니다. |
MessagingException | 다음 상황에 발생할 수 있는 일반 메시징 예외: 다른 엔터티 형식에 속하는(예: topic) 이름이나 경로를 사용하여 QueueClient 를 만들려고 시도합니다. 1MB보다 큰 메시지를 전송하려고 시도합니다. 서버 또는 서비스가 요청을 처리하는 동안 오류가 발생했습니다. 자세한 내용은 예외 메시지를 참조하세요. 이것은 보통 일시적인 예외입니다. | 코드를 확인하고 메시지 본문에서 직렬화 가능 개체(또는 사용자 지정 직렬 변환기 사용)만 사용하는지 확인합니다. 설명서에서 지원되는 속성 값 유형을 확인하고 지원되는 유형만 사용합니다. IsTransient 속성을 확인합니다. 이 값이 true이면 작업을 다시 시도할 수 있습니다. | 재시도 동작이 정의되지 않았으면 도움이 되지 않습니다. |
MessagingEntityAlreadyExistsException | 해당 서비스 네임스페이스에서 이미 다른 엔터티가 사용하는 이름으로 엔터티를 만들려고 합니다. | 기존 엔터티를 삭제하거나 만들려는 엔터티에 다른 이름을 선택합니다. | 재시도로 해결되지 않습니다. |
QuotaExceededException | 메시징 엔터티의 최대 허용 크기에 도달했습니다. 이 예외는 소비자별 그룹 수준에서 최대 수신자 수(5)가 이미 열려 있는 경우에 발생할 수 있습니다. | 엔터티나 하위 큐에서 메시지를 수신하여 엔터티에 공간을 만듭니다. QuotaExceededException을 참조하세요. |
그 사이 메시지가 제거되었으면 재시도가 도움이 될 수 있습니다. |
MessagingEntityDisabledException | 비활성화된 엔터티의 런타임 작업에 대한 요청입니다. | 엔터티를 활성화합니다. | 그 사이에 엔터티가 활성화된 경우 다시 시도하면 문제가 해결될 수 있습니다. |
Microsoft.ServiceBus.Messaging MessageSizeExceededException Microsoft.Azure.EventHubs MessageSizeExceededException |
메시지 페이로드가 1MB 제한을 초과합니다. 이 1MB 제한은 총 메시지에 대한 것으로, 여기에는 시스템 속성과 모든 .NET 오버헤드가 포함됩니다. | 메시지 페이로드의 크기를 줄인 다음 작업을 다시 시도합니다. | 재시도로 해결되지 않습니다. |
QuotaExceededException
QuotaExceededException 은 특정 엔터티에 대한 할당량이 초과됐음을 나타냅니다.
이 예외는 소비자별 그룹 수준에서 최대 수신자 수(5)가 이미 열려 있는 경우에 발생할 수 있습니다.
Event Hubs
Event Hubs는 Event Hubs당 20개의 소비자 그룹으로 제한됩니다. 더 만들려고 하면 QuotaExceededException을 받습니다.
TimeoutException
TimeoutException 은 사용자가 시작한 작업이 작업 시간 제한보다 더 오래 걸린다는 것을 나타냅니다.
Event Hubs의 경우 시간 제한은 연결 문자열의 일부로 또는 ServiceBusConnectionStringBuilder를 통해 지정됩니다. 오류 메시지 자체는 다를 수 있지만 현재 작업에 대해 지정된 시간 제한 값을 항상 포함합니다.
서비스를 실행하는 리소스의 Event Hubs 서비스 업데이트 또는 OS 업데이트와 같은 유지 관리 작업 도중 또는 작업 사이에 시간 제한이 발생할 것으로 예상됩니다. OS 업데이트 도중 엔터티가 이동하고 노드는 업데이트 또는 재부팅되며, 이로 인해 시간 제한이 발생할 수 있습니다. Azure Event Hubs 서비스에 대한 SLA(서비스 수준 계약) 세부 정보는 Event Hubs SLA를 참조하세요.
일반적인 원인
이 오류에 대한 일반적인 두 가지 원인은 잘못된 구성 또는 일시적 서비스 오류입니다.
- 잘못된 구성 작동 조건에 대한 작업 시간 제한이 너무 작을 수도 있습니다. 클라이언트 SDK에서 작업 시간 제한에 대한 기본값은 60초입니다. 코드에 너무 작은 값으로 설정된 값이 있는지 확인합니다. 네트워크 및 CPU 사용량의 조건은 특정 작업을 완료하는 데 걸리는 시간에 영향을 줄 수 있으므로 작업 시간 제한을 작은 값으로 설정하지 않아야 합니다.
- 일시적 서비스 오류 Event Hubs 서비스에서 예를 들어 트래픽이 높은 기간 동안 요청 처리에 지연이 발생할 수 있습니다. 이러한 경우 작업이 성공할 때까지 지연 후 작업을 다시 시도할 수 있습니다. 동일한 작업을 여러 번 시도한 후에도 계속 실패하는 경우 알려진 서비스 중단이 있는지 Azure 서비스 상태 사이트 를 방문하세요.
ServerBusyException
Microsoft.ServiceBus.Messaging.ServerBusyException 또는 Microsoft.Azure.EventHubs.ServerBusyException은 서버가 오버로드되었음을 나타냅니다. 이 예외에 대한 두 개의 관련 오류 코드가 있습니다.
오류 코드 50002
이 오류는 다음 두 가지 이유 중 하나로 발생할 수 있습니다.
이벤트 허브의 모든 파티션에서 부하가 균등하게 분산되지 않으며 하나의 파티션이 로컬 처리량 단위 제한에 도달했습니다.
해결 방법: 파티션 분산 전략을 수정하거나 EventHubClient.Send(eventDataWithOutPartitionKey)를 시도하면 도움이 될 수 있습니다.
Event Hubs 네임스페이스에 충분한 처리량 단위가 없습니다(Azure Portal의 Event Hubs 네임스페이스 창에서 메트릭 화면을 확인할 수 있음). 포털에는 집계된(1분) 정보가 표시되지만 실시간으로 처리량을 측정하게 되므로 예상값에 불과합니다.
해결 방법: 네임스페이스의 처리량 단위를 늘리면 도움이 될 수 있습니다.
Azure Portal에 있는 Event Hubs 네임스페이스 페이지의 규모 페이지 또는 개요 페이지에서 처리량 단위를 구성할 수 있습니다. 또는 자동 확장을 사용할 수 있습니다. 사용량 요구 사항을 충족하기 위해 처리량 단위 수를 늘려 자동으로 규모를 확장합니다.
TU(처리량 단위)는 Event Hubs 네임스페이스의 모든 이벤트 허브에 적용됩니다. 즉, 네임스페이스 수준에서 TU를 구입하고, 해당 네임스페이스에 속한 이벤트 허브 간에 공유됩니다. 각 TU에서 네임스페이스에 제공하는 기능은 다음과 같습니다.
- 초당 최대 1MB의 수신 이벤트(이벤트 허브로 전송된 이벤트), 단 초당 1,000개 이하의 수신 이벤트, 관리 작업 또는 제어 API 호출
- 초당 최대 2MB의 송신 이벤트(이벤트 허브에서 사용된 이벤트), 단 4096개를 초과하지 않는 송신 이벤트.
- 최대 84GB의 이벤트 스토리지(기본 1시간 보존 기간에 충분)
개요 페이지의 메트릭 표시 섹션에서 처리량 탭으로 전환합니다. 차트를 선택하면 X축에 1분 간격으로 더 큰 창에서 열립니다. 최고 값을 확인하고 60로 나누어 수신 바이트/초 또는 발신 바이트/초를 파악합니다. 요청 탭에서 비슷한 방법을 사용하여 사용량이 많은 시간에 초당 요청 수를 계산합니다.
값이 TU * 제한보다 높은 경우(수신의 경우 초당 1MB 또는 수신/초의 경우 1,000개 요청, 발신의 경우 초당 2MB) Event Hubs 네임스페이스의 (왼쪽 메뉴에 있는) 규모 페이지를 사용하여 TU의 수를 늘리고 수동으로 확장하거나 Event Hubs의 자동 확장 기능을 사용합니다. 네임스페이스를 수동으로 크기 조정하거나 자동으로 크기 조정할 때 최대 40TU까지 확장할 수 있습니다.
오류 코드 50008
이 오류는 드물게 발생합니다. 네임스페이스에 대한 코드를 실행하는 컨테이너의 CPU가 낮아서 Event Hubs 부하 분산 장치가 몇 초 이내에 시작되지 못할 때 이 오류가 발생합니다.
해결 방법: GetRuntimeInformation 메서드에 대한 호출 수를 제한합니다. Azure Event Hubs는 소비자 그룹별로 초당 최대 50개의 호출을 지원하여 초당 GetRuntimeInfo를 가져옵니다. 제한에 도달하면 다음과 유사한 예외가 발생할 수 있습니다.
ExceptionId: 00000000000-00000-0000-a48a-9c908fbe84f6-ServerBusyException: The request was terminated because the namespace 75248:aaa-default-eventhub-ns-prodb2b is being throttled. Error code : 50008. Please wait 10 seconds and try again.
다음 단계
Event Hubs에 대한 자세한 내용은 다음 링크를 참조하세요.