אתם צופים במסמכי התיעוד של Apigee Edge.
כניסה למסמכי העזרה של Apigee X. info

המדיניות 'מניעת עליות חדות בנפח התנועה' מגינה מפני עליות חדות בנפח התנועה באמצעות הרכיב <Rate>
. הרכיב הזה מגביל את מספר הבקשות שמעובדות על ידי שרת proxy של API ונשלחות לקצה העורפי, כדי להגן מפני השהיות בביצועים וזמן השבתה.
רכיב <SpikeArrest>
הגדרת המדיניות בנושא מניעת עלייה חדה בתנועה.
ערך ברירת המחדל | בכרטיסייה מדיניות ברירת מחדל שבהמשך |
חובה? | אופציונלי |
סוג | אובייקט מורכב |
רכיב הורה | לא רלוונטי |
רכיבי הצאצאים |
<Identifier> <MessageWeight> <Rate> (חובה)<UseEffectiveCount> |
תחביר
רכיב <SpikeArrest>
כולל את התחביר הבא:
<SpikeArrest continueOnError="[false|true]" enabled="[true|false]" name="policy_name" > <DisplayName>display_name</DisplayName> <Properties/> <Identifier ref="flow_variable"/> <MessageWeight ref="flow_variable"/> <Rate ref="flow_variable">rate[pm|ps]</Rate> <UseEffectiveCount>[false|true]</UseEffectiveCount> </SpikeArrest>
מדיניות ברירת המחדל
בדוגמה הבאה מוצגות הגדרות ברירת המחדל כשמוסיפים מדיניות של מניעת התקפי פסגה לתהליך בממשק המשתמש של Edge:
<SpikeArrest async="false" continueOnError="false" enabled="true" name="Spike-Arrest-1"> <DisplayName>Spike Arrest-1</DisplayName> <Properties/> <Identifier ref="request.header.some-header-name"/> <MessageWeight ref="request.header.weight"/> <Rate>30ps</Rate> <UseEffectiveCount>true</UseEffectiveCount> </SpikeArrest>
לרכיב הזה יש את המאפיינים הבאים, המשותפים לכל כללי המדיניות:
מאפיין | ברירת מחדל | חובה? | תיאור |
---|---|---|---|
name |
לא רלוונטי | נדרש |
השם הפנימי של המדיניות. הערך של המאפיין אפשר להשתמש ברכיב |
continueOnError |
false | אופציונלי | צריך להגדיר את הערך 'False' כדי להחזיר שגיאה כשהמדיניות נכשלת. זו התנהגות צפויה ברוב סוגי המדיניות. הערך של הפרמטר הוא TRUE כדי שביצוע הפעולות יתבצע גם אחרי שמדיניות תיכשל. |
enabled |
true | אופציונלי | כדי לאכוף את המדיניות צריך להגדיר את הערך True. מגדירים את המדיניות כ-"false" כדי "להשבית" את המדיניות. המדיניות הזו לא תיאכף גם אם היא תצורף לתהליך. |
async |
false | הוצא משימוש | המאפיין הזה הוצא משימוש. |
דוגמאות
בדוגמאות הבאות מפורטות כמה מהדרכים שבהן אפשר להשתמש במדיניות 'מניעת עלייה חדה בתנועה':
דוגמה 1
בדוגמה הבאה מוגדר הקצב לחמש בקשות לשנייה:
<SpikeArrest name="Spike-Arre>st-<1&qu>ot;< Ra>t<e5ps/Rate /S>pikeArrest
המדיניות מאפשרת שליחת בקשה אחת בכל 200 אלפיות שנייה (1000/5).
דוגמה 2
בדוגמה הבאה מוגדר הקצב ל-300 בקשות לדקה:
<SpikeArrest async="false" continueOnError="false" enabled=">tru<e" name="SpikeAr<reast" > D<ispl>ayNam<e&>;<gtSpikeArrea>st/DisplayName Rate300pm/Rate /SpikeArrest
הקצב בפועל הוא 300 פריטים לדקה, כלומר אסימון חדש מתווסף לקטגוריה כל 200 אלפיות השנייה. גודל הקטגוריה מוגדר תמיד ל-10% מ-messagesPerPeriod
. לכן, כשהערך של messagesPerPeriod
הוא 300, גודל הקטגוריה הוא 30 אסימונים.
דוגמה 3
בדוגמה הבאה, הבקשות מוגבלות ל-12 בדקה (בקשה אחת מותר לשלוח כל חמש שניות, או 60/12):
<SpikeArrest name="Spike-Arre>st-<1&qu>ot; < Rat>e12<pm/Rate Identifier ref=&qu>ot;<client_id" / MessageWeight ref=">;<request.head>er.weight" / /SpikeArrest
בנוסף, הרכיב <MessageWeight>
מקבל ערך מותאם אישית (הכותרת weight
) שמאפשר לשנות את משקל ההודעות לאפליקציות או ללקוחות ספציפיים. כך אפשר לשלוט בצורה יעילה יותר בבקרת הקצב של ישויות שמזוהות באמצעות הרכיב <Identifier>
.
דוגמה 4
בדוגמה הבאה מצוין שהמערכת תצטרך לחפש ערך בסביבת זמן הריצה שהוגדר באמצעות הבקשה שמועברת כמשתנה התהליך request.header.runtime_rate
:
<SpikeArrest name="Spike-Arre>st-<1" Rate ref="request.header.>r<untime_rate&>quot; / /SpikeArrest
הערך של משתנה הזרימה חייב להיות בפורמט intpm
או
intps
.
כדי לנסות את הדוגמה הזו, מריצים בקשה כמו זו:
curl http://myorg-myenv.apigee.net/price -H 'runtime_rate:30ps'
הפניה לרכיב הצאצא
בקטע הזה מתוארים רכיבי הצאצאים של <SpikeArrest>
.
<DisplayName>
אפשר להשתמש במאפיין name
כדי לתייג את המדיניות בכלי העריכה של שרת ה-proxy בממשק המשתמש לניהול, בשם שונה שנשמע טבעי יותר.
הרכיב <DisplayName>
הוא משותף לכל כללי המדיניות.
ערך ברירת המחדל | לא רלוונטי |
חובה? | אופציונלי. אם משמיטים את <DisplayName> , המערכת משתמשת בערך של המאפיין name של המדיניות |
סוג | מחרוזת |
רכיב הורה | <PolicyElement> |
רכיבי הצאצאים | ללא |
רכיב <DisplayName>
כולל את התחביר הבא:
תחביר
<PolicyElement> <DisplayName>policy_display_name</DisplayName> ... </PolicyElement>
דוגמה
<PolicyElement> <DisplayName>My Validation Policy</DisplayName> </PolicyElement>
לאלמנט <DisplayName>
אין מאפיינים או רכיבי צאצא.
<Identifier>
מאפשרת לבחור איך לקבץ את הבקשות כדי שאפשר יהיה להחיל את המדיניות של Spike Arrest על סמך הלקוח. לדוגמה, אפשר לקבץ בקשות לפי מזהה מפתח. במקרה כזה, כל בקשה של מפתח תצורף לשיעור החסימה של התקפי פסגה שלו, ולא כל הבקשות לשרת proxy.
משתמשים בו בשילוב עם הרכיב <MessageWeight>
כדי לקבל שליטה מפורטת יותר על הגבלת הקצב של בקשות.
אם משאירים את הרכיב <Identifier>
ריק, מופעלת הגבלת קצב אחת לכל הבקשות שנשלחות לשרת ה-API הזה.
ערך ברירת המחדל | לא רלוונטי |
חובה? | אופציונלי |
סוג | מחרוזת |
רכיב הורה |
<SpikeArrest>
|
רכיבי הצאצאים | ללא |
תחביר
<SpikeArrest continueOnError="[false|true]" enabled="[true|false]" > na<me="policy_name" I>d<entifier ref>="flow_variable"/ /SpikeArrest
דוגמה 1
בדוגמה הבאה, המדיניות של מניעת עלייה חדה חלה לפי מזהה מפתח:
<SpikeArrest name="Spike-Arre>st-<1" Identifier ref=">;de<velo>per.<id&quo>t<;/ Rate42p>m/Rate/ /SpikeArrest
בטבלה הבאה מתוארים המאפיינים של <Identifier>
:
מאפיין | תיאור | ברירת מחדל | נוכחות |
---|---|---|---|
ref |
המשתנה שמשמש את Spike Arrest לקבץ בקשות נכנסות. אפשר להשתמש בכל משתנה תהליך כדי לציין לקוח ייחודי, כמו אלה שזמינים במדיניות VerifyAPIKey. אפשר גם להגדיר משתנים מותאמים אישית באמצעות מדיניות JavaScript או מדיניות AssignMessage. | לא רלוונטי | חובה |
הרכיב הזה מתואר גם בפוסט הבא בקהילה של Apigee: http://community.apigee.com/questions/2807/how-does-the-edge-quota-policy-work-when-no-identi.html.
<MessageWeight>
קובע את המשקל שהוגדר לכל הודעה. משקל ההודעה משמש לשינוי ההשפעה של בקשה אחת על החישוב של שיעור ההפסקה של התקפות פסגה. משקל ההודעה יכול להיות כל משתנה תהליך, כמו כותרת HTTP, פרמטר של שאילתה, פרמטר של טופס או תוכן של גוף ההודעה. אפשר גם להשתמש במשתנים מותאמים אישית באמצעות מדיניות JavaScript או מדיניות AssignMessage.
משתמשים בו בשילוב עם <Identifier>
כדי להגביל עוד יותר את הבקשות לפי לקוחות או אפליקציות ספציפיים.
לדוגמה, אם הערך של Spike Arrest <Rate>
הוא 10pm
, ואפליקציה שולחת בקשות עם משקל של 2
, מותר לשלוח מהלקוח הזה רק חמש הודעות בדקה כי כל בקשה נספרת כ-2.
ערך ברירת המחדל | לא רלוונטי |
חובה? | אופציונלי |
סוג | מספר שלם |
רכיב הורה |
<SpikeArrest>
|
רכיבי הצאצאים | ללא |
תחביר
<SpikeArrest continueOnError="[false|true]" enabled="[true|false]" > na<me="policy_name" Mess>a<geWeight ref>="flow_variable"/ /SpikeArrest
דוגמה 1
בדוגמה הבאה, הבקשות מוגבלות ל-12 בדקה (בקשה אחת מותר לשלוח כל חמש שניות, או 60/12):
<SpikeArrest name="Spike-Arre>st-<1&qu>ot; < Rat>e12<pm/Rate Identifier ref=&qu>ot;<client_id" / MessageWeight ref=">;<request.head>er.weight" / /SpikeArrest
בדוגמה הזו, השדה <MessageWeight>
מקבל ערך מותאם אישית (הכותרת weight
בבקשה) שמתאים את משקלי ההודעות ללקוחות ספציפיים. כך אפשר לשלוט בצורה יעילה יותר בבקרת הקצב של ישויות שמזוהות באמצעות הרכיב <Identifier>
.
בטבלה הבאה מתוארים המאפיינים של <MessageWeight>
:
מאפיין | תיאור | נוכחות | ברירת מחדל |
---|---|---|---|
ref |
מזהה את משתנה התהליך שמכיל את משקל ההודעה של הלקוח הספציפי. זה יכול להיות כל משתנה תהליך, כמו פרמטר של שאילתה ב-HTTP, כותרת או תוכן גוף ההודעה. למידע נוסף, ראו חומר עזר בנושא משתני תהליך. אפשר גם להגדיר משתנים מותאמים אישית באמצעות מדיניות JavaScript או מדיניות AssignMessage. | חובה | לא רלוונטי |
<Rate>
ההגדרה קובעת את הקצב שבו מגבילים את העליות החדות (או הפיקים) בתעבורת הנתונים, על ידי הגדרת מספר הבקשות שמותר לשלוח במרווחי זמן של דקה או שנייה. אפשר גם להשתמש ברכיב הזה בשילוב עם <Identifier>
ו-<MessageWeight>
כדי לקבל ערכים מהלקוח ולצמצם את נפח התנועה בצורה חלקה במהלך זמן הריצה.
ערך ברירת המחדל | לא רלוונטי |
חובה? | חובה |
סוג | מספר שלם |
רכיב הורה |
<SpikeArrest>
|
רכיבי הצאצאים | ללא |
תחביר
אפשר לציין את השיעורים באחת מהדרכים הבאות:
- שיעור סטטי שציינתם כגוף של רכיב
<Rate>
- ערך משתנה, שאפשר להעביר על ידי הלקוח. מזינים את השם של משתנה התהליך באמצעות המאפיין
ref
.
<SpikeArrest continueOnError="[false|true]" enabled="[true|false]" > na<me="policy_name&quo>t; Rate <ref=&>q<uot;flow_var>iable"rate[pm|ps]/Rate /SpikeArrest
ערכי התעריף התקינים (שמוגדרים כערך משתנה או בגוף הרכיב) חייבים לעמוד בפורמט הבא:
intps
(מספר הבקשות לשנייה, משוחרר במרווחים של אלפיות שנייה)intpm
(מספר הבקשות לדקה, משוחרר בחלוקה למרווחי שניות)
הערך של int חייב להיות מספר שלם חיובי שאינו אפס.
דוגמה 1
בדוגמה הבאה מוגדר קצב של חמש בקשות לשנייה:
<SpikeArrest name="Spike-Arre>st-<1&qu>ot;< Ra>t<e5ps/Rate /S>pikeArrest
המדיניות מאפשרת שליחת בקשה אחת בכל 200 אלפיות שנייה (1000/5).
דוגמה 2
בדוגמה הבאה מוגדר הקצב ל-12 בקשות לדקה:
<SpikeArrest async="false" continueOnError="false" enabled=">tru<e" name="SpikeAr<reast" > D<ispl>ayNam<e&>;<gtSpikeArrea>st/DisplayName Rate300pm/Rate /SpikeArrest
מדיניות הדוגמה הזו מאפשרת שליחת בקשה אחת בכל 5 שניות (60/12).
בטבלה הבאה מתוארים המאפיינים של <Rate>
:
מאפיין | תיאור | נוכחות | ברירת מחדל |
---|---|---|---|
ref |
מזהה משתנה תהליך שמציין את הקצב. זה יכול להיות כל משתנה תהליך, כמו פרמטר של שאילתה ב-HTTP, כותרת או תוכן גוף ההודעה, או ערך כמו KVM. מידע נוסף זמין במאמר חומר עזר בנושא משתני תהליך.
אפשר גם להשתמש במשתנים מותאמים אישית באמצעות מדיניות JavaScript או מדיניות AssignMessage. אם מגדירים גם את לדוגמה: <Rate ref="request.header.custom_>rat<e&quo>t;1pm/Rate בדוגמה הזו, אם הלקוח לא מעביר כותרת custom_rate, הקצב של שרת ה-proxy של ה-API הוא בקשה אחת לדקה לכל הלקוחות. אם הלקוח מעביר כותרת custom_rate, מגבלת הקצב תהיה 10 בקשות לשנייה לכל הלקוחות בשרת ה-proxy, עד שנשלחת בקשה ללא הכותרת custom_rate. אפשר להשתמש ב- אם מציינים ערך ל- |
אופציונלי | לא רלוונטי |
<UseEffectiveCount>
המערכת מחלקת את מספרי מניעת הפסקות הזמניות (Spike Arrest) בין מעבדי ההודעות (MPs) כשמשתמשים בקבוצות עם התאמה אוטומטית לעומס.
תחביר
<SpikeArrest continueOnError="[false|true]" enabled="[true|false]" > na<me="policy_n>ame" < UseEffectiveCount>[<false|true]/>UseEffectiveCount /SpikeArrest
דוגמה 1
בדוגמה הבאה, הערך של <UseEffectiveCount>
מוגדר כ-true:
<SpikeArrest name='Spike-Arres>t-1<'>; <Rate4>0ps</Rate UseEffect>iveC<ounttrue/UseEffect>i<veCount /Spi>keArrest
הרכיב <UseEffectiveCount>
הוא אופציונלי. ערך ברירת המחדל הוא false
כשהרכיב לא נכלל במדיניות שלכם לטיפול בתנודות חדות בביקוש.
ערך ברירת המחדל | לא נכון |
חובה? | אופציונלי |
סוג | בוליאני |
רכיב הורה |
<SpikeArrest>
|
רכיבי הצאצאים | ללא |
בטבלה הבאה מתוארים המאפיינים של הרכיב <UseEffectiveCount>
:
מאפיין | תיאור | ברירת מחדל | נוכחות |
---|---|---|---|
ref |
מזהה את המשתנה שמכיל את הערך של <UseEffectiveCount> . זה יכול להיות כל משתנה תהליך, כמו פרמטר של שאילתה ב-HTTP, כותרת או תוכן גוף ההודעה. למידע נוסף, ראו חומר עזר בנושא משתני תהליך. אפשר גם להגדיר משתנים מותאמים אישית באמצעות מדיניות JavaScript או מדיניות AssignMessage. |
לא רלוונטי | אופציונלי |
ההשפעה של <UseEffectiveCount>
תלויה בערך שלו:
true
: המגבלה על שיעור העלייה החדה של יצירת בקשות (spike) של מכונה וירטואלית היא<Rate>
חלקי המספר הנוכחי של מכונות וירטואליות באותו אשכול. המגבלה המצטברת היא הערך של<Rate>
. כשמוסיפים (או מסירים) מודעות פרוגרמטיות באופן דינמי, המגבלות שלהן על קצב הבקשות בזמני שיא גדלות (או יורדות), אבל המגבלה הכוללת לא משתנה.false
(זהו ערך ברירת המחדל אם לא צוין): המגבלה על קצב העלייה החדה של כל מודעה היא פשוט הערך של<Rate>
שלה. המגבלה הכוללת היא הסכום של כל השיעורים של כל ה-MPs. כשמוסיפים (או מסירים) מודעות פרוגרמטיות, המגבלות שלהן על קצב העלייה החדה לא משתנות, אבל המגבלה הכוללת גדלה (או קטנה).
בטבלה הבאה מוצגת ההשפעה של <UseEffectiveCount>
על המגבלה בפועל של קצב שליחת הבקשות לכל MP:
הערך של <UseEffectiveCount> |
||||||
---|---|---|---|---|---|---|
false |
false |
false |
true |
true |
true |
|
מספר חברי הפרלמנט | 8 | 4 | 2 | 8 | 4 | 2 |
הערך של <Rate> |
10 | 10 | 10 | 40 | 40 | 40 |
שיעור אפקטיבי לכל אלף חשיפות | 10 | 10 | 10 | 5 | 10 | 20 |
מגבלת נתונים מצטברים | 80 | 40 | 20 | 40* | 40* | 40* |
* זהה ל-<Rate> . |
בדוגמה הזו, שימו לב שכאשר מספר המשתתפים קטן מ-4 ל-2, ו-<UseEffectiveCount>
הוא false
, הקצב האפקטיבי לכל משתתף נשאר ללא שינוי (10). לעומת זאת, כש-<UseEffectiveCount>
הוא true
, השיעור האפקטיבי לכל חבר פרלמנט עולה מ-10 ל-20 כשמספר חברי הפרלמנט יורד מ-4 ל-2.
משתני תהליך
כשמדיניות של Spike Arrest פועלת, משתנה התהליך הבא מאוכלס:
משתנה | סוג | הרשאה | תיאור |
---|---|---|---|
ratelimit.policy_name.failed |
בוליאני | הרשאת קריאה בלבד | מציין אם המדיניות נכשלה או לא (true או
false ). |
מידע נוסף זמין במאמר חומר עזר בנושא משתני תהליך.
הפניה לשגיאה
This section describes the fault codes and error messages that are returned and fault variables that are set by Edge when this policy triggers an error. This information is important to know if you are developing fault rules to handle faults. To learn more, see What you need to know about policy errors and Handling faults.
Runtime errors
These errors can occur when the policy executes.
Fault code | HTTP status | Cause | Fix |
---|---|---|---|
policies.ratelimit.FailedToResolveSpikeArrestRate |
500 |
This error occurs if the reference to the variable containing the rate setting
within the <Rate> element cannot be resolved to a value within the Spike Arrest
policy. This element is mandatory and used to specify the spike arrest rate in
the form of intpm or intps . |
build |
policies.ratelimit.InvalidMessageWeight |
500 |
This error occurs if the value specified for the <MessageWeight> element through
a flow variable is invalid (a non-integer value). |
build |
policies.ratelimit.SpikeArrestViolation |
429 |
The rate limit was exceeded. |
Deployment errors
These errors can occur when you deploy a proxy containing this policy.
Error name | Cause | Fix |
---|---|---|
InvalidAllowedRate |
If the spike arrest rate specified in the <Rate> element of the Spike Arrest
Policy is not an integer or if the rate does not have ps or pm as a suffix,
then the deployment of the API proxy fails. |
build |
Fault variables
These variables are set when a runtime error occurs. For more information, see What you need to know about policy errors.
Variables | Where | Example |
---|---|---|
fault.name="fault_name" |
fault_name is the name of the fault, as listed in the Runtime errors table above. The fault name is the last part of the fault code. | fault.name Matches "SpikeArrestViolation" |
ratelimit.policy_name.failed |
policy_name is the user-specified name of the policy that threw the fault. | ratelimit.SA-SpikeArrestPolicy.failed = true |
Example error response
Shown below is an example error response:
{ "fault":{ "detail":{ "errorcode":"policies.ratelimit.SpikeArrestViolation" }, "faultstring":"Spike arrest violation. Allowed rate : 10ps" } }
Example fault rule
Shown below is an example fault rule to handle a SpikeArrestViolation
fault:
<FaultRules> <FaultRule name="Spike Arrest Errors"> <Step> <Name>JavaScript-1</Name> <Condition>(fault.name Matches "SpikeArrestViolation") </Condition> </Step> <Condition>ratelimit.Spike-Arrest-1.failed=true</Condition> </FaultRule> </FaultRules>
קוד הסטטוס הנוכחי של HTTP לחריגה ממגבלת קצב שהוגדר על ידי מדיניות מכסה או מדיניות לעיכוב התקפות חירום הוא 429
(יותר מדי בקשות). כדי לשנות את קוד הסטטוס של ה-HTTP ל-500
(שגיאה פנימית בשרת), מגדירים את המאפיין features.isHTTPStatusTooManyRequestEnabled
לערך false
באמצעות ה-API
Update organization properties.
לדוגמה:
curl -u email:password -X POST -H "Content-type:application/xml" http://api.enterprise.apigee.com/v1/organizations/my<org -d \ "Organization type="trial&qu>ot; n<ame=">MyOrganiz<ation" Properties Property name="fea>ture<s.isHTTPS>tatusTooManyRequest<Enabled&quo>t<;true/Propert>y . . . /Properties /Organization"
סכימות
כל סוג מדיניות מוגדר על ידי סכימת XML (.xsd
). לידיעתכם, סכמות המדיניות זמינות ב-GitHub.
נושאים קשורים
- Quota policy: מדיניות מכסות, כדי להגביל את התנועה בלקוחות נפרדים
- הגבלת קצב של יצירת בקשות למידע כללי על הגבלת קצב
- השוואה בין מדיניות המכסות לבין מדיניות SpikeArrest
- דוגמאות עובדות של שרתי proxy ל-API