การแก้ปัญหาข้อผิดพลาดในการทำให้นโยบายแคชของการค้นหา

คุณกำลังดูเอกสารประกอบ Apigee Edge
ไปที่ เอกสารประกอบเกี่ยวกับ Apigee X.
ข้อมูล

InvalidTimeout

ข้อความแสดงข้อผิดพลาด

การทำให้พร็อกซี API ใช้งานได้ผ่าน Edge UI หรือ Edge Management API จะล้มเหลวโดยมีข้อความแสดงข้อผิดพลาดต่อไปนี้

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 ใช้งานได้จะล้มเหลว

การวินิจฉัย

  1. ระบุค่าที่ไม่ถูกต้องสำหรับองค์ประกอบ <CacheLookupTimeoutInSeconds> ในนโยบาย LookupCache ซึ่งคุณจะเห็นข้อมูลนี้ในข้อความแสดงข้อผิดพลาด ตัวอย่างเช่น ในข้อผิดพลาดต่อไปนี้ ค่าที่ไม่ถูกต้องที่ใช้กับองค์ประกอบ <CacheLookupTimeoutInSeconds> คือ -1

    CacheLookupTimeoutInSeconds -1 value should be greater than zero.
    
  2. ตรวจสอบนโยบาย LookupCache ทั้งหมดในพร็อกซี API ที่เกิดข้อผิดพลาด อาจมีนโยบาย LookupCache อย่างน้อย 1 รายการที่ระบุองค์ประกอบ <CacheLookupTimeoutInSeconds> ระบุนโยบาย LookUpCache ในตำแหน่งที่ระบุค่าที่ไม่ถูกต้อง (ระบุในขั้นตอนที่ 1 ด้านบน) สำหรับองค์ประกอบ <CacheLookupTimeoutInSeconds>

    ตัวอย่างเช่น การกำหนดค่านโยบายต่อไปนี้ระบุค่า <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>
    
  3. หากระบุ <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>

InvalidCacheResourceReference

ข้อความแสดงข้อผิดพลาด

การทำให้พร็อกซี API ใช้งานได้ผ่าน Edge UI หรือ Edge Management API จะล้มเหลวโดยมีข้อความแสดงข้อผิดพลาดต่อไปนี้

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 ใช้งานได้

การวินิจฉัย

  1. ระบุแคชที่ไม่ถูกต้องที่ใช้ในองค์ประกอบ <CacheResource> ของนโยบาย LookupCache และสภาพแวดล้อมที่เกิดข้อผิดพลาดขึ้น ซึ่งคุณจะเห็นทั้ง 2 รายการนี้ในข้อความแสดงข้อผิดพลาด ตัวอย่างเช่น ในข้อผิดพลาดต่อไปนี้ ชื่อของแคชที่ไม่ถูกต้องคือ tokencache และชื่อสภาพแวดล้อมคือ test

    Invalid cache resource reference tokencache in Step definition LookupCache-Token. Context Revision:2;APIProxy:TestCache;Organization:kkalckstein-eval;Environment:test
    
  2. ตรวจสอบนโยบาย 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>
    
  3. ตรวจสอบว่าแคช (ระบุในขั้นตอนที่ 1) ถูกกำหนดในสภาพแวดล้อมที่เฉพาะเจาะจงหรือไม่ (ระบุในขั้นตอนที่ 1)

    ใน Edge UI ให้ไปที่ ผู้ดูแลระบบ > สภาพแวดล้อม > ทดสอบและตรวจสอบว่ามีแคชอยู่ในแท็บแคชของการกำหนดค่าสภาพแวดล้อมหรือไม่ หากไม่มีแคชอยู่ แสดงว่าเกิดข้อผิดพลาด

    เช่น โปรดสังเกตในภาพหน้าจอด้านล่างว่าไม่มีแคชชื่อ 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 ใช้งานได้

โปรดดูข้อมูลเกี่ยวกับวิธีสร้างแคชในการสร้างและแก้ไขแคชของสภาพแวดล้อม

CacheNotFound

ข้อความแสดงข้อผิดพลาด

การทำให้พร็อกซี API ใช้งานได้ผ่าน Edge UI หรือ Edge Management API จะแสดงข้อความแสดงข้อผิดพลาดดังนี้ และสถานะการติดตั้งใช้งานของพร็อกซี API จะมีสถานะเป็นทำให้ใช้งานได้บางส่วน ดังนี้

Error: Cache : cache_resource, not found in organization : organization__environment.

ตัวอย่างข้อความแสดงข้อผิดพลาด

Error Cache : configCache, not found in organization : kkalckstein-eval__test

สาเหตุ

ข้อผิดพลาดนี้เกิดขึ้นหากไม่ได้สร้างแคชเฉพาะที่ระบุไว้ในข้อความแสดงข้อผิดพลาดบนคอมโพเนนต์ตัวประมวลผลข้อความที่เฉพาะเจาะจง

ความละเอียด

หากคุณเป็นผู้ใช้ Private Cloud โปรดทำตามวิธีการด้านล่าง

  1. แสดงรายการการทำให้พร็อกซี 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"
      ...
    
  2. จดบันทึก UUID ของโปรแกรมประมวลผลข้อความที่คุณเห็นข้อผิดพลาด steps.cache.CacheNotFound ระบุชื่อโฮสต์/ที่อยู่ IP ของโปรแกรมประมวลผลข้อความที่เชื่อมโยงกับ UUID

  3. เข้าสู่ระบบ Message Processor ที่ต้องการ และรีสตาร์ทโดยใช้คำสั่งต่อไปนี้:

    apigee-service edge-message-processor restart

หากคุณเป็นผู้ใช้ Public Cloud หรือหากยังคงพบปัญหาสําหรับ Private Cloud โปรดติดต่อทีมสนับสนุนของ Apigee เพื่อขอความช่วยเหลือ