Постмортем: Ошибки биллинга Claude Max + OpenClaw из-за устаревшего OAuth и изолированных задач cron

Самостоятельно размещенный OpenClaw с Claude Max начал возвращать ошибку billing error — API key has run out of credits, несмотря на то, что квота была далеко не исчерпана. Два дня отладки выявили две первопричины и цепочку, из-за которой отказ выглядит случайным.
Причина 1: Устаревший OAuth-токен портит весь провайдер
В файле auth-profiles.json было две записи: валидный OAuth-профиль anthropic:claude-cli и профиль anthropic:manual с токеном sk-ant-oat01-.... Когда ручной токен истек, OpenClaw не просто отклонил этот профиль — он классифицировал это как ошибку биллинга на уровне провайдера и занес в черный список весь провайдер anthropic, пропуская все модели, включая здоровый OAuth-профиль. Логи показали:
reason: "billing" errorPreview: "Provider anthropic has billing issue (skipping all models)" chain_exhausted
Здоровый OAuth-профиль с валидным токеном обновления никогда не использовался.
Исправление: Полностью удалить anthropic:manual из auth-profiles.json и openclaw.json. Оставить только anthropic:claude-cli.
Причина 2: Изолированные задачи cron попадают в отдельный биллинговый пул
OpenClaw имеет два пути выполнения:
- Основные сеансы — запускают бинарник
/usr/bin/claude, тарифицируются по подписке Max/Pro ✅ - Изолированные/встроенные запуски — прямой HTTP-запрос к Anthropic API, тарифицируются из пула Extra Usage ❌
Задачи cron с sessionTarget: isolated запускают автономный встроенный агент, который обращается к Anthropic API напрямую через HTTP — без заголовков Claude Code, которые отправляет CLI. Anthropic направляет такой запрос в пул Extra Usage, совершенно отдельную квоту. Если Extra Usage выключен, каждый изолированный запуск cron возвращает 400. OpenClaw усугубляет ситуацию: одна ошибка биллинга устанавливает disabledUntil на ~24 часа вперед в файле auth-state.json, блокируя все запросы — включая обычный чат — до истечения таймера. Блокировка переживает перезапуск шлюза.
Полная цепочка отказа
- Перезапуск шлюза → пропущенные задачи cron становятся в очередь на догонку
- Изолированный агент запускается через встроенный раннер → прямой HTTP-запрос к Anthropic API (без заголовков CLI)
- Пул Extra Usage → ошибка 400
- OpenClaw блокирует профиль аутентификации на ~24ч → все запросы заблокированы, включая обычный чат
Исправления
- Немедленная очистка блокировки биллинга:
python3 -c " import json with open('/home/USER/.openclaw/agents/main/agent/auth-state.json') as f: d = json.load(f) if 'usageStats' in d: for profile in d['usageStats']: d['usageStats'][profile].pop('disabledUntil', None) d['usageStats'][profile].pop('failureCounts', None) d['usageStats'][profile].pop('errorCount', None) d['usageStats'][profile].pop('disabledReason', None) d['usageStats'][profile].pop('lastFailureAt', None) with open('/home/USER/.openclaw/agents/main/agent/auth-state.json', 'w') as f: json.dump(d, f, indent=2) print('Cleared.') " openclaw gateway restart - Перенос всех задач cron из
isolatedвmain:python3 -c " import json with open('/home/USER/.openclaw/cron/jobs.json') as f: d = json.load(f) jobs = d if isinstance(d, list) else d.get('jobs', []) for j in jobs: if j.get('sessionTarget') == 'isolated': print(f'Fixing: {j["name"]}') j['sessionTarget'] = 'main' with open('/home/USER/.openclaw/cron/jobs.json', 'w') as f: json.dump(d, f, indent=2) print('Done.') "
Для кого это: Для всех, кто самостоятельно размещает OpenClaw с Claude Max или Pro и видит случайные ошибки биллинга, несмотря на то, что квота не исчерпана.
📖 Read the full source: r/openclaw
👀 Смотрите также

Установка OpenClaw на MacBook Pro с использованием локального Homebrew и NVM
Пользователь успешно установил OpenClaw на MacBook Pro, используя локальную учётную запись без прав администратора с локальным Homebrew, NVM v0.40.4, Python 3.14.3 через pyenv, Node 24 и LLM Qwen3.5-122B-A10B-MLX-vision-4.7-bit через oMLX.

4-файловая система памяти для агентов OpenClaw без плагинов
Пользователь Reddit делится практической системой памяти, использующей четыре файла в формате markdown: USER.md для идентификации, CONTEXT.md для текущей работы, MEMORY.md для структурированных тем и ARCHIVE.md для завершённых задач. Этот подход решает проблему «агент не знает, что он знает» через улучшенную архитектуру файлов, а не за счёт увеличения памяти.

Trellis 2 успешно работает на ROCm 7.11 с видеокартой AMD RX 9070 XT.
Разработчик запустил Trellis 2 на Linux Mint 22.3 с видеокартой AMD RX 9070 XT, используя ROCm 7.11, устранив две ключевые проблемы: нестабильность ROCm с тензорами высокого порядка N и неисправную функцию hipMemcpy2D в CuMesh.
