יצירת מאגרים מ-GitHub

בעזרת Cloud Build אפשר ליצור טריגרים ל-build ממאגרים שמתארחים ב-GitHub. אתם יכולים להריץ בנייה בתגובה לאירועים כמו שליחת קומיטים או בקשות מיזוג שמשויכים למאגר GitHub שלכם.

בדף הזה מוסבר איך להפעיל טריגרים של בנייה במופע של GitHub. מידע נוסף זמין במאמרים בנושא טריגרים של Cloud Build ומאגרי Cloud Build.

לפני שמתחילים

פועלים לפי ההוראות להתחברות למארח GitHub.
  • מפעילים את Cloud Build API.

    תפקידים שנדרשים להפעלת ממשקי API

    כדי להפעיל ממשקי API, צריך את תפקיד ה-IAM 'אדמין של Service Usage' (roles/serviceusage.serviceUsageAdmin), שכולל את ההרשאה serviceusage.services.enable. איך מקצים תפקידים

    להפעלת ה-API

כדי ליצור טריגר למאגר GitHub, צריך ליצור חיבור בין Google Cloud לבין המאגר. כדי ליצור חיבור דרך אפליקציית GitHub ב- Google Cloud, אפשר לעיין במאמר חיבור למאגר ב-GitHub.

יצירת טריגר של GitHub

בקטע הזה מוסבר איך ליצור טריגר ולקשר אותו להתקנה שלכם ב-GitHub.

מסוף Google Cloud

כדי ליצור טריגרים של GitHub באמצעות מסוף Google Cloud :

  1. פותחים את הדף Triggers במסוף Google Cloud .

    פתיחת הדף Triggers

  2. בוחרים את Google Cloud הפרויקט ולוחצים על פתיחה.

  3. לוחצים על Create trigger (יצירת ביטוי להפעלה).

  4. מזינים את הגדרות הטריגר הבאות:

    • שם: מזינים שם לטריגר.

    • אזור: בוחרים את האזור של הטריגר.

      • אם קובץ ההגדרות של ה-build שמשויך לטריגר מציין מאגר פרטי, Cloud Build משתמש במאגר הפרטי כדי להריץ את ה-build. במקרה הזה, האזור שאתם מציינים בטריגר חייב להיות זהה לאזור שבו יצרתם את המאגר הפרטי.
      • אם קובץ התצורה של ה-build שמשויך לטריגר לא מציין מאגר פרטי, Cloud Build משתמש במאגר ברירת המחדל כדי להריץ את ה-build באותו אזור שבו מוגדר הטריגר.

    • תיאור (אופציונלי): מזינים תיאור להפעלה.

    • אירוע: בוחרים את האירוע במאגר שיפעיל את הטריגר.

      • Push to a branch: מגדירים את הטריגר להתחלת בנייה של קומיטים בענף מסוים.

      • Push new tag (העלאת תג חדש): מגדירים את הטריגר להתחלת בנייה בהתחייבויות שמכילות תג מסוים.

      • בקשת משיכה: מגדירים את הטריגר להתחלת בנייה בהתחייבויות לבקשת משיכה.

    • מקור: הגדרת פרטים על מאגר GitHub:

      • שירות מאגר: בוחרים באפשרות Cloud Build.

      • יצירת מאגר: בוחרים באפשרות דור שני כמקור.

      • מאגר: בוחרים מאגר מרשימת המאגרים הזמינים.

      • Branch או Tag: מציינים ביטוי רגולרי עם ערך הענף או התג להתאמה. מידע על תחביר מקובל של ביטויים רגולריים זמין במאמר בנושא תחביר RE2.

      • שליטה בתגובות: אם בחרתם באפשרות בקשת משיכה בתור אירוע, אתם יכולים לבחור באחת מהאפשרויות הבאות כדי לקבוע אם הטריגר יפעיל באופן אוטומטי את הבנייה:

        • חובה, למעט בעלים ושותפי עריכה: כשבעלים או שותפי עריכה של מאגר יוצרים או מעדכנים בקשת משיכה, הטריגר מפעיל את הבנייה באופן אוטומטי. אם משתמש חיצוני יוזם את הפעולה, הבנייה מתבצעת רק אחרי שבעלים או משתף פעולה מגיבים /gcbrun על בקשת המשיכה.

        • חובה: כשמשתמש יוצר או מעדכן בקשת מיזוג, תהליכי הבנייה מופעלים רק אחרי שבעלים או משתף פעולה מגיב /gcbrun לבקשת המיזוג. הגרסאות מתבצעות בכל פעם שמתבצע שינוי בבקשת משיכה.

        • לא נדרש: כשמשתמש שתרם קוד יוצר או מעדכן בקשת מיזוג, טריגרים מפעילים אוטומטית את תהליכי הבנייה.

    • Configuration (תצורה): בוחרים את קובץ תצורת ה-build שנמצא במאגר המרוחק או יוצרים קובץ תצורת build מוטבע לשימוש ב-build.

      • סוג: בוחרים את סוג ההגדרה שרוצים להשתמש בה ב-build.
        • זיהוי אוטומטי: Cloud Build מזהה אוטומטית את סוג ההגדרה אם יש לכם קובץ cloudbuild.yaml או Dockerfile במאגר.
        • קובץ תצורה של Cloud Build‏ (yaml או json): משתמשים בקובץ תצורת build להגדרה.
        • Dockerfile: משתמשים ב-Dockerfile להגדרה.
        • Buildpacks: משתמשים ב-buildpacks להגדרה.
      • מיקום: מציינים את המיקום של ההגדרה.

        • מאגר: אם קובץ ההגדרות נמצא במאגר המרוחק, צריך לציין את המיקום של קובץ הגדרות הבנייה או של הספרייה Dockerfile ואת השם של התמונה שנוצרת. אם ההגדרה היא Dockerfile, אפשר גם להגדיר זמן קצוב לתהליך הבנייה. אחרי שתספקו את Dockerfile ואת שם התמונה, תוכלו לראות תצוגה מקדימה של פקודת docker build שה-build יבצע.
        • בתוך השורה: אם בחרתם באפשרות קובץ תצורת build ב-Cloud Build (yaml או json), תוכלו לציין את תצורת ה-build בתוך השורה. לוחצים על Open Editor (פתיחת עורך) כדי לכתוב את קובץ הגדרות ה-build במסוףGoogle Cloud באמצעות תחביר YAML או JSON. לוחצים על סיום כדי לשמור את הגדרות ה-build.
    • משתני החלפה (אופציונלי): אם בחרתם בקובץ התצורה של Cloud Build כאפשרות להגדרת ה-build, תוכלו להגדיר בשדה הזה משתני החלפה ספציפיים לטריגר. לדוגמה, נניח שאתם יוצרים כמה טריגרים, וכל טריגר פורס את האפליקציה בסביבה ספציפית. אתם יכולים לציין שהאפליקציה שלכם נפרסת בסביבה בקובץ ההגדרות של ה-build, ואז להשתמש בשדה הזה כדי להגדיר משתני החלפה שמציינים לאיזו סביבה הטריגר הזה צריך לפרוס. מידע על ציון ערכי החלפה בקובצי הגדרת build זמין במאמר החלפת ערכי משתנים.

    • Build logs (יומני בנייה) (אופציונלי): מסמנים את התיבה כדי לשלוח יומני בנייה ל-GitHub. במאמר הצגת יומני בנייה מוסבר איך לצפות ביומני בנייה.

    • חשבון שירות: בוחרים את חשבון השירות שבו רוצים להשתמש כשמפעילים את הטריגר. אם מדיניות הארגון מאפשרת שימוש בחשבון השירות מדור קודם של Cloud Build, אפשר להשאיר את השדה הזה ריק כדי להשתמש בחשבון השירות מדור קודם. אחרת, צריך לבחור את חשבון השירות הספציפי שבו רוצים להשתמש, גם אם זה חשבון השירות שמוגדר כברירת מחדל של Compute Engine.

  5. לוחצים על יצירה כדי לשמור את טריגר לפיתוח גרסת Build.

כדי ליצור טריגרים של GitHub באמצעות פקודות gcloud, אפשר לעיין בgcloudפקודות ליצירת טריגר לפיתוח גרסת Build.

‫CLI של gcloud

כדי ליצור טריגרים של GitHub באמצעות פקודות gcloud, מריצים את הפקודה הבאה:

    gcloud builds triggers create github \
      --name=TRIGGER_NAME \
      --repository=projects/PROJECT_ID/locations/REGION/connections/CONNECTION_NAME/repositories/REPO_NAME \
      --branch-pattern=BRANCH_PATTERN # or --tag-pattern=TAG_PATTERN \
      --build-config=BUILD_CONFIG_FILE \
      --region=REGION \
      --service-account=SERVICE-ACCOUNT

כאשר:

  • TRIGGER_NAME הוא השם של הטריגר.
  • PROJECT_ID הוא מזהה הפרויקט. Google Cloud
  • REGION הוא האזור של הטריגר.
  • CONNECTION_NAME הוא השם של החיבור ל-GitHub.
  • REPO_NAME הוא שם המאגר
  • BRANCH_PATTERN הוא שם הענף במאגר שבו רוצים להפעיל את ה-build.
  • TAG_PATTERN הוא שם התג במאגר שמשמש להפעלת ה-build.
  • BUILD_CONFIG_FILE הוא הנתיב לקובץ התצורה של ה-build.
  • SERVICE-ACCOUNT הוא חשבון השירות שבו יש להשתמש לפעולות של הפעלה ובנייה.

API

כדי ליצור טריגר GitHub באמצעות ה-API, משתמשים בתבנית ה-JSON הבאה:

{
    "filename": "cloudbuild.yaml",
    "name": "curl-trigger",
    "description": "curl trigger",
    "repository_event_config": {
      "repository": "REPO_NAME",
      "repository_type": "GITHUB",
      // Field filter must be only one of the following:
      "pullRequest": "PULL_REQUEST_FILTER",
      "push": "PUSH_FILTER"
    }
}

כאשר:

  • REPO_NAME הוא השם של חיבור המאגר שהגדרתם ב-Cloud Build.
  • PULL_REQUEST_FILTER הוא מופע של PullRequestFilter, שמגדיר את המסנן שמאפשר ל-Cloud Build להפעיל build כשמתבצעת בקשת משיכה תואמת ב-GitHub.
  • PUSH_FILTER הוא מופע של PushFilter, שמגדיר את המסנן שמאפשר ל-Cloud Build להפעיל בנייה כשמתבצעת פעולת push תואמת ב-GitHub.

מזינים את הפקודה curl הבאה בטרמינל:

  curl -X POST -H "Authorization: Bearer "$(gcloud auth print-access-token) -H "Content-Type: application/json; charset=utf-8" -H "x-goog-user-project: PROJECT_NUMBER" https://cloudbuild.googleapis.com/v1/projects/PROJECT_ID/triggers -d @trigger.json

כאשר:

  • PROJECT_NUMBER הוא מספר הפרויקט שלכם ב- Google Cloud .
  • PROJECT_ID הוא מזהה הפרויקט. Google Cloud

איך יוצרים את השינויים ורואים אותם

כדי ליצור build באמצעות טריגרים של GitHub, צריך לדחוף ולבצע commit של שינויים במאגר המקור המקושר, או להגדיר את ה-build בבקשות משיכה. אחרי שתבצעו את השינויים, Cloud Build יבנה את הקוד.

כדי לראות את השינויים ב-build ב-GitHub, עוברים לכרטיסייה Checks במאגר.

צילום מסך של הכרטיסייה 'שיחה'

תראו ש-Cloud Build יצר את השינויים שלכם. יוצגו גם פרטים נוספים על הבנייה, כמו הזמן שנדרש לבניית הקוד ומזהה הבנייה.

כדי לראות את השינויים ב-Build ב-Cloud Build, לוחצים על View more details on Google Cloud Build. הדף Build details במסוף Google Cloud ייפתח ובו תוכלו לראות פרטים על הגרסה, כמו סטטוס, יומנים ושלבי בנייה.

סוגים שונים של טריגרים שמבוססים על GitHub

אם קוד המקור שלכם נמצא ב-GitHub, יש שתי דרכים שבהן Cloud Build יכול להפעיל גרסאות build באופן אוטומטי. בקטע הזה מוסבר על שני טריגרים מבוססי GitHub ומוצגות השוואה בין התכונות שלהם.

  • טריגרים מדור קודם של GitHub: כשיוצרים טריגר מדור קודם של GitHub, ‏ Cloud Build משכפל את המאגר שלכם ב-GitHub ב-Cloud Source Repositories ומשתמש במאגר המשוכפל לכל הפעולות שלו. אפשר ליצור ולנהל טריגרים של GitHub באמצעות מסוף Google Cloud .

  • טריגרים של GitHub: סוג הטריגר הזה משתמש באפליקציית Cloud Build GitHub כדי להגדיר את GitHub ולבצע אימות ב-GitHub. טריגרים של GitHub מאפשרים להפעיל באופן אוטומטי תהליכי build בבקשות push ובבקשות משיכה של Git, ולראות את תוצאות ה-build ב-GitHub ובמסוף Google Cloud . בדף הזה מוסבר איך ליצור ולנהל טריגרים של GitHub באמצעות Google Cloud המסוף או Cloud Build API.

  • טריגרים של GitHub Enterprise: סוג הטריגר הזה מאפשר להפעיל בנייה בתגובה לשליחות או לבקשות משיכה במופע של GitHub Enterprise. אתם יכולים ליצור מאגרי מידע מ-GitHub Enterprise באמצעות מסוף Google Cloud או Cloud Build API.

בטבלה הבאה מוצגת השוואה בין טריגרים מדור קודם של GitHub, טריגרים של GitHub וטריגרים של GitHub Enterprise:

תכונה טריגרים מדור קודם של GitHub טריגרים של GitHub טריגרים של GitHub Enterprise
הרצת בנייה כשמבצעים push לקוד המקור כן כן כן
הפעלת בנייה בבקשות משיכה לא כן כן
יצירת גורם מפעיל באמצעות מסוף Google Cloud כן כן כן
יצירת טריגר באמצעות Cloud Build API לא כן כן
יצירת טריגר באמצעות אפליקציית Cloud Build GitHub לא כן כן
הצגת הסטטוס של ה-build במסוף Google Cloud כן כן כן
צפייה בסטטוס של ה-build ב-GitHub לא כן כן

שיתוף נתונים

הנתונים שנשלחים ל-GitHub מ-Cloud Build עוזרים לכם לזהות טריגרים לפי שם ולראות את תוצאות הבנייה ב-GitHub.

הנתונים הבאים משותפים כרגע בין Cloud Build לבין GitHub:

  • מזהה פרויקט ב-Cloud
  • שם הטריגר
  • יומני Build

אם יצרתם טריגרים לפני אוגוסט 2020, יכול להיות ששיתוף הנתונים לא מופעל בפרויקט שלכם. כדי להפעיל שיתוף נתונים לכל הטריגרים של GitHub בפרויקט, לוחצים על Enable בכרטיסייה Cloud Build Data sharing.

אם הפעלתם בדיקות סטטוס נדרשות במאגר ב-GitHub, הפעלת שיתוף הנתונים עלולה לגרום להפסקת בדיקות הסטטוס באופן זמני. כדי לשנות את ההגדרות של בדיקת הסטטוס כך שיחפשו את שם הטריגר:

  • השבתה של בדיקות נדרשות ספציפיות ל-Cloud Build במאגר GitHub
  • איך מוודאים ששיתוף הנתונים מופעל ב-Cloud Build
  • הפעלת גרסת build חדשה ב-Cloud Build שמעדכנת סטטוסים במאגר
  • הפעלה מחדש של בדיקות סטטוס נדרשות, בחירת שם הטריגר

המאמרים הבאים