Rate Limit

Este interceptor determina a quantidade máxima de chamadas permitidas em um certo intervalo de tempo (que pode ser um segundo, minuto, hora, dia ou mês), e pode ser inserido no fluxo da API ou do Plano.

No caso de uma API, o interceptor pode ser inserido a nível da API como um todo, de um recurso ou de uma operação. Em todos esses casos, a taxa será incrementada independentemente de quem fez a requisição, respeitando o intervalo configurado. Se adicionado ao fluxo de Plano, será incrementada a taxa específica de quem fez a requisição (app ou access token). Em ambos os casos, é possível adicionar um novo header com a quantidade de requisições restantes.

É fácil confundir o funcionamento do Rate Limit com outro interceptor que controla tráfego, o Spike Arrest. Por isso, incluímos uma definição mais detalhada de cada um, de suas diferenças e exemplos de configuração aqui.

Configuração

rate limit

O interceptor pode ser inserido apenas no fluxo de requisição (request). Para configurá-lo, temos que preencher algumas propriedades, como mostra a imagem acima.

  • Configuration type: Determina o tipo de configuração a ser usada pelo interceptor. Você pode optar por:

    • Total calls: Configura o interceptor pelo total de chamadas.

    • IP: Configura o interceptor pelas chamadas por IP, permitindo bloquear chamadas repetidas de um mesmo IP.

  • Calls: O número total de chamadas aceitas.

  • Interval: Determina o intervalo de tempo em que serão aceitas as chamadas, pode ser por segundo, minuto, hora, dia, semana ou mês.

  • Soft Limit: Permite configurar um percentual adicional de chamadas permitidas, marcando a opção e adicionando o valor no campo % à direita.

  • Return quota header: Se marcado, um parâmetro com a quantidade de requisições restantes será enviado com o header da resposta.

No exemplo da imagem, configuramos um limite de 300 chamadas por minuto, com 30% de excedente permitido. Ou seja, serão aceitas até 90 chamadas a mais.

Caso a opção Soft Limit seja marcada, o campo % passa a ser obrigatório. Caso contrário, o Rate Limit funcionará normalmente, tendo como base a quantidade de quota configurada no campo Calls.
Thanks for your feedback!
EDIT
How useful was this article to you?