מוצג המסמך של Apigee Edge.
עוברים אל
מסמכי תיעוד של Apigee X. מידע
לכל ארגון יש מחזור חיים ייחודי של פיתוח תוכנה (SDLC). לעיתים קרובות יש צורך לסנכרון ולהתאמה של פריסת ה-proxy של ה-API לתהליכים שמשמשים לשירותים לקצה העורפי.
אפשר להשתמש בשיטות של Edge API שהודגמו בנושא הזה כדי לשלב שרת proxy של API לניהול ה-SDLC של הארגון שלך. שימוש נפוץ ב-API הזה הוא כתיבת סקריפטים או קוד הפורסים שרתי proxy ל-API, או שמעבירים שרתי proxy של API מסביבה אחת לאחרת, כחלק תהליך אוטומטי גדול יותר שגם פורס או מעביר אפליקציות אחרות.
ה-Edge API לא מבצע הנחות לגבי ה-SDLC שלכם (או של כל אחד אחר, לצורך העניין). במקום זאת, היא חושפת פונקציות אטומיות שצוות הפיתוח שלכם יכול לתאם כדי לבצע אוטומציה ולבצע אופטימיזציה של מחזור החיים של פיתוח API.
למידע מלא, ראו Edge APIs.
כדי להשתמש ב-Edge API, תצטרכו לאמת את עצמכם בקריאות. אפשר לעשות זאת עם אחת מהשיטות הבאות:
- OAuth2 (Public Cloud בלבד)
- SAML (ענן ציבורי ופרטי)
- Basic Auth (לא מומלץ, ענן ציבורי ופרטי)
הנושא הזה מתמקד בקבוצת ממשקי API שמיועדים לניהול שרתי proxy ל-API.
סרטון: כדאי לצפות בסרטון הקצר הזה כדי ללמוד איך לפרוס API.
אינטראקציה עם ה-API
השלבים הבאים ינחו אתכם באינטראקציות פשוטות עם ממשקי ה-API.
הצגה של רשימת ממשקי ה-API בארגון
כדי להתחיל, אפשר לפרסם את כל שרתי ה-proxy ל-API בארגון שלכם. (חשוב לזכור להחליף את הטקסט רשומות עבור EMAIL:PASSWORD ו-ORG_NAME. הוראות מופיעות משתמשים ב-Edge API.
curl -u EMAIL:PASSWORD \ https://api.enterprise.apigee.com/v1/o/ORG_NAME/apis
תשובה לדוגמה:
[ "weatherapi" ]
טעינת API
אפשר להפעיל את ה-method GET
בכל שרת proxy ל-API בארגון. השיחה מחזירה רשימה של
את כל הגרסאות הזמינות של שרת ה-proxy ל-API.
curl -u EMAIL:PASSWORD -H "Accept: application/json" \ https://api.enterprise.apigee.com/v1/o/ORG_NAME/apis/weatherapi
תשובה לדוגמה:
{ "name" : "weatherapi", "revision" : [ "1" ] }
הפרטים היחידים המוחזרים באמצעות שיטה זו הם שם ה-Proxy ל-API יחד עם לגרסה הקודמת, שמשויך למספר שמשויך אליה. שרתי proxy ל-API מורכבים מחבילת הגדרות . גרסאות קודמות מספקות מנגנון קל לניהול עדכוני התצורה בזמן האימון. הגרסאות ממוספרות ברצף ומאפשרות לבטל שינוי על ידי פריסה גרסה קודמת של ה-proxy ל-API. בנוסף, תוכלו לפרוס גרסה קודמת של שרת proxy ל-API בתוך prod, תוך המשך יצירת גרסאות קודמות של שרת proxy זה של ה-API בבדיקה הסביבה. כשהכול מוכן, אפשר לקדם את הגרסה הקודמת של שרת ה-proxy ל-API דרך את סביבת הבדיקה על פני הגרסה הקודמת של שרת ה-proxy ל-API בסביבת prod.
בדוגמה הזו יש רק גרסה אחת כי ה-proxy ל-API נוצר עכשיו. כ-API שרת ה-proxy עובר במחזור החיים של הגדרה ופריסה איטרטיבית, מספר הגרסה במספרים שלמים. באמצעות קריאות API ישירות לפריסה, אפשר להגדיל את את מספר הגרסה של ה-Proxy ל-API. לפעמים, כשמבצעים שינויים קלים, לא רוצים את הגרסה הקודמת.
קבלת גרסה קודמת של API
גרסת ה-API (לדוגמה, api.company.com/v1
) אמורה להשתנות מאוד
לעיתים רחוקות. כשמשדרגים את גרסת ה-API, המשמעות היא למפתחים
שינוי משמעותי בחתימה של הממשק החיצוני שנחשפים על ידי ה-API.
התיקון של שרת ה-proxy ל-API הוא מספר מצטבר שמשויך לשרת proxy ל-API
הגדרה אישית. שירותי API מנהלים גרסאות קודמות של ההגדרות, כדי שתוכלו לבטל
את ההגדרה האישית כשמשהו משתבש. כברירת מחדל, הגרסה הקודמת של שרת proxy ל-API נקבעת באופן אוטומטי
מצטבר בכל פעם שמייבאים שרת proxy ל-API באמצעות ה-API לייבוא של שרת proxy ל-API. אם
אינך רוצה להגדיל את הגרסה של שרת proxy של API, השתמש בעדכון
גרסה של שרת ה-proxy ל-API. אם משתמשים ב-Maven לפריסה, צריך להשתמש ב-clean
או
update
אפשרויות, כפי שמתואר בפלאגין של Maven
Readme.
לדוגמה, אפשר לקרוא ל-method GET
בשרת proxy ל-API בגרסה 1 כדי לקבל תצוגה מפורטת.
curl -u EMAIL:PASSWORD -H "Accept:application/json" \ https://api.enterprise.apigee.com/v1/o/ORG_NAME/apis/weatherapi/revisions/1
תשובה לדוגמה
{ "configurationVersion" : { "majorVersion" : 4, "minorVersion" : 0 }, "contextInfo" : "Revision 1 of application weatherapi, in organization {org_name}", "createdAt" : 1343178905169, "createdBy" : "andrew@apigee.com", "lastModifiedAt" : 1343178905169, "lastModifiedBy" : "andrew@apigee.com", "name" : "weatherapi", "policies" : [ ], "proxyEndpoints" : [ ], "resources" : [ ], "revision" : "1", "targetEndpoints" : [ ], "targetServers" : [ ], "type" : "Application" }
רכיבי התצורה האלה של שרתי proxy ל-API מתועדים בפירוט בחומר העזר בנושא הגדרות של שרת proxy ל-API.
פריסת API סביבה
אחרי ששרת ה-proxy ל-API מוגדר לקבל בקשות ולהעביר אותן בצורה תקינה, אפשר לפרוס אותו
לסביבה אחת או יותר. בדרך כלל מבצעים איטרציה בשרתי proxy ל-API ב-test
, ואז, כשמוכנים,
אתה מקדם את הגרסה של שרת ה-proxy של ה-API ל-prod
. בדרך כלל, תגלו שיש עוד הרבה פיצ'רים
של proxy ל-API בסביבת הבדיקה, בעיקר מפני שתעשו הרבה פחות
בסביבת prod.
לא ניתן להפעיל שרת proxy של API לפני שהוא נפרס בסביבה. אחרי שצוברים
פרסה את הגרסה הקודמת של ה-proxy ל-API כדי ליצור, לאחר מכן אפשר לפרסם את כתובת ה-URL של prod
לגורמים חיצוניים
למפתחים.
איך להציג רשימה של סביבות
לכל ארגון ב-Apigee Edge יש לפחות שתי סביבות: test
ו-prod
.
היא שרירותית. המטרה היא לספק לכם אזור כדי לאמת ששרת ה-proxy ל-API
תקינה לפני שתפתחו אותו למפתחים חיצוניים.
כל סביבה היא למעשה כתובת רשת, וכך אפשר להפריד את תעבורת הנתונים בין שרתי ה-proxy ל-API שאתם עובדים עליהם, וכאלה שאפליקציות ניגשות אליהם בזמן הריצה.
הסביבות מספקות גם הפרדה בין נתונים ומשאבים. לדוגמה, אפשר להגדיר קבצים שמורים שונים ב-test and prod, שאפשר לגשת אליהם רק דרך שרתי proxy ל-API שמפעילים אותם הסביבה.
להציג את הסביבות ארגון
curl -u EMAIL:PASSWORD \ https://api.enterprise.apigee.com/v1/o/ORG_NAME/environments
תשובה לדוגמה
[ "test", "prod" ]
בדיקת הפריסות
פריסה היא גרסה של שרת proxy ל-API שנפרס בסביבה. ממשק API
שרת proxy שנמצא במצב פרוס נגיש דרך הרשת, בכתובות המוגדרות
את הרכיב <VirtualHost>
של הסביבה הזו.
פריסת שרתי proxy ל-API
אי אפשר להפעיל שרתי proxy ל-API לפני שנפרסו אותם. שירותי API חושפים ממשקי API מסוג RESTful שמספקים שליטה על תהליך הפריסה.
בכל רגע נתון ניתן לפרוס רק גרסה אחת של שרת proxy ל-API בסביבה. לכן צריך לבטל את הפריסה של הגרסה שנפרסה. יש לך אפשרות לקבוע אם החבילה החדשה תפרוס כגרסה חדשה או אם היא מחליפה את הגרסה הקיימת.
אתם צופים במסמכי העזרה של Apigee Edge.
כניסה למסמכי העזרה של Apigee X. info
קודם כול צריך לבטל את הפריסה של הגרסה הקיימת. מציינים את שם הסביבה ואת מספר הגרסה של שרת ה-proxy ל-API שרוצים לבטל את הפריסה שלו:
curl -X DELETE \ https://api.enterprise.apigee.com/v1/o/ORG_NAME/environments/ENV_NAME/apis/API_NAME/revisions/REVISION_NUMBER/deployments \ -u EMAIL:PASSWORD
לאחר מכן לפרוס את הגרסה החדשה. הגרסה החדשה של שרת ה-proxy ל-API כבר קיימת:
curl -X POST -H "Content-type:application/x-www-form-urlencoded" \ https://api.enterprise.apigee.com/v1/o/ORG_NAME/environments/ENV_NAME/apis/API_NAME/revisions/REVISION_NUMBER/deployments \ -u EMAIL:PASSWORD
פריסה חלקה (אפס זמן השבתה)
כדי לצמצם את הפוטנציאל לזמן השבתה במהלך הפריסה, צריך להשתמש בפרמטר override
בשיטת הפריסה ולהגדיר אותה ל-true
.
לא ניתן לפרוס גרסה אחת של שרת proxy ל-API מעל גרסה אחרת. הראשון תמיד צריך להיות
שלא נפרסו. אם מגדירים את override
לערך true
, מציינים שגרסה אחת
של שרת proxy ל-API צריך לפרוס בגרסה הקודמת שנפרסה. כתוצאה מכך
רצף הפריסה הפוך--הגרסה החדשה נפרסת, וברגע שהפריסה
הושלמה, והגרסה שכבר נפרסה לא פרוסה.
בדוגמה הבאה נקבע הערך של override
על ידי העברתו כפרמטר של טופס:
curl -X POST -H "Content-type:application/x-www-form-urlencoded" \ https://api.enterprise.apigee.com/v1/o/ORG_NAME/e/ENV_NAME/apis/API_NAME/revisions/REVISION_NUMBER/deployments" \ -d "override=true" \ -u EMAIL:PASSWORD
כדי לבצע אופטימיזציה נוספת של הפריסה, אפשר להגדיר את הפרמטר delay
.
הפרמטר delay
מציין מרווח זמן בשניות, שלפניו
צריך לבטל את הפריסה של הגרסה הקודמת. כתוצאה מכך, לעסקאות בזמן אמת יש מרווח זמן
איזון יש להשלים לפני ששרת ה-proxy ל-API שמעבד את העסקה שלהם יוסר. מעקב אחר הוא
מה קורה עם override=true
ועם קבוצת הפרמטר delay
:
- גרסה 1 מטפלת בבקשות.
- אנחנו פורסים את גרסה 2 במקביל.
- כשגרסה 2 נפרסת במלואה, תנועה חדשה נשלחת לגרסה 2. אין תנועה חדשה נשלח לגרסה 1.
- עם זאת, יכול להיות שגרסה 1 עדיין מעבדת עסקאות קיימות. על ידי הגדרה של
delay
(לדוגמה, 15 שניות), נותנים לגרסה 1 15 שניות לסיים את העיבוד של עסקאות קיימות. - לאחר פרק הזמן של ההשהיה, הפריסה של גרסה 1 תבוטל.
curl -X POST -H "Content-type:application/x-www-form-urlencoded" \ https://api.enterprise.apigee.com/v1/o/ORG_NAME/e/ENV_NAME/apis/API_NAME/revisions/REVISION_NUMBER/deployments?delay=15" \ -d "override=true" \ -u EMAIL:PASSWORD
פרמטר שאילתה | תיאור |
---|---|
override |
ברירת המחדל היא יש להגדיר ל- |
delay |
כדי לאפשר עיבוד עסקאות להסתיים בגרסה הקיימת לפני ש
לא נפרסו – ולבטל את האפשרות של ברירת המחדל היא 0 (אפס) שניות. כאשר המדיניות |
כשמשתמשים ב-override=true
יחד עם delay
, HTTP 5XX
אפשר לבטל את התגובות במהלך הפריסה. הסיבה לכך היא ששתי הגרסאות של שרת ה-proxy ל-API י
נפרסה בו-זמנית, כשהגרסה הישנה יותר לא פרוסה לאחר העיכוב.
הצגת כל הפריסות של API גרסה קודמת
לפעמים צריך לאחזר רשימה של כל גרסאות ה-API שנפרסו כרגע. שרת proxy.
curl https://api.enterprise.apigee.com/v1/o/ORG_NAME/apis/weatherapi/revisions/1/deployments \ -u EMAIL:PASSWORD
{ "aPIProxy" : "weatherapi", "environment" : [ { "configuration" : { "basePath" : "", "steps" : [ ] }, "name" : "test", "server" : [ { "status" : "deployed", "type" : [ "message-processor" ], "uUID" : "90096dd1-1019-406b-9f42-fbb80cd01200" }, { "status" : "deployed", "type" : [ "message-processor" ], "uUID" : "7d6e2eb1-581a-4db0-8045-20d9c3306549" }, { "status" : "deployed", "type" : [ "router" ], "uUID" : "1619e2d7-c822-45e0-9f97-63882fb6a805" }, { "status" : "deployed", "type" : [ "router" ], "uUID" : "8a5f3d5f-46f8-4e99-b4cc-955875c8a8c8" } ], "state" : "deployed" } ], "name" : "1", "organization" : "org_name" }
התשובה שלמעלה מכילה מאפיינים רבים שספציפיים לתשתית הפנימית של Apigee קצה. אם אתם לא משתמשים ב-Apigee Edge בארגון, אי אפשר לשנות את ההגדרות האלה.
המאפיינים החשובים שכלולים בתשובה הם organization
,
environment
, aPIProxy
, name
וגם state
. על ידי
על ידי בדיקת ערכי המאפיינים האלו, תוכל לאשר שגרסה ספציפית של שרת proxy ל-API
שנפרסו בסביבה.
הצגת כל הפריסות ב סביבת בדיקה
ניתן גם לאחזר את סטטוס הפריסה של סביבה ספציפית (כולל הגרסה הקודמת של שרת ה-proxy ל-API שנפרס כרגע) באמצעות הקריאה הבאה:
curl -u EMAIL:PASSWORD https://api.enterprise.apigee.com/v1/o/ORG_NAME/environments/test/deployments
הפעולה הזו תחזיר את אותה התוצאה שלמעלה לכל API שנפרס בסביבת הבדיקה
הצגת כל הפריסות ב- ארגון
כדי לאחזר רשימה של כל הגרסאות הקודמות שנפרסו כרגע לכל שרתי ה-proxy ל-API בכל הסביבות, משתמשים ב-method הבא של ה-API:
curl https://api.enterprise.apigee.com/v1/o/ORG_NAME/deployments \ -u EMAIL:PASSWORD
הפעולה הזו תחזיר את אותה התוצאה שתיארנו למעלה לכל שרתי ה-proxy ל-API שנפרסו בכל הסביבות.
מכיוון שה-API הוא RESTful, אפשר פשוט להשתמש ב-method POST
, יחד עם JSON או XML
מטען ייעודי (payload) מול אותו משאב כדי ליצור שרת proxy ל-API.
נוצר פרופיל עבור ה-Proxy ל-API. ייצוג ברירת המחדל של שרת proxy ל-API הוא
סימון אובייקטים ב-JavaScript (JSON). למטה מופיעה תגובת ברירת המחדל של JSON לבקשת POST
שלמעלה:
שיצרה Proxy ל-API בשם weatherapi
. תיאור של כל רכיב בפרופיל
ככה:
{ "configurationVersion" : { "majorVersion" : 4, "minorVersion" : 0 }, "contextInfo" : "Revision 1 of application weatherapi, in organization {org_name}", "createdAt" : 1357172145444, "createdBy" : "you@yourcompany.com", "displayName" : "weatherapi", "lastModifiedAt" : 1357172145444, "lastModifiedBy" : "you@yourcompany.com", "name" : "weatherapi", "policies" : [ ], "proxyEndpoints" : [ ], "resources" : [ ], "revision" : "1", "targetEndpoints" : [ ], "targetServers" : [ ], "type" : "Application" }
פרופיל ה-Proxy ל-API שנוצר מדגים את המבנה המלא של API שרת proxy:
APIProxy revision
: הגרסה הממוספרת של שרת ה-proxy ל-API תצורה, כפי שמתוחזק על ידי שירותי APIAPIProxy name
: השם הייחודי של שרת ה-proxy ל-APIConfigurationVersion
: הגרסה של שירותי ה-API שאליה שרת ה-proxy של ה-API תואמת להגדרות האישיותCreatedAt
: השעה שבה נוצר שרת ה-proxy ל-API, בפורמט של זמן UNIXCreatedBy
: כתובת האימייל של משתמש Apigee Edge שיצר את ה-API שרת proxyDisplayName
: שם ידידותי למשתמש לשרת ה-proxy ל-APILastModifiedAt
: השעה שבה נוצר שרת ה-proxy ל-API, בפורמט UNIX שעהLastModifiedBy
: כתובת האימייל של משתמש Apigee Edge שיצר את ה-API שרת proxyPolicies
: רשימה של כללי מדיניות שנוספו לשרת ה-proxy הזה ל-APIProxyEndpoints
: רשימה של ProxyEndpointsResources
: רשימת המשאבים הזמינים (JavaScript, Python, Java, XSST) יופעלו בשרת ה-proxy הזה ל-APITargetServers
: רשימה של שרתי TargetServer בעלי שם (שאפשר ליצור באמצעות management API), משמש בהגדרות מתקדמות למטרות איזון עומסיםTargetEndpoints
: רשימה של נקודות TargetEndpoints
חשוב לשים לב שהרבה מהרכיבים של תצורת ה-Proxy ל-API נוצרו באמצעות רכיב ה-POST
הפשוט
ה-methods שלמעלה ריקות. בנושאים הבאים נסביר איך להוסיף ולהגדיר מפתח
רכיבים של שרת proxy ל-API.
ניתן גם לקרוא על רכיבי התצורה האלה בחומר העזר בנושא הגדרות של שרת proxy ל-API.
כתיבת סקריפטים ל-API
באמצעות שרתי proxy לדוגמה של API, שזמין ב-GitHub מספקים סקריפטים של מעטפת שעוטפים את כלי הפריסה של Apigee. אם מסיבה כלשהי לא ניתן להשתמש בכלי הפריסה של Python, אז תוכלו לקרוא ישירות ל-API. שתי הגישות שאפשר לראות בסקריפטים לדוגמה שבהמשך.
גלישת את כלי הפריסה
קודם כל, צריך לוודא שכלי הפריסה של Python בסביבה המקומית שלכם.
לאחר מכן יוצרים קובץ לשמירת פרטי הכניסה שלכם. הסקריפטים של הפריסה שתכתוב ייובאו
את ההגדרות האלה, וכך תוכלו לנהל בצורה מרוכזת את פרטי הכניסה של החשבון. ב-API
דוגמת פלטפורמה, הקובץ הזה נקרא setenv.sh
.
#!/bin/bash org="Your ORG on enterprise.apigee.com" username="Your USERNAME on enterprise.apigee.com" # While testing, it's not necessary to change the setting below env="test" # Change the value below only if you have an on-premise deployment url="https://api.enterprise.apigee.com" # Change the value below only if you have a custom domain api_domain="apigee.net" export org=$org export username=$username export env=$env export url=$url export api_domain=$api_domain
הקובץ שלמעלה הופך את כל ההגדרות שלך לזמינות לסקריפטים של המעטפת שעוטפים את הפריסה של Google.
עכשיו יוצרים סקריפט מעטפת שמייבא את ההגדרות האלה ומשתמש בהן כדי לקרוא לכלי הפריסה. (לדוגמה, דוגמאות של פלטפורמות API של Apigee).
#!/bin/bash source path/to/setenv.sh echo "Enter your password for the Apigee Enterprise organization $org, followed by [ENTER]:" read -s password echo Deploying $proxy to $env on $url using $username and $org path/to/deploy.py -n {api_name} -u $username:$password -o $org -h $url -e $env -p / -d path/to/apiproxy
כדי להקל עליכם, צרו גם סקריפט להפעלה ולבדיקה של ה-API, ככה:
#!/bin/bash
echo Using org and environment configured in /setup/setenv.sh
source /path/to/setenv.sh
set -x
curl "http://$org-$env.apigee.net/{api_basepath}"
הפעלה ישירה של ה-API
כדאי לכתוב סקריפטים פשוטים של מעטפת שהופכים את תהליך ההעלאה לאוטומטי בפריסה של שרתי proxy ל-API.
הסקריפט שבהמשך מפעיל ישירות את ה-Management API. היא מבטלת את הפריסה של הגרסה הקיימת של
שרת ה-proxy ל-API שמעדכנים, יוצר קובץ ZIP מהספרייה /apiproxy
שמכיל את קובצי התצורה של שרת ה-proxy, ולאחר מכן מעלה, מייבאת ופורס את
הגדרה אישית.
#!/bin/bash #This sets the name of the API proxy and the basepath where the API will be available api=api source /path/to/setenv.sh echo Delete the DS_store file on OSX echo find . -name .DS_Store -print0 | xargs -0 rm -rf find . -name .DS_Store -print0 | xargs -0 rm -rf echo "Enter your password for the Apigee Enterprise organization $org, followed by [ENTER]:" read -s password echo Undeploy and delete the previous revision # Note that you need to explicitly update the revision to be undeployed. # One benefit of the Python deploy tool is that it manages this for you. curl -k -u $username:$password "$url/v1/o/$org/e/$env/apis/$api/revisions/1/deployments" -X DELETE curl -k -u $username:$password -X DELETE "$url/v1/o/$org/apis/$api/revisions/1" rm -rf $api.zip echo Create the API proxy bundle and deploy zip -r $api.zip apiproxy echo Import the new revision to $env environment curl -k -v -u $username:$password "$url/v1/o/$org/apis?action=import&name=$api" -T $api.zip -H "Content-Type: application/octet-stream" -X POST echo Deploy the new revision to $env environment curl -k -u $username:$password "$url/v1/o/$org/e/$env/apis/$api/revisions/1/deployments" -X POST