Cloud Build יכול לשלוח לכם התראות על עדכונים ב-build לערוצים שתבחרו. בדף הזה מוסבר איך להגדיר התראות באמצעות הכלי לשליחת התראות על בעיות ב-GitHub.
לפני שמתחילים
מפעילים את ממשקי ה-API של Cloud Build, Compute Engine, Cloud Run, Pub/Sub ו-Secret Manager.
תפקידים שנדרשים להפעלת ממשקי API
כדי להפעיל ממשקי API, צריך את תפקיד ה-IAM 'אדמין של Service Usage' (
roles/serviceusage.serviceUsageAdmin), שכולל את ההרשאהserviceusage.services.enable. איך מקצים תפקידים
- מתקינים את Google Cloud CLI.
הגדרת התראות על בעיות ב-GitHub
בקטע הבא מוסבר איך להגדיר ידנית התראות על בעיות ב-GitHub באמצעות הכלי לשליחת התראות על בעיות ב-GitHub. אם אתם רוצים להפוך את ההגדרה לאוטומטית, אפשר לעיין במאמר הגדרת התראות באופן אוטומטי.
כדי להגדיר את GitHub Issues:
יוצרים GitHub Personal Access Token:
- כדי ליצור טוקן חדש, עוברים אל ההגדרות של GitHub.
בוחרים את ההיקף
repo.לוחצים על יצירת טוקן.
מאחסנים את אסימון GitHub ב-Secret Manager:
פותחים את הדף Secret Manager במסוף Google Cloud :
לוחצים על Create secret (יצירת סוד).
מזינים שם לסוד.
בקטע Secret value (ערך סודי), מוסיפים את האסימון של GitHub.
כדי לשמור את הסוד, לוחצים על Create secret (יצירת סוד).
יכול להיות שלחשבון השירות של Cloud Run יש תפקיד עריכה בפרויקט, אבל התפקיד הזה לא מספיק כדי לגשת לסוד ב-Secret Manager. כדי לתת לחשבון השירות של Cloud Run גישה לסוד:
נכנסים לדף IAM במסוף Google Cloud :
מאתרים את חשבון השירות של Compute Engine שמוגדר כברירת מחדל שמשויך לפרויקט:
חשבון השירות של Compute Engine שמוגדר כברירת מחדל ייראה בערך כך:
project-number-compute@developer.gserviceaccount.comשימו לב לחשבון השירות של Compute Engine שמוגדר כברירת מחדל.
פותחים את הדף Secret Manager במסוף Google Cloud :
לוחצים על שם הסוד שמכיל את הסוד של אסימון GitHub.
בכרטיסייה Permissions, לוחצים על Add member.
מוסיפים את חשבון השירות שמוגדר כברירת מחדל ב-Compute Engine שמשויך לפרויקט כחבר.
בוחרים את ההרשאה Secret Manager Secret Accessor בתור התפקיד.
לוחצים על Save.
נותנים לחשבון השירות של Cloud Run הרשאה לקרוא מקטגוריות של Cloud Storage:
נכנסים לדף IAM במסוף Google Cloud :
מאתרים את חשבון השירות של Compute Engine שמוגדר כברירת מחדל שמשויך לפרויקט:
חשבון השירות של Compute Engine שמוגדר כברירת מחדל ייראה בערך כך:
project-number-compute@developer.gserviceaccount.comלוחצים על סמל העיפרון בשורה שמכילה את חשבון השירות של Compute Engine שמוגדר כברירת מחדל. תוצג הכרטיסייה גישת עריכה.
לוחצים על הוספת תפקיד נוסף.
מוסיפים את התפקיד הבא:
- צפייה באובייקט אחסון
לוחצים על Save.
כותבים קובץ תצורה של תבנית כדי לתאר את הפורמט של הבעיות שנוצרות ב-GitHub:
בקובץ התצורה של התבנית לדוגמה שבהמשך, השדות
titleו-bodyמשתמשים במשתני החלפה מה-build:{ "title": "Build {{.Build.BuildTriggerId}}: {{.Build.Status}}", "body": "[{{.Build.ProjectId}}] {{.Build.BuildTriggerId}} status: **{{.Build.Status}}**\n\n[View Logs]({{.Build.LogUrl}})" }כדי לראות את הדוגמה, אפשר לעיין בקובץ ההגדרות של התבנית של כלי ההתראות על בעיות ב-GitHub.
אפשר להגדיר שדות נוספים מפרמטרים הזמינים בגוף הבקשה מנקודת קצה ל-API של GitHub ליצירת בעיה.
כותבים קובץ תצורה של התראות כדי להגדיר את ההתראות על בעיות ב-GitHub ולסנן אירועים של בנייה:
בדוגמה הבאה של קובץ הגדרות של כלי להודעות, השדה
filterמשתמש בCommon Expression Language עם המשתנה הזמיןbuildכדי לסנן אירועי build עם סטטוסSUCCESS:apiVersion: cloud-build-notifiers/v1 kind: GitHubIssuesNotifier metadata: name: example-githubissues-notifier spec: notification: filter: build.status == Build.Status.FAILURE template: type: golang uri: gs://bucket_name/template-file-name delivery: githubToken: secretRef: github-token githubRepo: myuser/myrepo secrets: - name: github-token value: projects/project-id/secrets/secret-name/versions/latestכאשר:
-
githubTokenהוא משתנה ההגדרה שמשמש בדוגמה הזו כדי להפנות לאסימון GitHub שמאוחסן ב-Secret Manager. שם המשתנה שמציינים כאן צריך להיות זהה לשם בשדהnameבקטעsecrets. -
bucket-nameהוא שם הקטגוריה. -
template-file-nameהוא שם קובץ התבנית. -
myuser/myrepoהוא שם המאגר שבו ייווצרו הבעיות. -
project-idהוא מזהה הפרויקט. Google Cloud -
secret-nameהוא השם של הסוד שמכיל את הטוקן של GitHub.
כדי לראות את הדוגמה, אפשר לעיין בקובץ ההגדרות של כלי ההתראה של GitHub Issues.
במאמר Build מפורטים שדות נוספים שאפשר לסנן לפיהם. דוגמאות נוספות לסינון זמינות במאמר שימוש ב-CEL לסינון אירועי בנייה.
-
מעלים את קובץ התצורה של כלי ההתראה ואת קובץ התבנית לקטגוריה של Cloud Storage:
אם אין לכם קטגוריה של Cloud Storage, מריצים את הפקודה הבאה כדי ליצור קטגוריה, כאשר bucket-name הוא השם שרוצים לתת לקטגוריה, בכפוף לדרישות למתן שמות.
gcloud storage buckets create gs://bucket-name/מעלים את קובץ ההגדרות של כלי ההתראה ואת קובץ התבנית לקטגוריה:
gcloud storage cp config-file-name gs://bucket-name/config-file-name gcloud storage cp template-file-name gs://bucket-name/template-file-nameכאשר:
-
bucket-nameהוא שם הקטגוריה. -
config-file-nameהוא השם של קובץ ההגדרות. -
template-file-nameהוא שם קובץ התבנית.
-
פורסים את כלי ההתראה ב-Cloud Run:
gcloud run deploy service-name \ --image=us-east1-docker.pkg.dev/gcb-release/cloud-build-notifiers/githubissues:latest \ --no-allow-unauthenticated \ --update-env-vars=CONFIG_PATH=config-path,PROJECT_ID=project-idכאשר:
-
service-nameהוא השם של שירות Cloud Run שבו פורסים את האימג'. -
config-pathהוא הנתיב לקובץ ההגדרות של כלי ההתראות של GitHub Issues, gs://bucket-name/config-file-name. -
project-idהוא מזהה הפרויקט. Google Cloud
הפקודה
gcloud run deployשולפת את הגרסה העדכנית של התמונה המתארחת מ-Artifact Registry שבבעלות Cloud Build. Cloud Build תומך בתמונות של כלי התראה למשך תשעה חודשים. אחרי תשעה חודשים, Cloud Build מוחק את גרסת התמונה. אם רוצים להשתמש בגרסה קודמת של תמונה, צריך לציין את הגרסה הסמנטית המלאה של תג התמונה במאפייןimageשל הפקודהgcloud run deploy. גרסאות קודמות של תמונות ותגים אפשר למצוא ב-Artifact Registry.-
נותנים הרשאות Pub/Sub ליצירת טוקנים לאימות ב Google Cloud פרויקט:
gcloud projects add-iam-policy-binding project-id \ --member=serviceAccount:service-project-number@gcp-sa-pubsub.iam.gserviceaccount.com \ --role=roles/iam.serviceAccountTokenCreatorכאשר:
-
project-idהוא מזהה הפרויקט. Google Cloud -
project-numberהוא מספר הפרויקט שלכם ב- Google Cloud .
-
יוצרים חשבון שירות שייצג את הזהות של המינוי ל-Pub/Sub:
gcloud iam service-accounts create cloud-run-pubsub-invoker \ --display-name "Cloud Run Pub/Sub Invoker"אפשר להשתמש ב-
cloud-run-pubsub-invokerאו בשם ייחודי בתוך הפרויקט Google Cloud .נותנים לחשבון השירות
cloud-run-pubsub-invokerאת ההרשאהInvokerשל Cloud Run:gcloud run services add-iam-policy-binding service-name \ --member=serviceAccount:cloud-run-pubsub-invoker@project-id.iam.gserviceaccount.com \ --role=roles/run.invokerכאשר:
service-nameהוא השם של שירות Cloud Run שבו פורסים את האימג'.
project-idהוא מזהה הפרויקט. Google Cloud
יוצרים את הנושא
cloud-buildsכדי לקבל הודעות עדכון לגבי הגרסה של כלי ההתראות:gcloud pubsub topics create cloud-buildsאפשר גם להגדיר שם נושא מותאם אישית בקובץ תצורת ה-build כדי שההודעות יישלחו לנושא המותאם אישית במקום זאת. במקרה כזה, יוצרים נושא עם אותו שם נושא מותאם אישית:
gcloud pubsub topics create topic-nameמידע נוסף זמין במאמר בנושא נושאי Pub/Sub להתראות על בנייה.
יוצרים מנוי Pub/Sub מסוג push עבור כלי ההתראה:
gcloud pubsub subscriptions create subscriber-id \ --topic=cloud-builds \ --push-endpoint=service-url \ --push-auth-service-account=cloud-run-pubsub-invoker@project-id.iam.gserviceaccount.comכאשר:
-
subscriber-idהוא השם שרוצים לתת למינוי. -
service-urlהיא כתובת ה-URL שנוצרה על ידי Cloud Run לשירות החדש. -
project-idהוא מזהה הפרויקט. Google Cloud
-
ההתראות על הפרויקט שלכם ב-Cloud Build מוגדרות עכשיו. בפעם הבאה שתפעילו build, אם ה-build יתאים למסנן שהגדרתם, ייווצר issue במאגר GitHub שהגדרתם.
שימוש ב-CEL לסינון אירועים של בנייה
Cloud Build משתמש ב-CEL עם המשתנה build בשדות שמופיעים במשאב Build כדי לגשת לשדות שמשויכים לאירוע הבנייה, כמו מזהה הטריגר, רשימת התמונות או ערכי ההחלפה. אפשר להשתמש במחרוזת filter כדי לסנן אירועי בנייה בקובץ ההגדרות של הבנייה באמצעות כל שדה שמופיע במשאב Build. כדי למצוא את התחביר המדויק שמשויך לשדה, אפשר לעיין בקובץ cloudbuild.proto.
סינון לפי מזהה טריגר
כדי לסנן לפי מזהה טריגר, מציינים את ערך מזהה הטריגר בשדה filter
באמצעות build.build_trigger_id, כאשר trigger-id הוא מזהה הטריגר כמחרוזת:
filter: build.build_trigger_id == trigger-id
סינון לפי סטטוס
כדי לסנן לפי סטטוס, מציינים את סטטוס הבנייה שרוצים לסנן לפיו בשדה filter באמצעות build.status.
בדוגמה הבאה אפשר לראות איך מסננים אירועי בנייה עם סטטוס SUCCESS באמצעות השדה filter:
filter: build.status == Build.Status.SUCCESS
אפשר גם לסנן את הגרסאות עם סטטוסים שונים. בדוגמה הבאה מוצג סינון של אירועי בנייה עם הסטטוס SUCCESS, FAILURE או TIMEOUT באמצעות השדה filter:
filter: build.status in [Build.Status.SUCCESS, Build.Status.FAILURE, Build.Status.TIMEOUT]
כדי לראות ערכי סטטוס נוספים שאפשר לסנן לפיהם, אפשר לעיין בסטטוס בקטע 'הפניה למשאבי Build'.
סינון לפי תג
כדי לסנן לפי תג, מציינים את הערך של התג בשדה filter באמצעות build.tags, כאשר tag-name הוא השם של התג:
filter: tag-name in build.tags
אפשר לסנן לפי מספר התגים שצוינו באירוע הבנייה באמצעות size. בדוגמה הבאה, השדה filter מסנן אירועי build שיש להם בדיוק שני תגים, כאשר אחד מהתגים הוא v1:
filter: size(build.tags) == 2 && "v1" in build.tags
סינון לפי תמונות
כדי לסנן לפי תמונות, מציינים את הערך של התמונה בשדה filter באמצעות build.images, כאשר image-name הוא השם המלא של התמונה כפי שמופיע ב-Artifact Registry, למשל us-east1-docker.pkg.dev/my-project/docker-repo/image-one:
filter: image-name in build.images
בדוגמה הבאה, המסנן filter פועל על אירועי בנייה שבהם us-east1-docker.pkg.dev/my-project/docker-repo/image-one או us-east1-docker.pkg.dev/my-project/docker-repo/image-two מצוינים כשמות תמונות:
filter: "us-east1-docker.pkg.dev/my-project/docker-repo/image-one" in build.images || "us-east1-docker.pkg.dev/my-project/docker-repo/image-one" in build.images
סינון לפי שעה
אפשר לסנן אירועים של בנייה לפי זמן היצירה, זמן ההתחלה או זמן הסיום של הבנייה. כדי לעשות זאת, צריך לציין אחת מהאפשרויות הבאות בשדה filter: build.create_time, build.start_time או build.finish_time.
בדוגמה הבאה, השדה filter משתמש ב-timestamp כדי לסנן אירועי בנייה עם זמן בקשה ליצירת הבנייה ב-20 ביולי 2020 בשעה 6:00 בבוקר:
filter: build.create_time == timestamp("2020-07-20:T06:00:00Z")
אפשר גם לסנן אירועי בנייה לפי השוואות של טווחי זמן. בדוגמה הבאה, השדה filter משתמש ב-timestamp כדי לסנן אירועי בנייה עם שעת התחלה בין 20 ביולי 2020 בשעה 6:00 לבין 30 ביולי 2020 בשעה 6:00.
filter: timestamp("2020-07-20:T06:00:00Z") >= build.start_time && build.start_time <= timestamp("2020-07-30:T06:00:00Z")
מידע נוסף על האופן שבו אזורי זמן מבוטאים ב-CEL זמין בהגדרת השפה של אזורי זמן.
כדי לסנן לפי משך בנייה, אפשר להשתמש ב-duration כדי להשוות בין חותמות זמן.
בדוגמה הבאה, השדה filter משתמש ב-duration כדי לסנן אירועי בנייה עם בנייה שפועלת לפחות חמש דקות:
filter: build.finish_time - build.start_time >= duration("5m")
סינון לפי החלפה
כדי לסנן לפי החלפה, מציינים את משתנה ההחלפה בשדה filter באמצעות build.substitutions. בדוגמה הבאה, השדה filter מפרט את הגרסאות שמכילות את משתנה ההחלפה substitution-variable, ובודק אם substitution-variable תואם ל-substitution-value שצוין:
filter: build.substitutions[substitution-variable] == substitution-value
כאשר:
-
substitution-variableהוא השם של משתנה ההחלפה. -
substitution-valueהוא השם של ערך ההחלפה.
אפשר גם לסנן לפי ערכי ברירת מחדל של משתני החלפה. בדוגמה הבאה, בשדה filter מופיעים build-ים עם שם הענף master ו-build-ים עם שם המאגר github.com/user/my-example-repo. משתני ההחלפה שמוגדרים כברירת מחדל, BRANCH_NAME ו-REPO_NAME, מועברים כמפתחות אל build.substitutions:
filter: build.substitutions["BRANCH_NAME"] == "master" && build.substitutions["REPO_NAME"] == "github.com/user/my-example-repo"
אם רוצים לסנן מחרוזות באמצעות ביטויים רגולריים, אפשר להשתמש בפונקציה המובנית matches. בדוגמה שלמטה, השדה filter מסנן
גרסאות build עם סטטוס FAILURE או TIMEOUT, וגם גרסאות build עם
משתנה החלפה TAG_NAME עם ערך שתואם לביטוי הרגולרי
v{DIGIT}.{DIGIT}.{3 DIGITS}).
filter: build.status in [Build.Status.FAILURE, Build.Status.TIMEOUT] && build.substitutions["TAG_NAME"].matches("^v\\d{1}\\.\\d{1}\\.\\d{3}$")
רשימה של ערכי החלפה שמוגדרים כברירת מחדל מופיעה במאמר שימוש בהחלפות שמוגדרות כברירת מחדל.
המאמרים הבאים
- מידע נוסף על Cloud Build Notifiers
- איך נרשמים לקבלת התראות על בנייה
- איך כותבים קובץ הגדרות build של Cloud Build