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
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
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.
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
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:
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
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
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>
Verifica se il file identificato nel passaggio #1 fa parte del bundle specifico del proxy API o esiste nell'ambito dell'ambiente.
- Per verificare se il file fa parte dello specifico bundle del proxy API, segui uno dei passaggi seguenti:
- Nell'interfaccia utente di Apigee, controlla se il file si trova nella sezione Script del proxy API.
- Scarica il bundle proxy API e cerca se il file esiste.
- 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
- Per verificare se il file fa parte dello specifico bundle del proxy API, segui uno dei passaggi seguenti:
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: