במאמר הזה מוסבר איך משתמשים בבקרת בו-זמניות עם הודעות שמתפרסמות בנושא.
בקרת בו-זמניות עוזרת לכם לשנות את מספר ברירת המחדל של השרשורים ברקע (קלט/פלט) שספריית הלקוח משתמשת בהם כדי לפרסם הודעות. כך לקוחות המוציאים לאור יכולים לשלוח הודעות במקביל.
בקרת בו-זמניות היא תכונה זמינה בספריית הלקוח ברמה גבוהה של Pub/Sub. אפשר גם להטמיע בקרת בו-זמניות משלכם כשמשתמשים בספרייה ברמה נמוכה.
התמיכה בבקרת בו-זמניות תלויה בשפת התכנות של ספריית הלקוח. בשפות תכנות שתומכות בשרשורים מקבילים, כמו C++, Go ו-Java, ספריות הלקוח בוחרות כברירת מחדל את מספר השרשורים.
בדף הזה מוסבר על הרעיון של בקרת בו-זמניות ואיך מגדירים את התכונה הזו ללקוחות שלכם שהם בעלי אתרים. כדי להגדיר את לקוחות האפליקציות הרשומות שלכם לבקרת בו-זמניות, אפשר לעיין במאמר בנושא עיבוד של יותר הודעות באמצעות בקרת בו-זמניות.
לפני שמתחילים
לפני שמגדירים את תהליך העבודה של הפרסום, צריך לוודא שביצעתם את המשימות הבאות:
התפקידים הנדרשים
כדי לקבל את ההרשאות שנדרשות לפרסום הודעות בנושא, צריך לבקש מהאדמין להקצות לכם ב-IAM את התפקיד פרסום הודעות ב-Pub/Sub (roles/pubsub.publisher) בנושא.
כדי לקרוא הסבר על מתן תפקידים, ראו איך מנהלים את הגישה ברמת הפרויקט, התיקייה והארגון.
יכול להיות שאפשר לקבל את ההרשאות הנדרשות גם באמצעות תפקידים בהתאמה אישית או תפקידים מוגדרים מראש.
כדי ליצור או לעדכן נושאים ומינויים, צריך הרשאות נוספות.
הגדרות של בקרת בו-זמניות
ערכי ברירת המחדל של משתני בקרת בו-זמניות והשמות של המשתנים עשויים להיות שונים בספריות לקוח שונות. לדוגמה, בספריית הלקוח של Java, השיטות להגדרת בקרת בו-זמניות הן setExecutorProvider() ו-setChannelProvider(). מידע נוסף מופיע במאמרי העזרה של ה-API.
setExecutorProvider() מאפשרת להתאים אישית את ספק הביצוע שמשמש לעיבוד תשובות לפרסום. לדוגמה, אפשר לשנות את ספק ה-executor לספק שמחזיר executor יחיד ומשותף עם מספר מוגבל של threads בכמה לקוחות של בעלי תוכן דיגיטלי. ההגדרה הזו עוזרת להגביל את מספר השרשורים שנוצרים.
setChannelProvider() מאפשרת להתאים אישית את ספק הערוץ שמשמש לפתיחת חיבורים ל-Pub/Sub. בדרך כלל לא מגדירים את הערך הזה, אלא אם רוצים להשתמש באותו ערוץ בכמה לקוחות של בעלי תוכן דיגיטלי. שימוש חוזר בערוץ ביותר מדי לקוחות עלול לגרום לשגיאות
GOAWAYאוENHANCE_YOUR_CALM. אם השגיאות האלה מופיעות ביומנים של האפליקציה או ביומני Cloud, צריך ליצור עוד ערוצים.
דוגמאות קוד לבקרת בו-זמניות
C++
לפני שמנסים את הדוגמה הזו, צריך לפעול לפי הוראות ההגדרה של C++ במאמר תחילת העבודה המהירה: שימוש בספריות לקוח. מידע נוסף זמין במאמרי העזרה של Pub/Sub C++ API.
המשך
בדוגמה הבאה נעשה שימוש בגרסה הראשית של ספריית הלקוח Go Pub/Sub (v2). אם אתם עדיין משתמשים בספרייה v1, כדאי לעיין במדריך להעברה לגרסה v2. כדי לראות רשימה של דוגמאות קוד מגרסה 1, אפשר לעיין ב דוגמאות הקוד שהוצאו משימוש.
לפני שמנסים את הדוגמה הזו, צריך לפעול לפי הוראות ההגדרה של Go במאמר מדריך למתחילים: שימוש בספריות לקוח. מידע נוסף מופיע במאמרי העזרה של Pub/Sub Go API.
Java
לפני שמנסים את הדוגמה הזו, צריך לפעול לפי הוראות ההגדרה של Java במאמר התחלה מהירה: שימוש בספריות לקוח. מידע נוסף מופיע במאמרי העזרה של Pub/Sub Java API.
Ruby
בדוגמה הבאה נעשה שימוש בספריית הלקוח של Ruby Pub/Sub בגרסה 3. אם אתם עדיין משתמשים בספרייה v2, כדאי לעיין במדריך להעברה לגרסה v3. כדי לראות רשימה של דוגמאות קוד של Ruby v2, אפשר לעיין ב דוגמאות הקוד שהוצאו משימוש.
לפני שמנסים את הדוגמה הזו, צריך לפעול לפי הוראות ההגדרה של Ruby במאמר תחילת העבודה המהירה: שימוש בספריות לקוח. מידע נוסף מופיע במאמרי העזרה של Pub/Sub Ruby API.
המאמרים הבאים
כדי להגביל את המיקומים שבהם Pub/Sub מאחסן נתוני הודעות, אפשר לעיין במאמר בנושא הגבלת מיקומי משאבים ב-Pub/Sub.
מידע נוסף על קבלת הודעות זמין במאמר בחירת סוג מינוי.