Перейти к основному содержанию
На этой странице рассматривается операционная сторона запуска шлюза Claude apps: регистрация клиента OAuth в вашем поставщике идентификации (IdP), развертывание шлюза как контейнера и его ежедневное управление. Для каждого параметра в файле gateway.yaml, который шлюз читает при загрузке, см. Справочник по конфигурации. Развертывание в производстве следует четырем этапам по порядку, и разделы ниже соответствуют им. Первые два — это места, где вы делаете выбор; вторые два — справочный материал, который следует консультировать после запуска.
  1. Настройка вашего поставщика идентификации: зарегистрируйте клиента OAuth и проверьте примечания для каждого IdP для Okta, Entra и Google
  2. Развертывание шлюза: создайте образ контейнера с закрепленной версией и запустите его на Kubernetes, Cloud Run или вашей собственной платформе. Этот раздел также охватывает решения по стоимости, обходу, нескольким шлюзам и бессерверным вычислениям
  3. Настройка операций: журналы, зонды здоровья, поведение при сбое, ротация секретов и обновления. Справочник для подключения мониторинга и runbooks
  4. Проверка позиции безопасности: какие данные куда передаются, модель угроз и ответы на вопросы соответствия. Справочник для проверки безопасности
Если вход или загрузка не удаются, перейдите прямо к Устранению неполадок, который организован по ошибкам, которые вы видите.
Развертывайте в вашей частной сети. 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
Для приватной PKI установите 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 }.
Для поддержки с поставщиком удостоверений, не описанным выше, см. Troubleshooting.
Refresh tokens позволяют шлюзу молча обновлять сеанс разработчика без отправки разработчика в браузер. Они также управляют deprovisioningом, потому что когда IdP отключает пользователя, следующее обновление не удается и сеанс заканчивается в течение ttl_hours. Шлюз запрашивает offline_access по умолчанию, чтобы получить refresh token. Если ваш IdP требует явного согласия для offline access, настройте клиент OAuth, чтобы это позволить.Если ваш IdP вообще не может выдавать refresh tokens, шлюз все еще работает, но нет молчаливого обновления, поэтому разработчики повторно запускают вход в браузер, когда их сеанс истекает. Чтобы это не происходило каждый час, поднимите session.ttl_hours на 8 или 12. Компромисс — это задержка deprovisioningа, потому что без refresh tokens отключенный пользователь сохраняет доступ до истечения более длительного TTL.

Развертывание

Шлюз — это один бинарный файл 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 сервер.
Каждая production топология здесь помещает прокси L7, такой как Ingress, фронтенд Cloud Run или ALB, перед простыми HTTP репликами. Установите listen.trusted_proxies на диапазоны источников прокси, чтобы шлюз читал IP клиентов из X-Forwarded-For. Шлюз соблюдает заголовок только когда TCP peer доверен; пример Google Cloud имеет конкретные значения для каждой топологии. Без доверенных прокси каждый запрос выглядит как исходящий с IP прокси, что сворачивает ограничения скорости для каждого IP в один общий bucket и записывает IP прокси в события аудита.

Образ контейнера

Создайте свой собственный образ вокруг нативного бинарного файла claude из стандартного выпуска Claude Code:
  1. Загрузите сборку Linux для архитектуры вашего образа из закрепленного выпуска; см. Установка конкретной версии для URL загрузки.
  2. Проверьте его против подписанного GPG manifest.json выпуска, как описано в Целостность бинарного файла и подпись кода.
  3. Скопируйте его в контекст сборки.
Зеркалируйте выпуск в ваш внутренний реестр, если ваши сборки не могут достичь хоста выпуска, и закрепите версию, которую запускает ваш флот. Помимо бинарного файла, образу нужны:
  • Образ на основе 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, которое соответствует PORT Cloud 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 клиента, методом и путем, без представленного материала ключа
  • Операционные логи: читаемые для человека строки с префиксом [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 вместо этого, если вы предпочитаете, чтобы вошедшие разработчики продолжали работать через сбой хранилища; стоимость в том, что новые входы не удаются против реплики, которая все еще сообщает о готовности.
Если ваш IdP выходит из строя, существующие сеансы работают до ttl_hours, а новые входы и обновления не удаются. Установите более длительный ttl_hours, если ваш IdP имеет частые окна обслуживания.

Ротация JWT secret

Ротируйте подписывающий secret в три этапа, чтобы существующие сеансы оставались действительными:
  1. Создайте новый secret. Добавьте его в начало массива session.jwt_secret.
  2. Разверните развертывание. Новые tokens подписываются новым secret; старые tokens все еще проверяются.
  3. После ttl_hours плюс запас, удалите старый secret и разверните снова.
Ротация также является единственным способом вынудить сеансы выйти до истечения: bearer tokens проверяются локально против JWT secret, поэтому нет отзыва для каждого сеанса. Замена secret полностью, без сохранения старого в массиве, делает недействительным каждый выдающийся сеанс сразу. Для индивидуального offboarding deprovision пользователя в вашем IdP; их сеанс заканчивается в течение ttl_hours.

Postgres

Шлюз содержит пять таблиц, все созданные его миграциями при загрузке:
ТаблицаСодержимоеХранение
kvГранты устройства (10-минутный TTL) и счетчики ограничения скоростиTTL для каждой строки
spendСчетчики расходов за период для каждого principal, в центахadmin.spend_retention_months, по умолчанию 13
spend_limitsНастроенные лимиты расходовДо удаления через API
admin_auditТрассировка мутаций Admin APIadmin.audit_retention_days, по умолчанию 365
principal_emailsПоследний просмотренный email каждого principal, отображаемое имя и группы IdP. Содержит PII.admin.identity_retention_days с момента последней активности, по умолчанию 90
Цикл на 30 секунд истекает строки 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.
Если вы добавляете свои собственные элементы управления выходом, шлюз должен достичь сервера метаданных всякий раз, когда он использует учетные данные метаданных экземпляра, такие как workload identity. Две угрозы выходят за рамки, потому что это ваша инфраструктура для защиты:
  • Скомпрометированный хост шлюза: хост как содержит 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 gatewayforceLoginMethod или 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 proxyHTTPS_PROXY или HTTP_PROXY применяется к хосту шлюза и имя хоста прокси разрешается на публичный адрес. Прокси, чье имя хоста разрешается только на приватные адреса, разрешен и не вызывает эту ошибкуДобавьте хост шлюза в NO_PROXY на машине разработчика, чтобы соединение было прямым, или используйте прокси, чье имя хоста разрешается на приватные адреса
CLI /login: Could not resolve gateway host <host>Машина не может разрешить внутреннее DNS имя шлюза, обычно потому что она не в корпоративной сетиПопросите разработчика подключиться к вашей сети или VPN, затем повторите попытку /login
Загрузка выходит с ошибкой валидации конфигурации, называющей store.postgres_urlPostgres не настроен; шлюз требует 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.loadoidc.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 claimIdP не включает 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 scopeIdP отклоняет области, которые он не распознаетУстановите oidc.scopes на точный список, который принимает ваш IdP; он должен включать openid. По умолчанию openid profile email offline_access.
Сеансы не молчаливо обновляются после установки oidc.scopesoffline_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 или FirefoxChrome применяет form-action ко всей цепи перенаправления. Ваш IdP перенаправляет дальше на второй хост, который не в списке разрешений.Добавьте каждое дополнительное происхождение в цепи перенаправления в oidc.form_action_origins. Откройте Chrome DevTools → Console на странице Approve, чтобы увидеть, какое происхождение было заблокировано.
Вход завершается в IdP, но callback не удается, с ошибкой CSP в Chrome или “this sign-in link has expired” в SafariIdP вернул код через response_mode=form_post, который автоматически отправляет его cross-origin через POST на /oauth/callback. Chrome блокирует это под строгой CSP; Safari позволяет отправку, но callback читает только строку запроса.Убедитесь, что ваш IdP соблюдает response_mode=query, который шлюз явно запрашивает, чтобы callback был простым перенаправлением
Вход работает локально, но не удается за ALBpublic_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, не в хранилище доверия хоста CLIClaude Code читает хранилище доверия ОС по умолчанию на нативном бинарном файле и на Node 22.15 или позже; CLAUDE_CODE_CERT_STORE управляет этим поведением. Если CA установлен в хранилище доверия ОС, убедитесь, что разработчики используют текущий runtime. В противном случае установите NODE_EXTRA_CA_CERTS на сертификат CA PEM перед запуском. Подсказка отпечатка первого подключения все еще применяется.