Перейти до основного вмісту

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