Khắc phục sự cố lỗi triển khai chính sách PythonScript

Bạn đang xem tài liệu về Apigee Edge.
Chuyển đến tài liệu về Apigee X.
thông tin

InvalidResourceUrlFormat

Thông báo lỗi

Không triển khai được proxy API thông qua giao diện người dùng Edge hoặc API quản lý Edge với thông báo lỗi sau:

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

Thông báo lỗi mẫu

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

Ảnh chụp màn hình mẫu

Nguyên nhân

Nếu định dạng của URL tài nguyên được chỉ định trong phần tử <ResourceURL> hoặc <IncludeURL> của chính sách PythonScript không hợp lệ, thì proxy API sẽ không triển khai được.

Định dạng chính xác như sau:

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

Ví dụ: nếu phần tử <ResourceURL> được chỉ định như hình bên dưới, thì quá trình triển khai proxy API sẽ không thành công do không tuân theo mẫu bắt buộc:

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

Chẩn đoán

  1. Xác định định dạng URL tài nguyên không hợp lệ dùng trong chính sách PythonScript. Bạn có thể tìm thấy thông tin này trong thông báo lỗi. Ví dụ: trong lỗi sau, định dạng URL tài nguyên không hợp lệ là py:myscript.py:

    Invalid resource url format. Resource url is py:myscript.py.
    
  2. Kiểm tra tất cả các chính sách PythonScript trong Proxy API cụ thể nơi xảy ra lỗi. Nếu có bất kỳ chính sách PythonScript nào trong đó URL tài nguyên được chỉ định trong <ResourceURL> hoặc phần tử <IncludeURL> khớp với mục nhập không hợp lệ đã xác định ở bước #1 ở trên, thì đó chính là nguyên nhân gây ra lỗi.

    Ví dụ: chính sách sau đây chỉ định URL tài nguyên là py:myscript.py, khớp với nội dung trong thông báo lỗi:

    <?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>
    

    Vì URL tài nguyên được chỉ định là py:myscript.py không hợp lệ nên không thể triển khai Proxy API với lỗi:

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

Độ phân giải

Đảm bảo rằng định dạng URL tài nguyên được chỉ định trong phần tử <ResourceURL> của chính sách PythonScript là hợp lệ. Ví dụ:

<?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

Thông báo lỗi

Không triển khai được proxy API thông qua giao diện người dùng Edge hoặc API quản lý Edge với thông báo lỗi sau:

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

Thông báo lỗi mẫu

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

Ảnh chụp màn hình mẫu

Nguyên nhân

Nếu các phần tử <ResourceURL><IncludeURL> tham chiếu đến một tệp PythonScript không tồn tại, thì sẽ không triển khai được proxy API. Nếu đang triển khai một gói proxy từ máy cục bộ, thì bạn phải lưu trữ tệp nguồn PythonScript trong /apiproxy/resources/py(ở phạm vi proxy API).

Trong giao diện người dùng Edge, các tệp nguồn PythonScript xuất hiện trong py ở phần tập lệnh của ngăn Trình điều hướng của trình chỉnh sửa proxy API như minh họa dưới đây:

Bạn cũng có thể lưu trữ tệp tài nguyên trong kho lưu trữ cấp tổ chức và cấp môi trường (để cung cấp mã PythonScript cho tất cả các proxy trong một tổ chức hoặc môi trường chẳng hạn). Nếu không tìm thấy tệp tài nguyên nào được chỉ định trong chính sách, thì lỗi này sẽ xảy ra.

Chẩn đoán

  1. Xác định chính sách PythonScript nơi xảy ra lỗi và tham chiếu URL tài nguyên không hợp lệ. Bạn có thể tìm thấy thông tin này trong thông báo lỗi. Ví dụ: trong lỗi sau, tên chính sách là Python_script và giá trị tham chiếu URL tài nguyên không hợp lệ là py://myscript.py:

    Invalid resource url ref py://myscript.py in policy Python_script in myorg
    
  2. Xác minh rằng tham chiếu URL tài nguyên được chỉ định trong chính sách PythonScript không thành công khớp với giá trị được xác định trong thông báo lỗi (bước #1 ở trên). Ví dụ: Chính sách sau đây chỉ định tham chiếu URL tài nguyên là py://myscript.py, khớp với nội dung trong thông báo lỗi:

    <?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. Kiểm tra xem tệp được xác định trong tệp bước #1 có thuộc gói Proxy API cụ thể hay không, hoặc có tồn tại trong phạm vi tổ chức hoặc môi trường hay không.

    1. Để kiểm tra xem tệp có thuộc Gói proxy API cụ thể hay không, hãy làm theo một trong các bước bên dưới:
      1. Trong giao diện người dùng Edge, hãy kiểm tra xem tệp này có nằm trong phần tập lệnh của proxy API hay không.
      2. Tải gói Proxy API xuống và tìm kiếm xem tệp có tồn tại hay không.
    2. Nếu tệp đó không thuộc gói Proxy API cụ thể, hãy kiểm tra xem tệp đó có tồn tại ở cấp tổ chức hoặc môi trường hay không. Bạn có thể sử dụng Resource Files API (API Tệp tài nguyên) cho cuộc điều tra này.

    Nếu tệp không tồn tại ở cấp Proxy API, tổ chức hoặc môi trường thì đó là nguyên nhân gây ra lỗi.

    Trong ví dụ trên, tên tệp PythonScript không hợp lệ là myscript.py. Trong ảnh chụp màn hình bên dưới, hãy lưu ý rằng tệp được chỉ định làm URL tài nguyên trong chính sách không xuất hiện trong mục Tập lệnh. Ngoài ra, tệp không tồn tại ở cấp tổ chức hoặc môi trường. Do đó, quá trình triển khai Proxy API sẽ không thành công kèm theo lỗi:

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

Độ phân giải

Đảm bảo rằng các tệp PythonScript được chỉ định trong các phần tử <ResourceURL><IncludeURL> tham chiếu đến một tệp hợp lệ tồn tại ở cấp Proxy API, tổ chức hoặc môi trường.

Để sửa ví dụ về chính sách PythonScript hiển thị ở trên, hãy thêm tệp myscript.py vào gói API Proxy. Trong ảnh chụp màn hình dưới đây, bạn có thể thấy các tệp PythonScript được chỉ định trong các phần tử <ResourceURL><IncludeURL> hiển thị trong phần tập lệnh của gói Proxy API: