הדף הזה רלוונטי ל-Apigee ול-Apigee Hybrid.
לעיון במסמכי התיעוד של Apigee Edge
ExecutionError
קוד שגיאה
steps.javacallout.ExecutionError
גוף התגובה לשגיאה
{
"fault": {
"faultstring": "Execution returned an error result",
"detail": {
"errorcode": "flow.execution.ExecutionReturnedFailure"
}
}
}
מטרה
השגיאה הזו מתרחשת אם קוד Java יוצר חריגה או מחזיר null במהלך ההפעלה של מדיניות JavaCallout.
אבחון
מפעילים סשן מעקב כדי לתעד את השגיאה ולזהות איזו מדיניות JavaCallout נכשלה.

בודקים את מדיניות JavaCallout ואת המשאב שבו נעשה שימוש. בדוגמה שלמעלה, JavaCallout policy משתמש במשאב בשם
hello.jar, כמו שמוצג בהמשך:<JavaCallout name="hello-java"> <ClassName>com.apigeesample.HelloJava</ClassName> <ResourceURL>java://hello.jar</ResourceURL> </JavaCallout>כדי לתעד ולאחסן את חריגת Java במשתנה של זרימת נתונים, צריך לשנות את קוד המקור, כמו שמתואר במאמר טיפול בשגיאות במדיניות JavaCallout.
קומפילציה והחלפה של המשאב המושפע (קובץ JAR) בפריט מידע שנוצר בתהליך פיתוח (Artifact) של Java.
פורסים את ה-API Proxy כגרסה חדשה ומבצעים את הקריאה ל-API.
מתחילים סשן חדש של מעקב.

שימו לב שמשתנה
JAVA_STACKTRACEמכיל את נתוני דוח הקריסות. דוח הקריסות מפרט את החריגה בפועל, את קובץ המקור של Java ואת מספר השורה שבה השגיאה מתרחשת.אפשר להשתמש במידע הזה כדי לפתור את הבעיה בקוד Java.
בדוגמה הזו, המדיניות JavaCallout נכשלה בגלל ArithmeticException (חלוקה באפס) בקובץ
JavaError.javaבשורה #25.
רזולוציה
בהתאם לחריגה שנוצרה, פותרים את הבעיה בקובץ או בקבצים הרלוונטיים של מקור Java. א. בדוגמה שלמעלה, הבעיה נגרמה בגלל שגיאה אריתמטית (חלוקה באפס). עוברים לקובץ המקור הספציפי ולמספר השורה שמצוינים ב-stack trace.

ב. מכיוון שאי אפשר לחלק באפס, צריך להסיר את כל בלוק ה-else שמכיל את שורת הקוד הפגומה כדי לפתור את הבעיה.
מחליפים את קובץ ה-JAR הרלוונטי שמכיל את הקבצים ששונו ברמה המתאימה (proxy ל-API, סביבה או ארגון), במקום שבו הוא היה קודם.
שומרים ומפרסמים את ה-proxy ל-API כגרסה חדשה.