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

Thông báo lỗi sau 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:

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

Ví dụ về thông báo lỗi

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 phần tử Chính sách PythonScript không hợp lệ, thì việc triển khai proxy API sẽ không thành công.

Đị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ư dưới đây, thì phương thức không triển khai proxy API được do proxy 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 mà trong đó URL tài nguyên được chỉ định trong phần tử <ResourceURL> hoặc <IncludeURL> khớp với mục không hợp lệ được xác định trong bước 1 ở trên, thì đó 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>
    

    Do URL tài nguyên được chỉ định là py:myscript.py không hợp lệ, nên việc triển khai Proxy API không thành công kèm theo 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

Thông báo lỗi sau 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:

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

Ví dụ về thông báo lỗi

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ì việc triển khai proxy API sẽ không thành công. Nếu bạn đang triển khai gói proxy từ máy cục bộ, thì PythonScript tệp nguồn phải được lưu trữ 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 sẽ xuất hiện trong mục py trong mục Scripts (Tập lệnh) trong ngăn Điều hướng của trình chỉnh sửa proxy API như minh hoạ dưới đây:

Bạn cũng có thể lưu trữ các tệp tài nguyên trong kho lưu trữ cấp tổ chức và cấp môi trường (ví dụ: để cung cấp mã PythonScript cho tất cả proxy trong một tổ chức hoặc môi trường). Nếu không tìm thấy bất kỳ 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à 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 bị lỗi 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 đã xác định trong tệp ở bước 1 có thuộc gói API Proxy cụ thể hay không, hoặc có tồn tại ở phạm vi tổ chức hoặc môi trường hay không.

    1. Để kiểm tra xem tệp đó có nằm trong gói Proxy API cụ thể hay không, hãy làm theo một trong các bước dưới đây:
      1. Trong giao diện người dùng Edge, hãy kiểm tra xem tệp này có nằm trong mục Scripts (Tập lệnh) của proxy API hay không.
      2. Tải gói API Proxy xuống và tìm kiếm xem có tệp nào tồn tại.
    2. Nếu tệp không thuộc gói Proxy API cụ thể, hãy kiểm tra xem tệp đó có ở cấp tổ chức hoặc cấp môi trường hay không. Bạn có thể sử dụng API Tệp tài nguyên cho quá trình đ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 phần Tập lệnh. Ngoài ra, tệp không tồn tại ở cấp tổ chức hoặc cấp môi trường. Do đó, việc triển khai Proxy API 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 chính sách PythonScript mẫu 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 ở bên dưới, 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 mục Scripts (Tập lệnh) của gói API Proxy: