Вы просматриваете документацию Apigee Edge .
Перейдите к документации Apigee X. информация
Инвалидтаймаут
Сообщение об ошибке
Развертывание прокси-сервера API через пользовательский интерфейс Edge или API управления Edge завершается сбоем с этим сообщением об ошибке:
Error Saving Revision revision_number CacheLookupTimeoutInSeconds value value should be greater than zero.
Пример сообщения об ошибке
Error Saving Revision 2
CacheLookupTimeoutInSeconds -1 value should be greater than zero.
Пример снимка экрана с ошибкой
Причина
Если для элемента <CacheLookupTimeoutInSeconds>
политики LookupCache установлено отрицательное число, развертывание прокси-сервера API завершается неудачно.
Например, если элемент <CacheLookupTimeoutInSeconds>
имеет значение -1
, развертывание прокси-сервера API завершается неудачно.
Диагностика
Определите недопустимое значение, указанное для элемента
<CacheLookupTimeoutInSeconds>
в политике LookupCache . Эту информацию можно найти в сообщении об ошибке. Например, в следующей ошибке недопустимое значение, используемое для элемента<CacheLookupTimeoutInSeconds>
равно-1
:CacheLookupTimeoutInSeconds -1 value should be greater than zero.
Проверьте все политики LookupCache в конкретном прокси-сервере API, где произошел сбой. Может существовать одна или несколько политик LookupCache, в которых указан элемент
<CacheLookupTimeoutInSeconds>
. Определите политику LookUpCache, в которой для элемента<CacheLookupTimeoutInSeconds>
указано недопустимое значение (определенное на шаге 1 выше).Например, в следующей конфигурации политики указывается значение
<CacheLookupTimeoutInSeconds>
-1
, что соответствует сообщению об ошибке:<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <LookupCache async="false" continueOnError="false" enabled="true" name="LookupCache-Token"> <DisplayName>LookupCache-Token</DisplayName> <Properties/> <CacheKey> <Prefix/> <KeyFragment ref="request.queryparam.client_id"/> </CacheKey> <CacheLookupTimeoutInSeconds>-1</CacheLookupTimeoutInSeconds> <Scope>Exclusive</Scope> <ExpirySettings> <TimeoutInSec>3600</TimeoutInSec> </ExpirySettings> <AssignTo>usertoken</AssignTo> </LookupCache>
Если
<CacheLookupTimeoutInSeconds>
указано как отрицательное целое число, это и есть причина ошибки.
Разрешение
Убедитесь, что значение элемента <CacheLookupTimeoutInSeconds>
политики LookupCache всегда указано как неотрицательное целое число.
Чтобы исправить пример политики LookupCache, показанный выше, вы можете изменить элемент <CacheLookupTimeoutInSeconds>
на 30
.
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<LookupCache async="false" continueOnError="false" enabled="true" name="LookupCache-Token">
<DisplayName>LookupCache-Token</DisplayName>
<Properties/>
<CacheKey>
<Prefix/>
<KeyFragment ref="request.queryparam.client_id"/>
</CacheKey>
<CacheResource>tokencache</CacheResource>
<CacheLookupTimeoutInSeconds>30</CacheLookupTimeoutInSeconds>
<Scope>Exclusive</Scope>
<ExpirySettings>
<TimeoutInSec>3600</TimeoutInSec>
</ExpirySettings>
<AssignTo>usertoken</AssignTo>
</LookupCache>
Инвалидкачересаурцеференсе
Сообщение об ошибке
Развертывание прокси-сервера API через пользовательский интерфейс Edge или API управления Edge завершается сбоем с этим сообщением об ошибке:
Error Deploying Revision revision_number to environment Invalid cache resource reference [cache_resource] in Step definition [populate_cache_policy_name]. Context Revision:[revision_number];APIProxy:ResponseCache;Organization:[organization];Environment:[environment]
Пример сообщения об ошибке
Error Deploying Revision 2 to test
Invalid cache resource reference tokencache in Step definition LookupCache-Token. Context Revision:2;APIProxy:TestCache;Organization:kkalckstein-eval;Environment:test
Пример снимка экрана с ошибкой
Причина
Эта ошибка возникает, если для элемента <CacheResource>
установлено имя, которое не существует в среде, где развертывается прокси-сервер API.
Диагностика
Определите недопустимый кэш, используемый в элементе
<CacheResource>
политики LookupCache , и среду, в которой произошла ошибка. Оба эти элемента можно найти в сообщении об ошибке. Например, в следующей ошибке имя недопустимого кэша —tokencache
, а имя среды —test
.Invalid cache resource reference tokencache in Step definition LookupCache-Token. Context Revision:2;APIProxy:TestCache;Organization:kkalckstein-eval;Environment:test
Проверьте все политики LookupCache в конкретном прокси-сервере API, где произошел сбой. Определите конкретную политику LookupCache, в которой указан недопустимый кэш (определенный на шаге 1) в элементе
<CacheResource>
.Например, следующая политика определяет значение
<CacheResource>
какtokencache
, что соответствует сообщению об ошибке:<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <LookupCache async="false" continueOnError="false" enabled="true" name="LookupCache-Token"> <DisplayName>LookupCache-Token</DisplayName> <Properties/> <CacheKey> <Prefix/> <KeyFragment ref="request.queryparam.client_id"/> </CacheKey> <CacheResource>tokencache</CacheResource> <CacheLookupTimeoutInSeconds/> <Scope>Exclusive</Scope> <ExpirySettings> <TimeoutInSec>3600</TimeoutInSec> </ExpirySettings> <AssignTo>usertoken</AssignTo> </LookupCache>
Убедитесь, что кэш (определенный на шаге №1) определен в конкретной среде (определенной на шаге №1).
В пользовательском интерфейсе Edge перейдите в раздел «ADMIN» > «Среда» > «тест» и проверьте, существует ли кеш на вкладке «Кэши » в разделе «Конфигурация среды» . Если кэша нет, то это и есть причина ошибки.
Например, обратите внимание на скриншоте ниже, что кэша с именем
tokencache
не существует.Поскольку кэш с именем
tokencache
не определен вtest
среде, вы получаете сообщение об ошибке:Invalid cache resource reference tokencache in Step definition LookupCache-Token. Context Revision:2;APIProxy:TestCache;Organization:kkalckstein-eval;Environment:test
Разрешение
Убедитесь, что имя кэша, указанное в элементе <CacheResource>
, создано в среде, в которой вы хотите развернуть прокси-сервер 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
Причина
Эта ошибка возникает, если конкретный кэш, упомянутый в сообщении об ошибке, не был создан в определенном компоненте процессора сообщений.
Разрешение
Если вы являетесь пользователем частного облака , следуйте инструкциям ниже:
Перечислите развертывания прокси-сервера 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 .