Ruby에서 Queue Storage를 사용하는 방법

Microsoft Azure Storage Explorer 시도

Microsoft Azure Storage Explorer는 Windows, macOS 및 Linux에서 Azure Storage 데이터로 시각적으로 작업할 수 있도록 해주는 Microsoft의 독립 실행형 무료 앱입니다.

개요

이 가이드에서는 Microsoft Azure Queue Storage 서비스를 사용하여 일반 시나리오를 수행하는 방법을 설명합니다. 샘플은 Ruby Azure API를 사용하여 작성되었습니다. 여기서 다루는 시나리오에는 큐 만들기 및 삭제뿐만 아니라 큐 메시지 삽입, 보기, 가져오기삭제가 포함됩니다.

Queue Storage란?

Azure Queue Storage는 HTTP 또는 HTTPS를 사용하여 인증된 호출을 통해 전 세계 어디에서나 액세스할 수 있는 다수의 메시지를 저장하기 위한 서비스입니다. 단일 큐 메시지의 크기는 최대 64KB일 수 있으며, 하나의 큐에 스토리지 계정의 총 용량 제한까지 수백만 개의 메시지가 포함될 수 있습니다. Queue Storage는 비동기적으로 처리할 작업의 백로그를 만드는 데 자주 사용됩니다.

큐 서비스 개념

Azure 큐 서비스에는 다음 구성 요소가 포함됩니다.

Azure 큐 서비스 구성 요소

  • Storage 계정: Azure Storage에 대한 모든 액세스는 Storage 계정을 통해 수행됩니다. 스토리지 계정에 대한 자세한 내용은 스토리지 계정 개요를 참조하세요.

  • 큐: 큐에는 메시지 집합이 포함됩니다. 모든 메시지는 큐에 있어야 합니다. 큐 이름은 모두 소문자여야 합니다. 큐의 명명에 대한 자세한 내용은 큐 및 메타데이터 명명을 참조하세요.

  • 메시지: 최대 64KB인 임의 형식의 메시지입니다. 메시지가 큐에 남아 있을 수 있는 최대 시간은 7일입니다. 2017-07-29 이상 버전에서 허용되는 최대 TTL(Time to Live)은 모든 양수 또는 메시지가 만료되지 않는 -1입니다. 이 매개 변수를 생략하면 기본 TTL(Time to Live)은 7일입니다.

  • URL 형식: 큐는 http://<storage account>.queue.core.windows.net/<queue> URL 형식을 사용하여 주소를 지정할 수 있습니다.

    다음 URL은 다이어그램에 있는 큐의 주소를 지정합니다.

    http://myaccount.queue.core.windows.net/incoming-orders

Azure Storage 계정 만들기

첫 번째 Azure Storage 계정을 가장 쉽게 만드는 방법은 Azure Portal을 사용하는 것입니다. 자세한 내용은 스토리지 계정 만들기를 참조하십시오.

또한 Azure PowerShell, Azure CLI 또는 .NET용 Azure Storage 리소스 공급자를 사용하여 Azure 스토리지 계정을 만들 수도 있습니다.

이 시점에서 스토리지 계정을 Azure에 만들지 않으려는 경우 Azurite 스토리지 에뮬레이터를 사용하여 로컬 환경에서 코드를 실행하고 테스트할 수도 있습니다. 자세한 내용은 로컬 Azure Storage 개발에 Azurite 에뮬레이터 사용을 참조하세요.

Ruby 애플리케이션 만들기

Ruby 애플리케이션을 만듭니다. 지침은 Linux의 App Service에서 Ruby 애플리케이션 만들기를 참조하세요.

스토리지에 액세스하도록 애플리케이션 구성

Azure Storage를 사용하려면 스토리지 REST 서비스와 통신하는 편리한 라이브러리 세트가 포함된 Ruby Azure 패키지를 다운로드하여 사용해야 합니다.

RubyGems를 사용하여 패키지 가져오기

  1. PowerShell(Windows), Terminal(Mac) 또는 Bash(Unix)와 같은 명령줄 인터페이스를 사용합니다.
  2. 명령 창에서 gem install azure을 입력하여 gem 및 종속성을 설치합니다.

패키지 가져오기

원하는 텍스트 편집기를 사용하여 스토리지를 사용하려는 Ruby 파일의 맨 위에 다음을 추가합니다.

require "azure"

Azure Storage 연결 설정

Azure 모듈은 Azure Storage 계정에 연결하는 데 필요한 정보에 대한 환경 변수 AZURE_STORAGE_ACCOUNTAZURE_STORAGE_ACCESS_KEY를 읽습니다. 이러한 환경 변수가 설정되지 않으면 Azure::QueueService를 사용하기 전에 다음 코드로 계정 정보를 지정해야 합니다.

Azure.config.storage_account_name = "<your azure storage account>"
Azure.config.storage_access_key = "<your Azure storage access key>"

Azure 포털의 클래식 또는 Resource Manager 스토리지 계정에서 이러한 값을 가져오려면

  1. Azure Portal에 로그인합니다.
  2. 사용하려는 스토리지 계정으로 이동합니다.
  3. 오른쪽의 설정 블레이드에서 액세스 키를 클릭합니다.
  4. 나타나는 액세스 키 블레이드에 액세스 키 1 및 액세스 키 2가 표시됩니다. 이 둘 중 하나를 사용할 수 있습니다.
  5. 복사 아이콘을 클릭하여 키를 클립보드에 복사합니다.

방법: 큐 만들기

다음 코드는 Azure::QueueService 개체를 만들어 큐 작업을 수행할 수 있게 해 줍니다.

azure_queue_service = Azure::QueueService.new

create_queue() 메서드를 사용하여 지정된 이름이 있는 큐를 만듭니다.

begin
  azure_queue_service.create_queue("test-queue")
rescue
  puts $!
end

방법: 큐에 메시지 삽입

큐에 메시지를 삽입하려면 create_message() 메서드를 사용하여 새 메시지를 만들어 큐에 추가합니다.

azure_queue_service.create_message("test-queue", "test message")

방법: 다음 메시지 보기

큐에서 메시지를 제거하지 않고도 peek_messages() 메서드를 호출하여 큐의 앞에서 원하는 메시지를 볼 수 있습니다. 기본적으로 peek_messages()는 단일 메시지를 읽습니다. 보려는 메시지의 수를 지정할 수도 있습니다.

result = azure_queue_service.peek_messages("test-queue",
  {:number_of_messages => 10})

큐에서 다음 메시지를 제거하는 방법

2단계를 거쳐 큐에서 메시지를 제거할 수 있습니다.

  1. list_messages()를 호출하면 기본적으로 큐에서 다음 메시지를 가져옵니다. 가져오려는 메시지의 수를 지정할 수도 있습니다. list_messages()에서 반환된 메시지는 이 큐의 메시지를 읽는 다른 코드에는 표시되지 않습니다. 표시 제한 시간(초 단위)을 매개 변수로 전달합니다.
  2. 큐에서 메시지 제거를 완료하려면 delete_message()도 호출해야 합니다.

메시지를 제거하는 이 2단계 프로세스는 코드가 하드웨어 또는 소프트웨어 오류로 인해 메시지를 처리하지 못하는 경우 코드의 다른 인스턴스가 동일한 메시지를 가져와서 다시 시도할 수 있도록 보장합니다. 코드는 메시지가 처리된 직후에 delete_message()를 호출합니다.

messages = azure_queue_service.list_messages("test-queue", 30)
azure_queue_service.delete_message("test-queue",
  messages[0].id, messages[0].pop_receipt)

방법: 대기 중인 메시지의 콘텐츠 변경

큐에 있는 메시지의 콘텐츠를 변경할 수 있습니다. 다음 코드에서는 update_message() 메서드를 사용하여 메시지를 업데이트합니다. 이 메서드는 큐 메시지의 pop 수신 및 메시지가 큐에 표시되는 시간을 나타내는 UTC DateTime 값이 포함된 튜플을 반환합니다.

message = azure_queue_service.list_messages("test-queue", 30)
pop_receipt, time_next_visible = azure_queue_service.update_message(
  "test-queue", message.id, message.pop_receipt, "updated test message",
  30)

방법: 큐에서 메시지를 제거하는 추가 옵션

큐에서 메시지 검색을 사용자 지정할 수 있는 방법으로는 두 가지가 있습니다.

  1. 메시지의 배치를 가져올 수 있습니다.
  2. 표시하지 않는 제한 시간을 더 길거나 더 짧게 설정하여 코드에서 각 메시지를 완전히 처리하는 시간을 늘리거나 줄일 수 있습니다.

다음 코드 예제에서는 list_messages() 메서드를 사용하여 한 번의 호출로 15개의 메시지를 가져옵니다. 그런 다음 각 메시지를 인쇄하고 삭제합니다. 또한 각 메시지에 대해 표시하지 않는 제한 시간을 5분으로 설정합니다.

azure_queue_service.list_messages("test-queue", 300
  {:number_of_messages => 15}).each do |m|
  puts m.message_text
  azure_queue_service.delete_message("test-queue", m.id, m.pop_receipt)
end

방법: 큐 길이 가져오기

큐에 있는 메시지의 추정된 개수를 가져올 수 있습니다. get_queue_metadata() 메서드는 대략적인 메시지 수와 기타 큐 메타데이터를 반환합니다.

message_count, metadata = azure_queue_service.get_queue_metadata(
  "test-queue")

방법: 큐 삭제

큐와 큐에 포함된 모든 메시지를 삭제하려면 큐 개체의 delete_queue() 메서드를 호출합니다.

azure_queue_service.delete_queue("test-queue")

다음 단계

이제 Queue Storage의 기본 사항을 배웠으므로 다음 링크를 따라 좀 더 복잡한 스토리지 작업에 대해 알아보세요.

이 문서에서 설명하는 Azure Queue Storage와 Service Bus 큐를 사용하는 방법에서 설명하는 Azure Service Bus 큐 간의 비교는 Azure Queues 및 Service Bus 큐 - 비교 및 대조를 참조하세요.