Saltar para o conteúdo principal

Documentation Index

Fetch the complete documentation index at: https://apidoc.cometapi.com/llms.txt

Use this file to discover all available pages before exploring further.

Trate erros da CometAPI decidindo se a requisição deve ser corrigida ou repetida. Faça retry em 429, falhas da classe timeout e falhas temporárias do servidor com backoff; não faça retry em requisições malformadas nem em falhas de autenticação.

Faça retry apenas em falhas que permitem retry

Status ou sinalTentar novamente?Ação
400NãoCorrija o corpo da requisição ou os parâmetros.
401NãoCorrija a chave de API e o cabeçalho Authorization.
403Geralmente nãoRemova campos não suportados e verifique o acesso ao modelo.
429SimFaça retry com exponential backoff e jitter.
500 com invalid_requestNãoCorrija a estrutura da requisição.
500, 503, 504, 524SimFaça retry com backoff e mantenha o request ID.

Adicione backoff

O exemplo em Python a seguir faz retry apenas em falhas que permitem retry:
import os
import random
import time
from openai import APIError, OpenAI, RateLimitError

client = OpenAI(
    api_key=os.environ["COMETAPI_KEY"],
    base_url="https://api.cometapi.com/v1",
)

for attempt in range(5):
    try:
        response = client.chat.completions.create(
            model="your-model-id",
            messages=[{"role": "user", "content": "Say hello."}],
        )
        print(response.choices[0].message.content)
        break
    except RateLimitError:
        delay = min(30, 2**attempt) + random.random()
        time.sleep(delay)
    except APIError as error:
        status_code = getattr(error, "status_code", None)
        if status_code in {500, 503, 504, 524}:
            delay = min(30, 2**attempt) + random.random()
            time.sleep(delay)
            continue
        raise
else:
    raise RuntimeError("The request failed after retries.")
A resposta bem-sucedida inclui a saída do modelo:
{
  "choices": [
    {
      "message": {
        "role": "assistant",
        "content": "Hello."
      }
    }
  ],
  "usage": {
    "total_tokens": 9
  }
}

Registre contexto útil

O formato JSON a seguir é seguro para armazenar depois que você remover segredos do usuário e arquivos grandes:
{
  "method": "POST",
  "path": "/v1/chat/completions",
  "model": "your-model-id",
  "status": 429,
  "request_id": "request_id_from_error_message",
  "retryable": true
}

Erros comuns

ErroCorreção
Fazer retry em 401Interrompa os retries e rotacione ou recarregue a chave de API.
Fazer retry em JSON inválidoValide o corpo da requisição antes de enviar outra requisição.
Sem request ID nos logsCapture o corpo exato do erro antes que seu SDK o encapsule.
Retry imediato após 429Adicione jitter e reduza a concorrência.
Last modified on May 28, 2026