다음을 통해 공유


빠른 시작: Azure Service Bus 큐에 메시지 보내기 및 받기(Python)

이 문서에서는 Service Bus 큐에 메시지를 보내고 받는 간단한 시나리오에 대한 단계별 지침을 제공합니다. GitHub의 Python용 Azure SDK 리포지토리에서 Azure Service Bus에 대한 미리 빌드된 JavaScript 및 TypeScript 샘플을 찾을 수 있습니다.

이 빠른 시작에서 당신은 다음을 수행합니다.

  • Azure Portal을 사용하여 Service Bus 네임스페이스를 만듭니다.

  • Azure Portal을 사용하여 Service Bus 큐를 만듭니다.

  • Azure-servicebus 패키지를 사용하여 다음을 수행할 Python 코드를 작성합니다.

    • 큐에 메시지 집합을 보냅니다.
    • 큐에서 해당 메시지를 받습니다.

서비스를 접하는 경우 시작하기 전에 Service Bus 개요 를 참조하세요.

필수 조건

사용자 고유의 Azure 계정으로 이 빠른 시작을 사용하려면 다음이 필요합니다.

  • 개발자 머신에 암호 없는 인증을 제공하는 Azure CLI를 설치합니다.
  • 터미널 또는 명령 프롬프트에서 az login을 사용하여 Azure 계정으로 로그인합니다.
  • 리소스에 적절한 데이터 역할을 추가할 때 동일한 계정을 사용합니다.
  • 동일한 터미널 또는 명령 프롬프트에서 코드를 실행합니다.
  • Service Bus 네임스페이스의 이름을 적어둡니다. 코드에 필요합니다.

이 빠른 시작은 Python을 사용하여 복사하고 실행할 수 있는 샘플에서 작동합니다. Python 애플리케이션을 만드는 방법에 대한 지침은 빠른 시작: Azure App Service에 Python 웹앱 배포를 참조하세요. 이 빠른 시작에서 사용되는 패키지를 설치하는 방법에 대한 자세한 내용은 Python용 Azure 라이브러리 패키지를 설치하는 방법을 참조하세요.

Azure Portal에서 네임스페이스 만들기

Azure에서 Service Bus 메시징 엔터티 사용을 시작하려면 Azure 전체에서 고유한 이름으로 네임스페이스를 만듭니다. 네임스페이스는 애플리케이션에서 큐 및 토픽과 같은 Service Bus 리소스에 대한 범위 지정 컨테이너를 제공합니다.

네임스페이스를 만들려면

  1. Azure Portal에 로그인합니다.

  2. 왼쪽 위에서 플라이아웃 메뉴를 선택하고 모든 서비스 페이지로 이동합니다.

  3. 왼쪽 탐색 모음에서 통합을 선택합니다.

  4. 메시징 서비스>Service Bus까지 아래로 스크롤하고 만들기를 선택합니다.

    메뉴에서 리소스 만들기, 통합 및 Service Bus 선택을 보여 주는 스크린샷

  5. 네임스페이스 만들기 페이지의 기본 사항 탭에서 다음 단계를 수행합니다.

    1. 구독에 대해 네임스페이스를 만들 Azure 구독을 선택합니다.

    2. 리소스 그룹의 경우 기존 리소스 그룹을 선택하거나 새 리소스 그룹을 만듭니다.

    3. 다음 명명 규칙을 충족하는 네임스페이스 이름을 입력합니다.

      • 이름은 Azure에서 고유해야 합니다. 시스템에서 사용 가능한 이름인지 즉시 확인합니다.
      • 이름 길이는 6~50자여야 합니다.
      • 이름에는 문자, 숫자, 하이픈만 포함될 수 있습니다 -.
      • 이름은 문자로 시작하고 문자 또는 숫자로 끝나야 합니다.
      • 이름은 -sb>로 -mgmt 끝나지 않습니다.
    4. 위치의 경우 네임스페이스를 호스트할 지역을 선택합니다.

    5. 가격 책정 계층에 대해 네임스페이스에 대한 가격 책정 계층(기본, 표준 또는 프리미엄)을 선택합니다. 이 빠른 시작의 경우 표준을 선택합니다.

      프리미엄 계층을 선택하는 경우 네임스페이스에 대해 지역에서 복제를 사용하도록 설정할 수 있습니다. 지역 복제 기능을 사용하면 네임스페이스의 메타데이터와 데이터가 주 지역에서 하나 이상의 보조 지역으로 지속적으로 복제됩니다.

      중요합니다

      토픽 및 구독을 사용하려면 표준 또는 프리미엄을 선택합니다. 기본 가격 책정 계층에서는 토픽 및 구독이 지원되지 않습니다.

      프리미엄 가격 책정 계층을 선택한 경우 메시징 단위 수를 지정합니다. 프리미엄 계층은 CPU 및 메모리 수준에서 리소스 격리를 제공하므로 각 워크로드가 독립적으로 실행됩니다. 이 리소스 컨테이너를 메시징 단위라고 합니다. 프리미엄 네임스페이스에는 하나 이상의 메시징 단위가 있습니다. 각 Service Bus 프리미엄 네임스페이스에 대해 1, 2, 4, 8 또는 16개의 메시징 단위를 선택할 수 있습니다. 자세한 내용은 Service Bus 프리미엄 메시징 계층을 참조하세요.

    6. 페이지 아래쪽에서 검토 + 만들기를 선택합니다.

      네임스페이스 만들기 페이지를 보여 주는 스크린샷

    7. 검토 + 만들기 페이지에서 설정을 검토하고 만들기를 선택합니다.

  6. 리소스 배포에 성공하면 배포 페이지에서 리소스로 이동을 선택합니다.

    리소스로 이동 링크가 있는 배포 성공 페이지를 보여 주는 스크린샷

  7. Service Bus 네임스페이스에 대한 홈페이지가 표시됩니다.

    만든 Service Bus 네임스페이스의 홈페이지를 보여 주는 스크린샷.

Azure Portal에서 큐 만들기

  1. Service Bus 네임스페이 페이지에서 탐색 메뉴의 엔터티를 왼쪽으로 확장하고 큐를 선택합니다.

  2. 페이지의 도구 모음에서 + 큐를 선택합니다.

  3. 큐의 이름을 입력합니다. 다른 값은 기본값으로 둡니다.

  4. 선택하고생성합니다.

    큐 만들기 페이지를 보여 주는 스크린샷

Azure에 앱 인증

이 문서에서는 Azure Service Bus에 연결하는 두 가지 방법, 즉 암호 없는 문자열과 연결 문자열을 보여줍니다.

첫 번째 옵션은 Microsoft Entra ID 및 RBAC(역할 기반 액세스 제어)의 보안 주체를 사용하여 Service Bus 네임스페이스에 연결하는 방법을 보여 줍니다. 코드, 구성 파일 또는 Azure Key Vault와 같은 보안 스토리지에 하드 코딩된 연결 문자열이 있는 것에 대해 걱정할 필요가 없습니다.

두 번째 옵션은 연결 문자열을 사용하여 Service Bus 네임스페이스에 연결하는 방법을 보여줍니다. Azure를 접하는 경우 연결 문자열 옵션을 더 쉽게 따를 수 있습니다. 실제 애플리케이션 및 프로덕션 환경에서는 암호 없는 옵션을 사용하는 것이 좋습니다. 자세한 내용은 Service Bus 인증 및 권한 부여를 참조하세요. 암호 없는 인증에 대한 자세한 내용은 .NET 앱 인증을 참조하세요.

Microsoft Entra 사용자에게 역할 할당

로컬로 개발할 때 Azure Service Bus에 연결하는 사용자 계정에 올바른 권한이 있는지 확인합니다. 메시지를 보내고 받으려면 Azure Service Bus 데이터 소유자 역할이 필요합니다. 이 역할을 자신에게 할당하려면 사용자 액세스 관리자 역할 또는 작업을 포함하는 Microsoft.Authorization/roleAssignments/write 다른 역할이 필요합니다.

Azure Portal, Azure CLI 또는 Azure PowerShell을 사용하여 사용자에게 Azure RBAC 역할을 할당할 수 있습니다. 역할 할당에 사용 가능한 범위에 대해 자세히 알아보려면 Azure RBAC에 대한 이해 범위를 참조하세요.

다음 예에서는 Azure Service Bus 리소스에 대한 모든 권한을 제공하는 Azure Service Bus Data Owner 역할을 사용자 계정에 할당합니다. 실제 시나리오에서는 최소 권한 원칙 에 따라 사용자에게 더 안전한 프로덕션 환경에 필요한 최소 권한만 부여합니다.

Azure Service Bus에 대한 Azure 기본 제공 역할

Azure Service Bus의 경우 Azure Portal 및 Azure 리소스 관리 API를 통한 네임스페이스 및 관련된 모든 리소스의 관리는 이미 Azure RBAC 모델을 사용하여 보호되고 있습니다. Azure는 Service Bus 네임스페이스에 대한 액세스 권한을 부여하기 위해 다음과 같은 Azure 기본 제공 역할을 제공합니다.

  • Azure Service Bus 데이터 소유자: 큐, 토픽, 구독 및 필터를 포함하여 Service Bus 네임스페이스 및 해당 엔터티에 대한 데이터 액세스를 사용하도록 설정합니다. 이 역할의 멤버는 큐 또는 토픽/구독에서 메시지를 보내고 받을 수 있습니다.
  • Azure Service Bus 데이터 발신자: 이 역할을 사용하여 Service Bus 네임스페이스 및 해당 엔터티에 대한 액세스 권한을 부여 send 합니다.
  • Azure Service Bus 데이터 수신기: 이 역할을 사용하여 Service Bus 네임스페이스 및 해당 엔터티에 대한 액세스 권한을 부여 receive 합니다.

사용자 지정 역할을 만들려면 Service Bus 작업에 필요한 권한을 참조하세요.

Azure Service Bus 소유자 역할에 Microsoft Entra 사용자 추가

Service Bus 네임스페이스 수준에서 Azure Service Bus 데이터 소유자 역할에 Microsoft Entra 사용자 이름을 추가합니다. 이 구성을 사용하면 사용자 계정의 컨텍스트에서 실행되는 앱이 큐 또는 토픽에 메시지를 보낼 수 있습니다. 큐 또는 토픽의 구독(subscription)에서 메시지를 받을 수 있습니다.

중요합니다

대부분의 경우 역할 할당이 Azure에서 전파되는 데 1~2분이 걸립니다. 드문 경우지만 최대 8분까지 걸릴 수 있습니다. 코드를 처음 실행할 때 인증 오류가 발생하면 잠시 기다렸다가 다시 시도하세요.

  1. Azure Portal에 Service Bus 네임스페이스 페이지가 열려 있지 않은 경우 기본 검색 창이나 왼쪽 탐색 모음을 사용하여 Service Bus 네임스페이스를 찾습니다.

  2. 개요 페이지의 왼쪽 메뉴에서 액세스 제어(IAM)를 선택합니다.

  3. 액세스 제어(IAM) 페이지에서 역할 할당 탭을 선택합니다.

  4. 상단 메뉴에서 + 추가 를 선택한 다음 역할 할당을 추가합니다.

    역할을 할당하는 방법을 보여 주는 스크린샷

  5. 검색 상자를 사용하여 결과를 원하는 역할로 필터링합니다. 이 예에서는 Azure Service Bus Data Owner를 검색하고 일치하는 결과를 선택합니다. 다음을 선택합니다.

  6. 다음에 대한 액세스 할당 아래에서 사용자, 그룹 또는 서비스 주체를 선택한 다음, + 멤버 선택을 선택합니다.

  7. 대화 상자에서 Microsoft Entra 사용자 이름(일반적으로 user@___domain 이메일 주소)을 검색한 다음, 대화 상자 하단에서 선택을 선택합니다.

  8. 검토 + 할당을 선택하여 최종 페이지로 이동한 다음, 검토 + 할당을 다시 선택하여 프로세스를 완료합니다.

pip를 사용하여 패키지 설치

  1. 이 Service Bus 빠른 시작에 필요한 Python 패키지를 설치하려면 해당 경로에 Python이 있는 명령 프롬프트 창을 엽니다.

  2. 샘플을 저장할 폴더로 디렉터리를 변경합니다.

  3. 다음 패키지를 설치합니다.

    pip install azure-servicebus
    pip install azure-identity
    pip install aiohttp
    

큐에 메시지 보내기

다음 샘플 코드는 큐에 메시지를 보내는 방법을 보여줍니다. Visual Studio Code와 같은 텍스트 편집기를 열고, send.py 파일을 만들고, 다음 코드를 추가합니다.

  1. Import 문을 추가합니다.

    import asyncio
    from azure.servicebus.aio import ServiceBusClient
    from azure.servicebus import ServiceBusMessage
    from azure.identity.aio import DefaultAzureCredential
    
  2. 상수를 추가하고 자격 증명을 정의합니다.

    FULLY_QUALIFIED_NAMESPACE = "FULLY_QUALIFIED_NAMESPACE"
    QUEUE_NAME = "QUEUE_NAME"
    
    credential = DefaultAzureCredential()
    

    중요합니다

    • FULLY_QUALIFIED_NAMESPACE를 Service Bus 네임스페이스의 정규화된 네임스페이스로 바꿉니다.
    • QUEUE_NAME을 큐 이름으로 바꿉니다.
  3. 단일 메시지를 보내는 메서드를 추가합니다.

    async def send_single_message(sender):
        # Create a Service Bus message and send it to the queue
        message = ServiceBusMessage("Single Message")
        await sender.send_messages(message)
        print("Sent a single message")
    

    보낸 사람은 만든 큐에 대한 클라이언트 역할을 하는 개체입니다. 나중에 만들고 이 함수에 인수로 보냅니다.

  4. 메시지 목록을 보내는 메서드를 추가합니다.

    async def send_a_list_of_messages(sender):
        # Create a list of messages and send it to the queue
        messages = [ServiceBusMessage("Message in list") for _ in range(5)]
        await sender.send_messages(messages)
        print("Sent a list of 5 messages")
    
  5. 메시지 일괄 처리를 보내는 메서드를 추가합니다.

    async def send_batch_message(sender):
        # Create a batch of messages
        async with sender:
            batch_message = await sender.create_message_batch()
            for _ in range(10):
                try:
                    # Add a message to the batch
                    batch_message.add_message(ServiceBusMessage("Message inside a ServiceBusMessageBatch"))
                except ValueError:
                    # ServiceBusMessageBatch object reaches max_size.
                    # New ServiceBusMessageBatch object can be created here to send more data.
                    break
            # Send the batch of messages to the queue
            await sender.send_messages(batch_message)
        print("Sent a batch of 10 messages")
    
  6. Service Bus 클라이언트를 만든 다음, 메시지를 보낼 큐 발신자 개체를 만듭니다.

    async def run():
        # create a Service Bus client using the credential
        async with ServiceBusClient(
            fully_qualified_namespace=FULLY_QUALIFIED_NAMESPACE,
            credential=credential,
            logging_enable=True) as servicebus_client:
            # get a Queue Sender object to send messages to the queue
            sender = servicebus_client.get_queue_sender(queue_name=QUEUE_NAME)
            async with sender:
                # send one message
                await send_single_message(sender)
                # send a list of messages
                await send_a_list_of_messages(sender)
                # send a batch of messages
                await send_batch_message(sender)
    
            # Close credential when no longer needed.
            await credential.close()
    
  7. run 메서드를 호출하고 메시지를 인쇄합니다.

    asyncio.run(run())
    print("Done sending messages")
    print("-----------------------")
    

큐에서 메시지 받기

다음 샘플 코드는 큐에서 메시지를 수신하는 방법을 보여 줍니다. 코드는 5(max_wait_time)초 동안 새 메시지를 수신하지 않을 때까지 계속해서 새 메시지를 받습니다.

Visual Studio Code와 같은 텍스트 편집기를 열고, recv.py 파일을 만들고, 다음 코드를 추가합니다.

  1. send.py 샘플과 마찬가지로, import 문장을 추가합니다. 상수는 사용자 고유의 값으로 바꾸고 자격 증명을 정의합니다.

    import asyncio
    
    from azure.servicebus.aio import ServiceBusClient
    from azure.identity.aio import DefaultAzureCredential
    
    FULLY_QUALIFIED_NAMESPACE = "FULLY_QUALIFIED_NAMESPACE"
    QUEUE_NAME = "QUEUE_NAME"
    
    credential = DefaultAzureCredential()
    
  2. Service Bus 클라이언트를 만든 다음, 메시지를 받을 큐 수신자 개체를 만듭니다.

    async def run():
        # create a Service Bus client using the connection string
        async with ServiceBusClient(
            fully_qualified_namespace=FULLY_QUALIFIED_NAMESPACE,
            credential=credential,
            logging_enable=True) as servicebus_client:
    
            async with servicebus_client:
                # get the Queue Receiver object for the queue
                receiver = servicebus_client.get_queue_receiver(queue_name=QUEUE_NAME)
                async with receiver:
                    received_msgs = await receiver.receive_messages(max_wait_time=5, max_message_count=20)
                    for msg in received_msgs:
                        print("Received: " + str(msg))
                        # complete the message so that the message is removed from the queue
                        await receiver.complete_message(msg)
    
            # Close credential when no longer needed.
            await credential.close()
    
  3. run 메서드를 호출합니다.

    asyncio.run(run())
    

앱 실행

해당 경로에 Python이 있는 명령 프롬프트를 연 다음, 큐에서 메시지를 보내고 받는 코드를 실행합니다.

python send.py; python recv.py

다음과 같은 출력이 표시됩니다.

Sent a single message
Sent a list of 5 messages
Sent a batch of 10 messages
Done sending messages
-----------------------
Received: Single Message
Received: Message in list
Received: Message in list
Received: Message in list
Received: Message in list
Received: Message in list
Received: Message inside a ServiceBusMessageBatch
Received: Message inside a ServiceBusMessageBatch
Received: Message inside a ServiceBusMessageBatch
Received: Message inside a ServiceBusMessageBatch
Received: Message inside a ServiceBusMessageBatch
Received: Message inside a ServiceBusMessageBatch
Received: Message inside a ServiceBusMessageBatch
Received: Message inside a ServiceBusMessageBatch
Received: Message inside a ServiceBusMessageBatch
Received: Message inside a ServiceBusMessageBatch

Azure portal에서 Service Bus 네임스페이스로 이동합니다. 개요 페이지에서 수신발신 메시지 수가 16개인지 확인합니다. 개수가 표시되지 않으면 몇 분 정도 기다린 다음 페이지를 새로 고칩니다.

수신 및 발신 메시지 수

개요 페이지에서 큐를 선택하여 Service Bus 큐 페이지로 이동합니다. 이 페이지에서 수신발신 메시지 수를 확인할 수도 있습니다. 큐의 현재 크기활성 메시지 수와 같은 기타 정보도 볼 수 있습니다.

큐 세부 정보

다음 설명서와 샘플을 참조하세요.