Вы просматриваете документацию Apigee Edge .
Перейдите к документации Apigee X. информация
Инвалидкачересаурцеференсе
Сообщение об ошибке
Развертывание прокси-сервера API через пользовательский интерфейс Edge или API управления Edge завершается сбоем с этим сообщением об ошибке:
Error Deploying Revision revision_number to environment Invalid cache resource reference [cache_resource] in Step definition [invalidate_cache_policy_name]. Context Revision:[revision_number];APIProxy:[apiproxy_name];Organization:[organization];Environment:[environment]
Пример сообщения об ошибке
Error Deploying Revision 2 to test
Invalid cache resource reference tokencache in Step definition InvalidateCache-Token. Context Revision:2;APIProxy:TestCache;Organization:kkalckstein-eval;Environment:test
Пример снимка экрана с ошибкой
Причина
Эта ошибка возникает, если элементу <CacheResource>
в политике InvalidateCache присвоено имя, которое не существует в среде, где развертывается прокси-сервер API.
Диагностика
Определите имя политики InvalidateCache , недопустимый кэш, используемый в элементе
<CacheResource>
политики InvalidateCache, и среду, в которой произошла ошибка. Все эти элементы вы можете найти в сообщении об ошибке. Например, в следующей ошибке имя политики InvalidateCache —InvalidateCache-Token
, имя недопустимого кэша —tokencache
, а имя среды —test
.Invalid cache resource reference tokencache in Step definition InvalidateCache-Token. Context Revision:2;APIProxy:TestCache;Organization:kkalckstein-eval;Environment:test
Изучите неудачный XML-код политики InvalidateCache и проверьте, соответствует ли имя кэша, указанное для элемента
<CacheResource>
, сообщению об ошибке.В этом примере имя кэша, указанное в элементе
<CacheResource>
, —tokencache
:<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <InvalidateCache async="false" continueOnError="false" enabled="true" name="InvalidateCache-Token"> <DisplayName>InvalidateCache-Token</DisplayName> <Properties/> <CacheKey> <Prefix/> <KeyFragment ref=""/> </CacheKey> <CacheResource>tokencache</CacheResource> <Scope>Exclusive</Scope> <CacheContext> <APIProxyName/> <ProxyName>default</ProxyName> <TargetName>default</TargetName> </CacheContext> <PurgeChildEntries>false</PurgeChildEntries> </InvalidateCache>
Убедитесь, что кэш (определенный на шаге №1) определен в конкретной среде (определенной на шаге №1).
В пользовательском интерфейсе Edge перейдите в раздел «ADMIN» > «Среда» > «тест» и проверьте, существует ли кеш на вкладке «Кэши » в разделе «Конфигурация среды» . Если кэша нет, то это и есть причина ошибки.
Например, обратите внимание на скриншоте ниже, что кэша с именем
tokencache
не существует.Поскольку кэш с именем
tokencache
не определен вtest
среде, вы получаете сообщение об ошибке:Invalid cache resource reference tokencache in Step definition InvalidateCache-Token. Context Revision:2;APIProxy:TestCache;Organization:kkalckstein-eval;Environment:test
Разрешение
Убедитесь, что кэш, указанный в элементе <CacheResource>
политики InvalidateCache, создан в среде, в которой вы хотите развернуть прокси-сервер API.
Дополнительную информацию о том, как создать кэш, см. в разделе Создание и редактирование кэша среды .
Кэш не найден
Сообщение об ошибке
Развертывание прокси-сервера API через пользовательский интерфейс Edge или API управления Edge приводит к появлению такого сообщения об ошибке, а состояние развертывания прокси-сервера API помечается как частично развернутое:
Error: Cache : cache_resource, not found in organization : organization__environment.
Пример сообщения об ошибке
Error Cache : configCache, not found in organization : kkalckstein-eval__test
Причина
Эта ошибка возникает, если конкретный кэш, упомянутый в сообщении об ошибке, не был создан в определенном компоненте процессора сообщений. Процессор сообщений — это внутренний компонент Edge, который обрабатывает поток трафика API через Apigee Edge.
Разрешение
Если вы являетесь пользователем частного облака , следуйте инструкциям ниже:
Перечислите развертывания прокси-сервера API и определите, какие процессоры сообщений имеют ошибку
steps.cache.CacheNotFound
.curl -u $USERID:$USERPASSWORD http://
:8080/v1/organizations/ /environments/ /apis/ /revisions/ /deployments Пример вывода
{ "aPIProxy" : "TestCache", "environment" : [ { "configuration" : { "basePath" : "/", "configVersion" : "SHA-512:45d3f39783414d3859bf2dec4135d8f5f9960ee6b2d361db2799c82693a8e3f8b95dbbb37c547eb3c0a3819d8ca51727f390502bcaefdf1f113263521a9023b6", "steps" : [ ] }, "name" : "prod", "server" : [ { "pod" : { "name" : "pod1", "region" : "us-central1" }, "status" : "deployed", "type" : [ "message-processor" ], "uUID" : "f2e5e34a-5630-43a9-8fef-48a5b9da76d1" }, { "pod" : { "name" : "pod1", "region" : "us-central1" }, "status" : "deployed", "type" : [ "message-processor" ], "uUID" : "879a6538-a5e0-4503-b142-9cb2b4e0623d" }, { "error" : "Cache : configCache, not found in organization : kkalckstein-eval__test", "errorCode" : "steps.cache.CacheNotFound", "status" : "error", "type" : [ "message-processor" ], "uUID" : "a8f9ce0b-c32d-48a9-b26c-9c75d8bf467d" }, ... "state" : "deployed" } ], "name" : "2", "organization" : "kkalckstein-eval" ...
Обратите внимание на UUID процессора сообщений, в котором вы наблюдаете ошибку
steps.cache.CacheNotFound
. Определите имя хоста/IP-адрес процессора сообщений, соответствующий UUID.Войдите в определенный процессор сообщений и перезапустите его, используя следующую команду:
apigee-service edge-message-processor restart
Если вы являетесь пользователем общедоступного облака или проблема с частным облаком не устранена, обратитесь за помощью в службу поддержки Apigee .