Habilitar a sondagem longa para filas de mensagens do Amazon SQS - AWS SDK para C++

As traduções são geradas por tradução automática. Em caso de conflito entre o conteúdo da tradução e da versão original em inglês, a versão em inglês prevalecerá.

Habilitar a sondagem longa para filas de mensagens do Amazon SQS

Por padrão, o Amazon SQS; usa sondagem curta, consultando somente um subconjunto dos servidores, com base em uma distribuição aleatória ponderada, para determinar se há alguma mensagem disponível para inclusão na resposta.

A sondagem longa ajuda a reduzir seu custo de uso do Amazon SQS, reduzindo o número de respostas vazias quando não há mensagens disponíveis para retornar em resposta a ReceiveMessage uma solicitação enviada para uma fila do Amazon SQS e eliminando respostas falsas vazias. Você pode definir uma frequência de sondagem longa de 1 a 20 segundos.

Pré-requisitos

Antes de começar, recomendamos que você leia Getting started using the AWS SDK para C++.

Baixe o exemplo código de código e crie a solução conforme descrito em Conceitos básicos dos exemplos de código.

Para executar os exemplos, o perfil de usuário que seu código usa para fazer as solicitações deve ter as permissões adequadas AWS (para o serviço e a ação). Para obter mais informações, consulte Fornecimento de AWS credenciais.

Habilitar a sondagem longa ao criar uma fila

Para permitir uma sondagem longa ao criar uma fila do Amazon SQS, defina ReceiveMessageWaitTimeSeconds o atributo no objeto antes de chamar CreateQueueRequesta função de membro SQSClient da CreateQueue classe.

Inclui

#include <aws/core/Aws.h> #include <aws/sqs/SQSClient.h> #include <aws/sqs/model/CreateQueueRequest.h> #include <iostream>

Código

Aws::SQS::SQSClient sqsClient(clientConfiguration); Aws::SQS::Model::CreateQueueRequest request; request.SetQueueName(queueName); request.AddAttributes( Aws::SQS::Model::QueueAttributeName::ReceiveMessageWaitTimeSeconds, pollTimeSeconds); const Aws::SQS::Model::CreateQueueOutcome outcome = sqsClient.CreateQueue(request); if (outcome.IsSuccess()) { std::cout << "Successfully created queue " << queueName << std::endl; } else { std::cout << "Error creating queue " << queueName << ": " << outcome.GetError().GetMessage() << std::endl; }

Consulte o exemplo completo.

Habilitar a sondagem longa em uma fila existente

Além de ativar a sondagem longa ao criar uma fila, você também pode ativá-la em uma fila existente ReceiveMessageWaitTimeSeconds configurando a função de membro da SQSClient classe SetQueueAttributesRequestSetQueueAttributesantes de chamar.

Inclui

#include <aws/core/Aws.h> #include <aws/sqs/SQSClient.h> #include <aws/sqs/model/SetQueueAttributesRequest.h> #include <iostream>

Código

Aws::SQS::SQSClient sqsClient(clientConfiguration); Aws::SQS::Model::SetQueueAttributesRequest request; request.SetQueueUrl(queueURL); request.AddAttributes( Aws::SQS::Model::QueueAttributeName::ReceiveMessageWaitTimeSeconds, pollTimeSeconds); const Aws::SQS::Model::SetQueueAttributesOutcome outcome = sqsClient.SetQueueAttributes( request); if (outcome.IsSuccess()) { std::cout << "Successfully updated long polling time for queue " << queueURL << " to " << pollTimeSeconds << std::endl; } else { std::cout << "Error updating long polling time for queue " << queueURL << ": " << outcome.GetError().GetMessage() << std::endl; }

Consulte o exemplo completo.

Habilitar sondagem longa no recebimento da mensagem

Você pode ativar a sondagem longa ao receber uma mensagem definindo o tempo de espera em segundos no ReceiveMessageRequestque você fornece para a função de ReceiveMessage membro da SQSClient classe.

nota

Você deve se certificar de que o tempo limite da solicitação do AWS cliente seja maior que o tempo máximo de pesquisa longa (20s) para que suas ReceiveMessage solicitações não se esgotem enquanto aguarda o próximo evento de enquete!

Inclui

#include <aws/core/Aws.h> #include <aws/sqs/SQSClient.h> #include <aws/sqs/model/ReceiveMessageRequest.h>

Código

Aws::SQS::SQSClient sqsClient(customConfiguration); Aws::SQS::Model::ReceiveMessageRequest request; request.SetQueueUrl(queueUrl); request.SetMaxNumberOfMessages(1); request.SetWaitTimeSeconds(waitTimeSeconds); auto outcome = sqsClient.ReceiveMessage(request); if (outcome.IsSuccess()) { const auto &messages = outcome.GetResult().GetMessages(); if (messages.empty()) { std::cout << "No messages received from queue " << queueUrl << std::endl; } else { const auto &message = messages[0]; std::cout << "Received message:" << std::endl; std::cout << " MessageId: " << message.GetMessageId() << std::endl; std::cout << " ReceiptHandle: " << message.GetReceiptHandle() << std::endl; std::cout << " Body: " << message.GetBody() << std::endl << std::endl; } } else { std::cout << "Error receiving message from queue " << queueUrl << ": " << outcome.GetError().GetMessage() << std::endl; }

Consulte o exemplo completo.

Mais informações