PythonScript 정책 런타임 오류 문제해결

ApigeeApigee Hybrid 문서입니다.
Apigee Edge 문서 보기

ScriptEvaluationFailed

오류 코드

steps.script.ScriptEvaluationFailed

오류 응답 본문

{
    "fault": {
        "faultstring": "Evaluation of script pythonscript_name (py) failed with reason: error_type: error_description"",
        "detail": {
            "errorcode": "steps.script.ScriptEvaluationFailed"
        }
    }
}

가능한 원인

Python 스크립트 정책은 여러 가지 유형의 ScriptEvaluationFailed 오류를 발생시킬 수 있습니다. 아래 섹션에서는 이러한 오류 중 일부를 설명합니다.

NameError

PythonScript 코드에 정의 없이 참조되거나 연산되는 변수가 있는 경우, 이름 오류가 발생합니다.

오류 응답 본문

{
    "fault": {
        "faultstring": "Evaluation of script pythonscript_name (py) failed with reason: "NameError: variable_name is not defined"",
        "detail": {
            "errorcode": "steps.script.ScriptEvaluationFailed"
        }
    }
}

오류 응답 본문 예시

{
    "fault": {
        "faultstring": "Evaluation of script myscript.py (py) failed with reason: "NameError: 'num3' is not defined"",
        "detail": {
            "errorcode": "steps.script.ScriptEvaluationFailed"
        }
    }
}

진단

  1. 오류 응답의 faultstring 요소에서 PythonScript 정책과 정의되지 않은 변수 이름을 식별합니다. 예를 들어 다음 faultstring에서 PythonScript 이름은 myscript.py이고 정의되지 않은 변수 이름은 num3입니다.

    "faultstring": "Evaluation of script myscript.py (py) failed with reason: "NameError: 'num3' is not defined""
  2. 위의 1단계에서 식별된 PythonScript 소스 파일을 검토하고 위의 1단계에서 식별된 정의되지 않은 변수가 참조되고 있는지 확인합니다. 예를 들어 다음 PythonScript 코드에서는 정의되지 않은 변수 num3을 참조하여 이는 faultstring의 오류와 일치합니다.

    num1 = 1.5
    num2 = 6.3
    sum = float(num1) + float(num3)
    print('The sum of {0} and {1} is {2}'.format(num1, num3 sum))
  3. 특정 변수가 PythonScript 코드 내에 정의되어 있는지 확인합니다. 변수가 정의되지 않은 경우 이는 오류의 원인이 됩니다.

    위의 예제 스크립트에서 num3 변수는 정의되지 않았습니다. 따라서 다음과 같은 오류가 발생합니다.

    "faultstring": "Evaluation of script myscript.py (py) failed with reason: "NameError: 'num3' is not defined""

해결 방법

PythonScript 코드에서 참조된 모든 변수가 올바르게 정의되었는지 확인합니다.

위에 표시된 PythonScript 예시의 문제를 해결하려면 변수 num3을 사용하기 전에 정의합니다. 예를 들면 다음과 같습니다.

num1 = 1.5
num2 = 6.3
num3 = 8.7
sum = float(num1) + float(num3)
print('The sum of {0} and {1} is {2}'.format(num1, num3, sum))

ZeroDivisionError

이 오류는 나누기 또는 모듈로 연산의 두 번째 인수가 0일 때 발생합니다.

오류 응답 본문

{
    "fault": {
        "faultstring": "Evaluation of script pythonscript_name (py) failed with reason: "ZeroDivisionError: reason_for_error"",
        "detail": {
            "errorcode": "steps.script.ScriptEvaluationFailed"
        }
    }
}

오류 응답 본문 예시

{
    "fault": {
        "faultstring": "Evaluation of script myscript.py (py) failed with reason: "ZeroDivisionError: integer division or modulo by zero"",
        "detail": {
            "errorcode": "steps.script.ScriptEvaluationFailed"
        }
    }
}

진단

  1. PythonScript 정책 이름과 오류 응답의 faultstring 요소에서 실패한 이유를 식별합니다. 예를 들어 다음 faultstring에서 PythonScript 이름은 myscript.py이고 실패 이유는 integer division or modulo by zero입니다.

    "faultstring": "Evaluation of script myscript.py (py) failed with reason: "ZeroDivisionError: integer division or modulo by zero""
  2. 위의 1단계에서 식별된 PythonScript 소스 파일을 검사하여 0으로 나누기 또는 모듈로 연산을 하는지 확인합니다. 예를 들어 다음 PythonScript 코드에서는 0으로 나누기를 수행하며 이는 faultstring의 오류와 일치합니다.

    a = 0
    b = 5
    c = b/a
    print c

    위의 예시 스크립트에서 나누기 연산의 두 번째 인수가 0이므로 다음과 같은 오류가 발생합니다.

    "faultstring": "Evaluation of script myscript.py (py) failed with reason: "ZeroDivisionError: integer division or modulo by zero""

해결 방법

PythonScript에서 나누기 또는 모듈로 연산의 두 번째 인수가 0이 아닌지 확인합니다.

위에 표시된 PythonScript 예시의 문제를 해결하려면 나누기 또는 모듈로 연산의 두 번째 인수로 0이 아닌 값을 사용합니다. 예를 들면 다음과 같습니다.

a = 3
b = 5
c = b/a
print c

추가 정보

위에 설명된 오류 외에도 steps.script.ScriptEvaluationFailed 오류가 발생할 수 있는 다른 원인이 많이 있습니다. 자세한 내용은 공식 Python 문서를 참조하세요.