gateway.yaml, который шлюз читает при загрузке, см. Справочник по конфигурации.
Развертывание в производстве следует четырем этапам по порядку, и разделы ниже соответствуют им. Первые два — это места, где вы делаете выбор; вторые два — справочный материал, который следует консультировать после запуска.
- Настройка вашего поставщика идентификации: зарегистрируйте клиента OAuth и проверьте примечания для каждого IdP для Okta, Entra и Google
- Развертывание шлюза: создайте образ контейнера с закрепленной версией и запустите его на Kubernetes, Cloud Run или вашей собственной платформе. Этот раздел также охватывает решения по стоимости, обходу, нескольким шлюзам и бессерверным вычислениям
- Настройка операций: журналы, зонды здоровья, поведение при сбое, ротация секретов и обновления. Справочник для подключения мониторинга и runbooks
- Проверка позиции безопасности: какие данные куда передаются, модель угроз и ответы на вопросы соответствия. Справочник для проверки безопасности
Развертывайте в вашей частной сети. Claude Code подключается только к шлюзу, адрес которого является приватным. Это защита безопасности, потому что доверенный шлюз может отправлять параметры, которые запускают команды на машинах разработчиков. Поместите шлюз за внутренним балансировщиком нагрузки или VPN и дайте ему имя хоста, которое разрешается только на приватные IP-адреса.
Настройка поставщика удостоверений
Зарегистрируйте конфиденциальное веб-приложение OAuth/OpenID Connect (OIDC) с одним URI перенаправления,https://<gateway>/oauth/callback, и назначьте его пользователям или группам, которые должны иметь доступ к шлюзу.
Работает любой OIDC-совместимый IdP: Okta, Microsoft Entra ID, Google Workspace, Keycloak, Dex, PingFederate и другие. IdP должен соответствовать трем требованиям:
- Обслуживает
/.well-known/openid-configurationпо HTTPS в production; шлюз принимаетhttp://издателя, и издатель loopback дополнительно требуетCLAUDE_GATEWAY_ALLOW_LOOPBACK=1 - Поддерживает поток authorization-code. PKCE (Proof Key for Code Exchange) включен по умолчанию; отключите его с помощью
oidc.use_pkce: falseдля IdP, которые его не поддерживают - Возвращает
emailи опциональноgroupsв id_token или обслуживает их из конечной точки userinfo сoidc.userinfo_fallback: true
oidc.ca_cert_pem.
Несколько поставщиков обрабатывают утверждения email и group по-разному:
- Okta: сервер авторизации организации в
https://example.okta.comвозвращает тонкий id_token, который опускаетemailиgroups, поэтому установитеoidc.userinfo_fallback: trueвсякий раз, когда вы используете его какissuer. Пользовательский сервер авторизации, такой какhttps://example.okta.com/oauth2/default, который включаетemailи опциональноgroupsв id_token, выдает их напрямую и не требует fallback. Okta выдаетgroupsтолько когда областьgroupsзапрашивается вoidc.scopesи фильтр утверждения groups приложения это позволяет;userinfo_fallbackне может заполнить утверждение, которое IdP не был попрошен выдать. - Microsoft Entra ID:
issuer=https://login.microsoftonline.com/<tenant-id>/v2.0. Entra выдает Object ID групп, а не имена, поэтому используйте GUID вmanaged.policies.match.groupsили используйте App Roles для читаемых имен. Если ваш tenant выдает роли подrolesвместоgroups, установитеoidc.groups_claim: roles. - Google Workspace:
issuer=https://accounts.google.com. id_token Google не содержит groups. Чтобы использовать основанные на группахallowed_groupsилиmanaged.policiesс Google в качестве IdP, настройтеoidc.google_groups, которая ищет группы каждого пользователя через Admin SDK Directory API, используя сервисный аккаунт с делегированием на уровне домена. Без этого используйтеoidc.allowed_email_domainsдля проверки членства иmanaged.policies.match.email_domainдля назначения политики. Google также игнорирует стандартную областьoffline_access. Для refresh tokens установитеoidc.scopes: [openid, profile, email]иoidc.extra_auth_params: { access_type: offline, prompt: consent }.
Развертывание
Шлюз — это один бинарный файл Linux. Он масштабируется горизонтально, потому что реплики не имеют состояния, а Postgres — это общий уровень координации. Запустите его так же, как вы запускаете stateless сервисы в вашей среде. Остальная часть этого раздела указывает, что нужно образу, с краткими примечаниями для Kubernetes и Cloud Run. Шлюз предназначен для запуска внутри вашей сети, потому что он содержит ваши upstream учетные данные и действует как единственная точка выхода для inference. Он может работать везде, где ваши разработчики и ваш IdP могут достичь по HTTPS; рассматривайте его как любой другой сервис, содержащий production учетные данные. Несколько решений формируют развертывание помимо того, где оно работает:- Стоимость: нет отдельной лицензии или платы за место для шлюза; это часть бинарного файла
claude. Вы платите за inference через ваше существующее облачное или обязательство Anthropic, плюс вычисления для контейнера и вашего сборщика телеметрии. - Обход: шлюз не требует, чтобы единственный маршрут к модели проходил через него. Разработчик со своими собственными учетными данными все еще может вызвать поставщика напрямую, поэтому закрытие этого пути — это решение политики сети, например блокировка выхода на
api.anthropic.comкроме как от шлюза. Блокировка этого выхода также нарушает проверку безопасности домена WebFetch, которая вызываетapi.anthropic.comс каждой машины разработчика; установитеskipWebFetchPreflight: trueв управляемой политике, чтобы отключить это. - Несколько шлюзов: каждый шлюз — это отдельное развертывание со своей конфигурацией. CLI хранит отпечаток доверия и учетные данные для каждого имени хоста шлюза, поэтому разные команды могут подключаться к разным шлюзам без конфликтов. Чтобы обслуживать несколько издателей OIDC, запустите отдельные экземпляры.
- Бессерверная архитектура: Cloud Run работает; установите
min-instances: 1, чтобы избежать холодного обнаружения OIDC. Lambda и Cloud Functions не работают, потому что шлюз — это долгоживущий HTTP сервер.
listen.trusted_proxies на диапазоны источников прокси, чтобы шлюз читал IP клиентов из X-Forwarded-For. Шлюз соблюдает заголовок только когда TCP peer доверен; пример Google Cloud имеет конкретные значения для каждой топологии. Без доверенных прокси каждый запрос выглядит как исходящий с IP прокси, что сворачивает ограничения скорости для каждого IP в один общий bucket и записывает IP прокси в события аудита.
Образ контейнера
Создайте свой собственный образ вокруг нативного бинарного файлаclaude из стандартного выпуска Claude Code:
- Загрузите сборку Linux для архитектуры вашего образа из закрепленного выпуска; см. Установка конкретной версии для URL загрузки.
- Проверьте его против подписанного GPG
manifest.jsonвыпуска, как описано в Целостность бинарного файла и подпись кода. - Скопируйте его в контекст сборки.
- Образ на основе glibc: единственные динамические зависимости сборки glibc — это библиотеки glibc. Образы на основе Musl нуждаются в сборке
linux-x64-muslилиlinux-arm64-muslплюс дополнительные пакеты; см. Настройка Alpine Linux. - Записываемый каталог состояния: шлюз работает как любой пользователь, но минимальные образы не имеют записываемого home. Установите
CLAUDE_CONFIG_DIRна записываемый путь, такой как/tmp/.claude. - Команда контейнера:
claude gateway --config /etc/claude/gateway.yaml, с файлом конфигурации, смонтированным только для чтения, и секретами, предоставленными как переменные окружения; шлюз слушает наlisten.port, по умолчанию8080.
Kubernetes
Запустите шлюз как Deployment, как любой stateless сервис:- Смонтируйте конфигурацию из ConfigMap и секреты из Secret; ссылайтесь на секреты в YAML через
${file:/path/to/secret}или как переменные окружения - Завершите TLS на Ingress и установите
listen.public_urlна имя хоста Ingress - Укажите зонд готовности на
GET /readyzи зонд живучести наGET /healthz
Workload identityПредпочитайте workload identity платформы вместо статических ключей: IRSA на EKS для Bedrock, Workload Identity на GKE для Agent Platform и workload identity на AKS для Foundry. Установите
auth: {} в блоке upstream или use_azure_ad: true для Foundry, и шлюз подхватывает идентификацию pod через цепь учетных данных по умолчанию этого поставщика. Для кросс-облачного сопряжения, такого как upstream Bedrock на GKE, установите явные учетные данные в блоке auth upstream вместо этого. Справочник upstreams имеет детали настройки для каждой платформы.Cloud Run
Настройте сервис следующим образом:- Оставьте
listen.portна его значении по умолчанию8080, которое соответствуетPORTCloud Run по умолчанию, или установитеport: ${PORT} - Установите
public_urlна внешне доступное происхождение. Для production это обычно имя хоста внутреннего балансировщика нагрузки, потому что/loginотклоняет публичные адреса и URL*.run.appразрешается на один, поэтому URL Cloud Run один работает только дляcurlили дымового теста браузера. Исключение — сеть, где*.run.appразрешается приватно через Private Service Connect и приватную зону Cloud DNS; в этой топологии URL Cloud Run — это действительныйpublic_url. Пример Google Cloud охватывает оба. - Смонтируйте конфигурацию как том секрета
- Установите
min-instances: 1, чтобы избежать холодного обнаружения OIDC при первом запросе
Для полного примера на Google Cloud, охватывающего Cloud Run или GKE, Cloud SQL и Secret Manager, см. Развертывание на Google Cloud.
Отправьте URL шлюза на машины разработчиков
Как только шлюз начнет обслуживать, отправьтеforceLoginMethod и forceLoginGatewayUrl на каждую машину разработчика через управляемые параметры, через MDM или путем прямого написания файла managed-settings.json для каждой ОС. Без этого /login показывает стандартный выбор аккаунта без опции шлюза. См. Управляемые параметры на стороне клиента для путей файлов.
Операции
Как только шлюз начнет обслуживать трафик, ежедневная операция — это чтение его логов, проверка его здоровья и ротация его секретов по вашему расписанию. Подразделы охватывают каждое, плюс то, что содержит Postgres и как ведут себя обновления и откаты.Логи
Шлюз записывает два потока в stderr, оба JSON-дружественные:- События аудита: однострочный JSON для каждого события, связанного с безопасностью. Направьте stderr в ваш агрегатор логов. Выдаваемые события включают
config.load,session.mint,session.refresh,device.authorize,device.verify,auth.denied,access.denied,inference,managed.serve,spend.blockedиadmin.denied. Поля варьируются по событиям:- Успешные события mint и refresh содержат
sub,email,client_ipи результат - События отказа содержат причину, путь и IP клиента, так как идентификация не существует при отказе
inferenceзаписывает, какой upstream обслужил запрос и статус ответаadmin.deniedзаписывает отклоненную попытку аутентификации admin-API с причиной (invalid_keyилиno_credentials), IP клиента, методом и путем, без представленного материала ключа
- Успешные события mint и refresh содержат
- Операционные логи: читаемые для человека строки с префиксом
[gateway]для загрузки, предупреждений и ошибок upstream. Переменная окруженияCLAUDE_GATEWAY_LOG_LEVELуправляет многословностью и принимаетinfo,warnилиerror, сinfoпо умолчанию. Это не влияет на события аудита, которые всегда выдаются.
Здоровье
Шлюз обслуживаетGET /healthz как зонд живучести и GET /readyz как зонд готовности; /readyz проверяет доступность хранилища. Оба исключены из access_control.allow_cidrs, поэтому зонды продолжают работать на заблокированном слушателе.
Документ обнаружения OAuth в /.well-known/oauth-authorization-server также возвращает 200 только после загрузки конфигурации, обнаружения OIDC, построения клиента upstream и миграции Postgres, поэтому он также служит проверкой загрузки end-to-end.
Работающий шлюз также обслуживает описание путей и форм запросов, которые он принимает, в <public_url>/protocol, соответствующих версии, которую вы запускаете. Содержимое не стабильно между выпусками.
Поведение при сбое
Если Postgres выходит из строя, сам шлюз продолжает обслуживать вошедших разработчиков, а новые входы не удаются. Продолжают ли разработчики работать, зависит от того, как ваш оркестратор обрабатывает готовность:- Существующие сеансы: bearer tokens проверяются локально с помощью JWT secret, обновления сеанса не касаются хранилища, и процесс шлюза все еще может обслуживать inference
- Новые входы: не удаются до восстановления Postgres, потому что поток устройства и его счетчики ограничения скорости живут в Postgres
- Применение ограничения расходов: по умолчанию не удается открыто во время сбоя, поэтому inference все еще течет; переключите его на отказ закрыто, если вы предпочитаете блокировать, чем работать без учета
- Готовность:
/readyzсообщает о неготовности во время сбоя, поэтому оркестраторы, которые управляют трафиком на готовность, удаляют каждую реплику из ротации сразу. В этой топологии весь трафик, включая inference, который шлюз все еще может обслуживать, не удается на балансировщике нагрузки до восстановления Postgres. Зонд живучести на/healthzпродолжает проходить, поэтому реплики не перезапускаются. Укажите зонд готовности на/healthzвместо этого, если вы предпочитаете, чтобы вошедшие разработчики продолжали работать через сбой хранилища; стоимость в том, что новые входы не удаются против реплики, которая все еще сообщает о готовности.
ttl_hours, а новые входы и обновления не удаются. Установите более длительный ttl_hours, если ваш IdP имеет частые окна обслуживания.
Ротация JWT secret
Ротируйте подписывающий secret в три этапа, чтобы существующие сеансы оставались действительными:- Создайте новый secret. Добавьте его в начало массива
session.jwt_secret. - Разверните развертывание. Новые tokens подписываются новым secret; старые tokens все еще проверяются.
- После
ttl_hoursплюс запас, удалите старый secret и разверните снова.
ttl_hours.
Postgres
Шлюз содержит пять таблиц, все созданные его миграциями при загрузке:| Таблица | Содержимое | Хранение |
|---|---|---|
kv | Гранты устройства (10-минутный TTL) и счетчики ограничения скорости | TTL для каждой строки |
spend | Счетчики расходов за период для каждого principal, в центах | admin.spend_retention_months, по умолчанию 13 |
spend_limits | Настроенные лимиты расходов | До удаления через API |
admin_audit | Трассировка мутаций Admin API | admin.audit_retention_days, по умолчанию 365 |
principal_emails | Последний просмотренный email каждого principal, отображаемое имя и группы IdP. Содержит PII. | admin.identity_retention_days с момента последней активности, по умолчанию 90 |
kv прошедшие их TTL, и почасовая очистка применяет окна хранения на таблицы расходов, поэтому ничего не растет без ограничений. Без ограничений расходов настроенных, только kv записывается. Если ваша политика безопасности запрещает DDL из роли приложения, предварительно создайте эти таблицы и _migrations с ролью администратора и предоставьте роли приложения SELECT, INSERT, UPDATE, DELETE на каждой.
С ограничениями расходов в использовании, потерянная база данных означает потерю отслеживания расходов и лимитов, а не просто повторные входы разработчиков, поэтому запускайте регулярные резервные копии. Чтобы стереть одного ушедшего разработчика немедленно, а не ждать хранения, запустите DELETE FROM principal_emails WHERE principal = '<sub>' напрямую; это удаляет единственную таблицу, содержащую их email, имя и группы. Строки spend и admin_audit ссылаются только на псевдонимный OIDC sub.
Обновления
Реплики не имеют состояния, поэтому rolling restart безопасен в любое время. Шлюз запускает миграции схемы при загрузке, что означает, что развертывание нового бинарного файла автоматически мигрирует базу данных. Если роль базы данных не может запускать DDL, предварительно создайте схему, включая таблицу_migrations, инициализированную текущей версией; в противном случае загрузка не удается при попытке CREATE TABLE.
Миграции добавляются только, поэтому откат к предыдущему бинарному файлу, который знает меньше миграций, безопасен; он игнорирует дополнительные строки. Откат также переподтверждает YAML против схемы более старого бинарного файла, поэтому конфигурация, которая приняла ключ, введенный более новым выпуском, не удается при загрузке на более старом. Удалите новый ключ перед откатом.
Потому что вы закрепляете версию шлюза в своем собственном образе, исправления в новых выпусках Claude Code, включая исправления безопасности, достигают вашего развертывания только когда вы обновляете закрепление и переразворачиваете. Включите шлюз в тот же цикл патчей, который вы используете для других сервисов, содержащих production учетные данные.
Безопасность
Этот раздел отвечает на вопросы, которые задает проверка безопасности: какие данные проходят через шлюз и куда они идут, какие атаки защищает дизайн и какие ответы принадлежат в опроснике соответствия.Поток данных
| Данные | Путь | Отправлено Anthropic шлюзом |
|---|---|---|
| Inference (prompts, completions) | CLI → шлюз → ваш upstream | Только если API Anthropic — это настроенный upstream |
| Телеметрия (метрики OTLP, плюс опциональные логи и трассировки) | CLI → шлюз → ваш сборщик | Никогда |
| Идентификация (email, groups, sub) | IdP → шлюз → JWT → CLI; CLI штампует это на экспортах OTLP | Никогда |
| Управляемые параметры | Ваш YAML шлюза → CLI | Никогда |
| Журнал аудита | Stderr шлюза → ваш агрегатор | Никогда |
Краткое резюме модели угроз
Шлюз находится внутри периметра вашей сети, но отдельные ноутбуки разработчиков не рассматриваются как доверенные. Дизайн учитывает это тремя способами:- Разработчики держат краткосрочные JWT вместо сырых ключей upstream. Ветвь CLI-к-шлюзу использует грант устройства RFC 8628, и обмен авторизацией шлюза с IdP запускает PKCE в конфигурации по умолчанию, поэтому перехваченный код авторизации IdP бесполезен.
- Страница проверки устройства применяет same-origin POST и ограничение скорости для каждого IP согласно RFC 8628 §5.1. См. Сопротивление brute-force пользовательского кода.
- Исходящие запросы проходят через защиту от подделки запроса на стороне сервера (SSRF), которая разрешает DNS, блокирует link-local и адреса облачных метаданных плюс loopback по умолчанию и закрепляет соединение на разрешенный IP, поэтому управляемые оператором URL, такие как IdP и назначения OTLP, не могут быть перенаправлены на конечные точки облачных метаданных. Диапазоны приватных RFC 1918 намеренно разрешены, потому что IdP и сборщики OTLP обычно живут на приватных IP. Для локальной разработки против loopback IdP или сборщика установите
CLAUDE_GATEWAY_ALLOW_LOOPBACK=1в окружении шлюза; оставьте его неустановленным в production.
- Скомпрометированный хост шлюза: хост как содержит upstream учетные данные, так и распределяет управляемые параметры каждому подключенному разработчику, поэтому контроль над конфигурацией шлюза сравним с контролем над вашим MDM. Диалог одобрения CLI для параметров, способных к shell, ограничивает молчаливые изменения, но не заменяет безопасность хоста.
- Вредоносный поставщик OIDC: поставщик подписывает id_tokens, которым шлюз доверяет, поэтому он может утверждать любую идентификацию. Проверка и защита вашего IdP — это ваша ответственность.
Сопротивление brute-force пользовательского кода
user_code, который разработчик вводит на странице проверки /device, — это 8 символов, взятых из алфавита из 20 символов, что дает 20⁸ или около 2,56×10¹⁰ комбинаций, и он истекает через 10 минут.
Шлюз применяет ограничения скорости для каждого IP на конечных точках грантов устройства, настраиваемые через rate_limits. Поднимите лимиты, если много разработчиков входят с одного общего корпоративного NAT адреса. Лимиты применяются только к потоку входа, а не к inference.
Позиция соответствия
- Резидентность данных: собственная плоскость данных шлюза не отправляет ничего Anthropic, если только API Anthropic не является настроенным upstream; когда это так, ваше существующее соглашение об обработке данных применяется к пути inference. Телеметрия, аудит, идентификация и параметры идут только к назначениям, которые вы настраиваете.
- Трафик хост-процесса: хост-процесс — это CLI Claude Code, который может отправлять аналитику запуска и проверки обновлений Anthropic. Для развертываний со строгим выходом установите
CLAUDE_CODE_DISABLE_NONESSENTIAL_TRAFFIC=1в окружении контейнера шлюза. - Аналитика клиента: CLI отключает свою собственную аналитику использования при входе в шлюз, и отчеты об ошибках отключены по умолчанию на поверхностях API третьих сторон.
- Машины клиентов: CLI разработчиков все еще отправляют проверки имени хоста WebFetch и проверки версии Anthropic, если не установлены
CLAUDE_CODE_DISABLE_NONESSENTIAL_TRAFFIC=1иskipWebFetchPreflight: true. См. использование данных. - Рейтинги опроса: учетные данные шлюза отключают приемник рейтингов, привязанный к Anthropic, поэтому рейтинги не отправляются Anthropic.
- Обмен транскриптом: выбор Yes на подсказке обмена транскриптом опроса записывает локальный файл в
~/.claude/feedback-bundles/вместо загрузки Anthropic. - Обновления клиента: проверки обновлений отделены от трафика шлюза. Закрепите версии через вашу собственную дистрибуцию и установите
DISABLE_UPDATES, если ноутбуки не должны получать выпуски.DISABLE_AUTOUPDATERостанавливает только фоновые обновления, в то время какclaude updateвсе еще работает. - TLS: обслуживайте
public_urlпо HTTPS в production, либо из собственного слушателя шлюза черезlisten.tls, либо из TLS-завершающего ingress перед простыми HTTP репликами с установленнымlisten.public_url. Шлюз не отказывает простой HTTP. IdP должен обслуживать HTTPS в production, и Postgres поддерживает?sslmode=require. УстановитеStrict-Transport-Securityна вашем ingress. - Раскрытие уязвимостей: следуйте Отчету о проблемах безопасности
Устранение неполадок
Для вопросов и обратной связи используйте поддержку Claude Code или откройте issue в репозитории Claude Code на GitHub. При сообщении о проблеме включите:- Проблема шлюза: stderr шлюза для соответствующего окна, ваш
gateway.yamlс редактированными секретами, версию шлюза, показанную на целевой странице в/и в заголовке ответаx-cc-gateway-versionна/managed/settings, и что недавно изменилось - Проблема входа: разработчик запускает
claude --debug-file ./claude-debug.txt, воспроизводит и отправляет этот файл плюс журнал аудита шлюза для того же окна - Проблема inference: запрошенная модель, настроенные upstreams и журнал аудита шлюза для запроса, который записывает, какой upstream обслужил его и статус ответа
| Симптом | Причина | Исправление |
|---|---|---|
/login разработчика показывает стандартный выбор аккаунта вместо экрана Cloud gateway | forceLoginMethod или forceLoginGatewayUrl не установлены в управляемых параметрах на этой машине | Разверните файл управляемых параметров на устройство; /login читает URL шлюза оттуда |
Запуск показывает Gateway login is configured in managed settings, but this Claude Code build does not include Cloud gateway support. | Установленная сборка Claude Code предшествует поддержке шлюза | Попросите разработчика обновить Claude Code до выпуска, который включает поддержку Cloud gateway |
CLI /login: Gateway hosts must be on your organization's private network; <host> resolves to the public (or unrecognized) address <ip> | Имя хоста шлюза разрешается на по крайней мере один публичный IP адрес. Claude Code проверяет каждый разрешенный адрес и требует, чтобы каждый был приватным. Частая причина — dual-stack имя, где одно семейство разрешается на публичный адрес, включая AWS внутренние dual-stack балансировщики нагрузки, которые возвращают публичные AAAA адреса | Попросите имя шлюза разрешаться только на приватные адреса на машинах разработчиков. Для dual-stack имени удалите публичный диапазон записи или обслуживайте отдельное внутреннее DNS имя. См. предпосылку приватной сети. |
CLI /login: Gateway login requires a direct connection and does not support connecting through an HTTP proxy | HTTPS_PROXY или HTTP_PROXY применяется к хосту шлюза и имя хоста прокси разрешается на публичный адрес. Прокси, чье имя хоста разрешается только на приватные адреса, разрешен и не вызывает эту ошибку | Добавьте хост шлюза в NO_PROXY на машине разработчика, чтобы соединение было прямым, или используйте прокси, чье имя хоста разрешается на приватные адреса |
CLI /login: Could not resolve gateway host <host> | Машина не может разрешить внутреннее DNS имя шлюза, обычно потому что она не в корпоративной сети | Попросите разработчика подключиться к вашей сети или VPN, затем повторите попытку /login |
Загрузка выходит с ошибкой валидации конфигурации, называющей store.postgres_url | Postgres не настроен; шлюз требует Postgres | Установите store.postgres_url. Для локальной разработки используйте одноразовый контейнер: docker run --rm -p 5432:5432 -e POSTGRES_HOST_AUTH_METHOD=trust postgres. |
Загрузка выходит: requires the native binary | Запуск под Node вместо нативного бинарного файла | Установите Claude Code с одним из методов автономной установки |
Загрузка выходит с ошибкой обнаружения OIDC после config.load | oidc.issuer недоступен или цепь TLS не доверена | Проверьте, что издатель доступен из pod и обслуживает /.well-known/openid-configuration. Установите ca_cert_pem для приватной PKI. |
| Загрузка выходит с ошибкой разрешения Postgres | Роль приложения не имеет CREATE TABLE | Предварительно создайте схему с ролью администратора и предоставьте DML роли приложения или временно предоставьте DDL для загрузок, которые применяют новые миграции |
/oauth/callback показывает “Sign-in could not be completed” | Домен email отклонен, валидация id_token не удалась или email_verified явно false, что шлюз всегда отклоняет без переопределения | Проверьте allowed_email_domains и что IdP возвращает проверенное утверждение email. Для email_verified: false исправьте проверку на стороне IdP. Если ваш IdP выдает email под другим именем утверждения, установите oidc.email_claim. |
Лог: token exchange failed: id_token missing email claim | IdP не включает email в id_token по умолчанию. Это отклонение срабатывает только когда установлен allowed_email_domains; без него отсутствующий email создает сеанс без email | Настройте IdP для выдачи email в id_token. Okta: добавьте email к утверждениям ID-token пользовательского сервера авторизации. Entra: добавьте email как опциональное утверждение на регистрацию приложения. PingFederate: включите политику OpenID Connect, которая выдает email. Если IdP обслуживает email из конечной точки userinfo, но не будет включать его в id_token, такой как сервер авторизации организации Okta, установите oidc.userinfo_fallback: true. |
Каждый запрос Bedrock возвращает 502; лог показывает Could not load credentials from any providers | На EC2 hop limit IMDSv2 по умолчанию 1 блокирует запрос метаданных экземпляра изнутри контейнера. Загрузка и /readyz проходят в любом случае, потому что AWS SDK разрешает учетные данные экземпляра при первом запросе, а не при построении клиента | Поднимите hop limit с aws ec2 modify-instance-metadata-options --instance-id <id> --http-put-response-hop-limit 2 или установите его в шаблоне запуска. Изменение применяется к каждому контейнеру на экземпляре. Предпочитайте роли задач ECS, где доступны, которые читают учетные данные из конечной точки учетных данных контейнера ECS и избегают изменения полностью, или применяйте изменение на выделенном экземпляре шлюза, чтобы ограничить воздействие. |
| Ошибка IdP: unknown or unsupported scope | IdP отклоняет области, которые он не распознает | Установите oidc.scopes на точный список, который принимает ваш IdP; он должен включать openid. По умолчанию openid profile email offline_access. |
Сеансы не молчаливо обновляются после установки oidc.scopes | offline_access был удален из переопределения | Добавьте offline_access обратно, если ваш IdP его поддерживает. Без refresh token разработчики повторно запускают вход в браузер каждые session.ttl_hours. |
| Браузер показывает “This request came from another site and was blocked” | Cross-site form POST, заблокирован как защита CSRF. Ожидается для встроенных или проксированных страниц | Откройте ссылку проверки напрямую |
| Chrome блокирует кнопку Approve с “Refused to send form data … violates … Content Security Policy directive: form-action”, но та же страница работает в Safari или Firefox | Chrome применяет form-action ко всей цепи перенаправления. Ваш IdP перенаправляет дальше на второй хост, который не в списке разрешений. | Добавьте каждое дополнительное происхождение в цепи перенаправления в oidc.form_action_origins. Откройте Chrome DevTools → Console на странице Approve, чтобы увидеть, какое происхождение было заблокировано. |
| Вход завершается в IdP, но callback не удается, с ошибкой CSP в Chrome или “this sign-in link has expired” в Safari | IdP вернул код через response_mode=form_post, который автоматически отправляет его cross-origin через POST на /oauth/callback. Chrome блокирует это под строгой CSP; Safari позволяет отправку, но callback читает только строку запроса. | Убедитесь, что ваш IdP соблюдает response_mode=query, который шлюз явно запрашивает, чтобы callback был простым перенаправлением |
| Вход работает локально, но не удается за ALB | public_url не установлен, поэтому IdP получает внутреннее происхождение http:// как redirect_uri | Установите listen.public_url на внешнее происхождение https:// |
| Разработчик видит подсказку доверия повторно | Сертификат TLS ротируется для каждой реплики или для каждого запроса | Используйте стабильный сертификат на ingress или завершите TLS один раз и запустите реплики по простому HTTP внутри |
CLI /login: “Could not verify the gateway’s TLS certificate” или SELF_SIGNED_CERT_IN_CHAIN | Цепь TLS шлюза подписана приватным CA, не в хранилище доверия хоста CLI | Claude Code читает хранилище доверия ОС по умолчанию на нативном бинарном файле и на Node 22.15 или позже; CLAUDE_CODE_CERT_STORE управляет этим поведением. Если CA установлен в хранилище доверия ОС, убедитесь, что разработчики используют текущий runtime. В противном случае установите NODE_EXTRA_CA_CERTS на сертификат CA PEM перед запуском. Подсказка отпечатка первого подключения все еще применяется. |
Связанное
- Обзор шлюза Claude apps: быстрый старт и подключение разработчика
- Справочник по конфигурации: каждый параметр файла
gateway.yaml