Перейти к основному содержанию

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.

Обрабатывайте ошибки CometAPI, определяя, нужно ли исправить запрос или повторить его. Повторяйте 429, сбои класса timeout и временные серверные сбои с backoff; не повторяйте некорректные запросы или сбои аутентификации.

Повторяйте только допускающие повтор сбои

Статус или сигналПовторять?Действие
400НетИсправьте тело запроса или параметры.
401НетИсправьте API key и заголовок Authorization.
403Обычно нетУдалите неподдерживаемые поля и проверьте доступ к модели.
429ДаПовторите с экспоненциальным backoff и jitter.
500 with invalid_requestНетИсправьте форму запроса.
500, 503, 504, 524ДаПовторите с backoff и сохраните request ID.

Добавьте backoff

Следующий пример Python повторяет только сбои, допускающие повтор:
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.")
Успешный ответ включает вывод модели:
{
  "choices": [
    {
      "message": {
        "role": "assistant",
        "content": "Hello."
      }
    }
  ],
  "usage": {
    "total_tokens": 9
  }
}

Логируйте полезный контекст

Следующая JSON-структура безопасна для хранения после удаления пользовательских секретов и больших файлов:
{
  "method": "POST",
  "path": "/v1/chat/completions",
  "model": "your-model-id",
  "status": 429,
  "request_id": "request_id_from_error_message",
  "retryable": true
}

Распространённые ошибки

ОшибкаИсправление
Повтор 401Прекратите повторы и замените или заново загрузите API key.
Повтор недопустимого JSONПроверяйте тело запроса перед отправкой следующего запроса.
В логах нет request IDСохраняйте точное тело ошибки до того, как ваш SDK обернёт его.
Немедленный повтор после 429Добавьте jitter и уменьшите concurrency.

Связанные ссылки

Last modified on May 28, 2026