Risoluzione degli errori di deployment dei criteri PythonScript

Stai visualizzando la documentazione di Apigee e Apigee hybrid.
Visualizza la documentazione di Apigee Edge.

InvalidResourceUrlFormat

Messaggio di errore

Il deployment di un proxy API tramite l'API o la UI di Apigee non va a buon fine e genera questo messaggio di errore:

Error Deploying Revision revision_number to environment
Invalid resource url format. Resource url is invalid_URL.

Esempio di messaggio di errore

Error Deploying Revision 2 to prod
Invalid resource url format. Resource url is py:myscript.py.

Screenshot di esempio

Errore durante il deployment della revisione 2 nella produzione.

Causa

Se il formato dell'URL della risorsa specificato all'interno dell'elemento <ResourceURL> o <IncludeURL> del criterio PythonScript non è valido, il deployment del proxy API non riesce.

Il formato corretto è il seguente:

<ResourceURL>py://file_name.py</ResourceURL>
<IncludeURL>py://file_name.py</IncludeURL>

Ad esempio, se l'elemento <ResourceURL> viene specificato come mostrato di seguito, il deployment del proxy API non va a buon fine perché non segue il pattern richiesto:

<ResourceURL>py:myscript.py</ResourceURL>

Diagnosi

  1. Identifica il formato dell'URL della risorsa non valido usato nel criterio PythonScript. Puoi trovare queste informazioni nel messaggio di errore. Ad esempio, nel seguente errore, il formato dell'URL della risorsa non valido è py:myscript.py:

    Invalid resource url format. Resource url is py:myscript.py.
    
  2. Esamina tutti i criteri PythonScript nello specifico proxy API in cui si è verificato l'errore. Se esiste un criterio PythonScript in cui l'URL della risorsa specificato nell'elemento <ResourceURL> o <IncludeURL> corrisponde alla voce non valida identificata nel passaggio #1 precedente, questa è la causa dell'errore.

    Ad esempio, il seguente criterio specifica l'URL della risorsa come py:myscript.py, che corrisponde al messaggio di errore indicato:

    <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
    <Script async="false" continueOnError="false" enabled="true" timeLimit="200" name="py-TotalVariable">
        <DisplayName>py-TotalVariable</DisplayName>
        <Properties/>
        <ResourceURL>py:myscript.py</ResourceURL>
    </Script>
    

    Poiché l'URL della risorsa è specificato come py:myscript.py, che non è valido, il deployment del proxy API ha esito negativo e restituisce l'errore:

    Invalid resource url format. Resource url is py:myscript.py.
    

Risoluzione

Assicurati che il formato dell'URL della risorsa specificato nell'elemento <ResourceURL> del criterio PythonScript sia valido. Ad esempio:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<Script async="false" continueOnError="false" enabled="true" timeLimit="200" name="py-TotalVariable">
    <DisplayName>py-TotalVariable</DisplayName>
    <Properties/>
    <ResourceURL>py://myscript.py</ResourceURL>
</Script>

InvalidResourceUrlReference

Messaggio di errore

Il deployment di un proxy API tramite l'API o la UI di Apigee non va a buon fine e genera questo messaggio di errore:

Error Deploying Revision revision_number to environment
Invalid resource url ref invalid_reference in policy policy_name in org_name

Esempio di messaggio di errore

Error Deploying Revision 2 to prod
Invalid resource url ref py://myscript.py in policy Python_script in myorg

Screenshot di esempio

Errore durante il deployment della revisione 2 nella produzione.

Causa

Se gli elementi <ResourceURL> e <IncludeURL> fanno riferimento a un file PythonScript inesistente, il deployment del proxy API non riesce. Se esegui il deployment di un bundle proxy dalla tua macchina locale, i file di origine PythonScript devono essere archiviati in /apiproxy/resources/py(nell'ambito del proxy API).

Nell'interfaccia utente di Apigee, i file di origine PythonScript vengono visualizzati in py nella sezione Script del riquadro di navigazione dell'editor del proxy API, come mostrato di seguito:

Sezione degli script del riquadro di navigazione dell&#39;editor proxy API.

Puoi anche archiviare i file di risorse in repository a livello di ambiente (per rendere il codice PythonScript disponibile a tutti i proxy in un ambiente env, ad esempio). Se non è possibile trovare file di risorse specificati nel criterio, si verifica questo errore.

Diagnosi

  1. Identifica il criterio PythonScript in cui si è verificato l'errore e il riferimento dell'URL della risorsa non valido. Puoi trovare queste informazioni nel messaggio di errore. Ad esempio, nell'errore seguente, il nome del criterio è Python_script e il riferimento dell'URL della risorsa non valido è py://myscript.py:

    Invalid resource url ref py://myscript.py in policy Python_script in myorg
    
  2. Verifica che il riferimento dell'URL della risorsa specificato nel criterio PythonScript non riuscito corrisponda al valore identificato nel messaggio di errore (passaggio 1 sopra). Ad esempio, il seguente criterio specifica il riferimento dell'URL della risorsa come py://myscript.py, che corrisponde al contenuto del messaggio di errore:

    <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
    <Script async="false" continueOnError="false" enabled="true" name="Python_script">
        <DisplayName>Python-1</DisplayName>
        <Properties/>
        <ResourceURL>py://myscript.py</ResourceURL>
    </Script>
    
  3. Verifica se il file identificato nel passaggio #1 fa parte del bundle specifico del proxy API o esiste nell'ambito dell'ambiente.

    1. Per verificare se il file fa parte dello specifico bundle del proxy API, segui uno dei passaggi seguenti:
      1. Nell'interfaccia utente di Apigee, controlla se il file si trova nella sezione Script del proxy API.
      2. Scarica il bundle proxy API e cerca se il file esiste.
    2. Se il file non fa parte dello specifico bundle proxy API, verifica se esiste a livello di ambiente. Puoi utilizzare l'API Resource Files per questa indagine.

    Se il file non esiste a livello di proxy API o di ambiente, è questa la causa dell'errore.

    Nell'esempio precedente, il nome di file PythonScript non valido è myscript.py. Nello screenshot riportato di seguito, puoi notare che il file specificato come URL di una risorsa nel criterio non viene visualizzato nella sezione Script. Inoltre, il file non esiste a livello di ambiente. Pertanto, il deployment del proxy API non riesce e restituisce l'errore:

    Invalid resource url ref py://myscript.py in policy Python_script in myorg
    

URL della risorsa non valido.

Risoluzione

Assicurati che i file PythonScript specificati negli elementi <ResourceURL> e <IncludeURL> facciano riferimento a un file valido esistente a livello di proxy API o di ambiente.

Per correggere il criterio PythonScript di esempio mostrato sopra, aggiungi il file myscript.py al bundle proxy API. Nello screenshot seguente puoi vedere che i file PythonScript specificati negli elementi <ResourceURL> e <IncludeURL> sono visibili nella sezione Script del bundle proxy API:

Sezione degli script del bundle proxy API.