במדריך הזה מוסבר למפתחים ולאנשי תפעול שפורסים קונטיינרים ב-Kubernetes איך להשתמש בערכי הגיבוב (digest) של קובצי אימג' של קונטיינרים כדי לזהות קובצי אימג' של קונטיינרים. תקציר של קובץ אימג' של קונטיינר מזהה באופן ייחודי ובלתי ניתן לשינוי קובץ אימג' של קונטיינר.
פריסת תמונות של קונטיינרים באמצעות תקציר התמונה מספקת כמה יתרונות בהשוואה לשימוש בתגי תמונה. לפני שממשיכים במדריך הזה, כדאי לעיין במסמך הנלווה בנושא שימוש בסיכומי קובצי אימג' של קונטיינרים.
הארגומנט image לקונטיינרים במפרט של Pod ב-Kubernetes מקבל תמונות עם ערכי גיבוב. הארגומנט הזה רלוונטי לכל מקום שבו משתמשים במפרט של Pod, כמו בקטע template של משאבי Deployment, StatefulSet, DaemonSet, ReplicaSet, CronJob ו-Job.
כדי לפרוס תמונה באמצעות ה-digest, משתמשים בשם התמונה, ואחריו @sha256: וערך ה-digest. הדוגמה הבאה היא של משאב Deployment שמשתמש בתמונה עם תקציר. פריסה היא אובייקט Kubernetes API שמאפשר להריץ כמה עותקים של Pods שמפוזרים בין הצמתים באשכול.
apiVersion: apps/v1 kind: Deployment metadata: name: echo-deployment spec: selector: matchLabels: app: echo template: metadata: labels: app: echo spec: containers: - name: echoserver image: gcr.io/google-containers/echoserver@sha256:cb5c1bddd1b5665e1867a7fa1b5fa843a47ee433bbb75d4293888b71def53229 ports: - containerPort: 8080
חיסרון אחד בשימוש בסיכום תמונות הוא שלא יודעים את ערך הסיכום עד שמפרסמים את התמונה במאגר. כשיוצרים תמונות חדשות, ערך ה-digest משתנה, וצריך דרך לעדכן את מניפסטים של Kubernetes בכל פעם שמבצעים פריסה.
במדריך הזה מוסבר איך להשתמש בכלים כמו Skaffold, kpt, digester, kustomize, gke-deploy ו-ko כדי להשתמש בערכי גיבוב של תמונות במניפסטים.
המלצות
במסמך הזה מוצגות כמה דרכים להשתמש בסיכום תמונות בפריסות של Kubernetes. הכלים שמתוארים במסמך הזה משלימים זה את זה.
לדוגמה, אפשר להשתמש בפלט של פונקציית kpt עם kustomize כדי ליצור וריאנטים לסביבות שונות. Skaffold יכול ליצור תמונות באמצעות ko ולפרוס את התמונות לאשכולות Kubernetes באמצעות kubectl או kpt.
הסיבה לכך שהכלים משלימים זה את זה היא שהם מבצעים עריכות מובנות על סמך מודל משאבי Kubernetes (KRM). המודל הזה מאפשר להוסיף כלים, ואתם יכולים לשדרג את השימוש בכלים כדי ליצור תהליכים וצינורות עיבוד נתונים שיעזרו לכם לפרוס את האפליקציות והשירותים שלכם.
כדי להתחיל, מומלץ לבחור בגישה שהכי מתאימה לכלים ולתהליכים הקיימים שלכם:
Skaffold יכול להוסיף תקצירים להפניות לתמונות. כדי להפעיל את הפונקציה הזו, צריך לבצע שינוי קטן בהגדרה. אימוץ Skaffold מספק יתרונות נוספים, כמו הפשטה של האופן שבו כלים שונים יוצרים ומפריסים תמונות של קונטיינרים.
אם משתמשים בכלי digester כ-webhook לשינוי הרשאות גישה באשכולות Kubernetes, אפשר להוסיף digests לכל הפריסות עם השפעה מינימלית על התהליכים הנוכחיים של יצירת קובצי אימג' בקונטיינרים ופריסתם. בנוסף, ה-webhook של ה-digester מפשט את ההטמעה של Binary Authorization, כי הוא דורש רק הוספה של תווית למרחב שמות.
kpt היא אפשרות מצוינת אם אתם צריכים כלי גמיש לשינוי מניפסטים של Kubernetes. אפשר להשתמש בכלי digester כפונקציית KRM בצד הלקוח בצינור kpt.
אם אתם כבר משתמשים ב-kustomize כדי לנהל מניפסטים של Kubernetes בסביבות שונות, מומלץ להשתמש בטרנספורמציות של תמונות כדי לפרוס תמונות לפי תקציר.
koהיא דרך מצוינת ליצור ולפרסם תמונות לאפליקציות Go, והיא נמצאת בשימוש בפרויקטים של קוד פתוח כמו Knative, Tekton ו-sigstore.
אם אתם לא משתמשים באף אחד מהכלים שמתוארים במסמך הזה, מומלץ להתחיל עם Skaffold ועם ה-webhook של digester. Skaffold הוא כלי נפוץ שמשמש מפתחים וצוותי הפצה, והוא משתלב עם הכלים האחרים שמתוארים במדריך הזה. אתם יכולים להשתמש באפשרויות השילוב האלה כשהדרישות שלכם משתנות. ה-webhook של digester Kubernetes משלים את Skaffold בכך שהוא מאפשר פריסות מבוססות-תקציר עבור אשכול שלם.
מטרות
- משתמשים ב-Skaffold כדי ליצור קובץ אימג' ולהעביר אותו בדחיפה, וכדי להוסיף את שם קובץ האימג' ואת ה-digest למניפסט של Kubernetes.
- משתמשים בפונקציה בצד הלקוח לסיכום וב-webhook לשינוי הרשאות הכניסה כדי להוסיף סיכומים לתמונות ב-Pods של Kubernetes ולתבניות של Pods.
- אפשר להשתמש ב-kpt setters כדי להחליף תג תמונה במניפסט של Kubernetes ב-image digest.
- אפשר להשתמש ב-kustomize כדי ליצור מניפסט של Kubernetes עם תקציר של תמונה.
- משתמשים ב-
gke-deployכדי לפתור תג תמונה לסיכום ב-Kubernetes manifest. - משתמשים בפקודה
koכדי ליצור קובץ אימג' ולהעביר אותו בדחיפה, וכדי להוסיף את שם קובץ האימג' ואת הגיבוב שלו למניפסט של Kubernetes.
עלויות
במסמך הזה משתמשים ברכיבים הבאים של Google Cloud, והשימוש בהם כרוך בתשלום:
כדי להעריך את ההוצאות בהתאם לתחזית השימוש שלכם, אתם יכולים להיעזר במחשבון העלויות.
כשמסיימים את המשימות שמתוארות במסמך הזה אפשר למחוק את המשאבים שיצרתם כדי להימנע מחיובים נוספים. מידע נוסף זמין בקטע הסרת המשאבים.
לפני שמתחילים
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator role
(
roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
-
Verify that billing is enabled for your Google Cloud project.
-
Enable the Artifact Registry API.
Roles required to enable APIs
To enable APIs, you need the Service Usage Admin IAM role (
roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles. -
In the Google Cloud console, activate Cloud Shell.
ב-Cloud Shell, מגדירים את פרויקט ברירת המחדל ל-Google Cloud CLI:
gcloud config set project PROJECT_IDמחליפים את
PROJECT_IDב[מזהה הפרויקט].יוצרים מאגר של קובצי אימג' של קונטיינרים ב-Artifact Registry:
gcloud artifacts repositories create REPOSITORY \ --location=LOCATION \ --repository-format=dockerמחליפים את מה שכתוב בשדות הבאים:
-
REPOSITORY: השם שבו רוצים להשתמש למאגר, למשלdigest-tutorial. -
LOCATION: מיקום ב-Artifact Registry, לדוגמהus-central1.
-
מגדירים אימות למיקום ב-Artifact Registry עבור כלי ה-CLI שבהם נעשה שימוש במדריך הזה:
gcloud auth configure-docker LOCATION-docker.pkg.devשימוש ב-Skaffold
Skaffold הוא כלי שורת פקודה לפיתוח ופריסה רציפים של אפליקציות באשכולות Kubernetes.
משתמשים ב-Skaffold כדי ליצור אימג', להעביר אותו בדחיפה ל-Artifact Registry ולהחליף את ערך ה-placeholder
imageבתבנית של מניפסט Kubernetes בשם, בתג וב-digest של האימג' שהועבר בדחיפה:ב-Cloud Shell, יוצרים ספרייה ועוברים אליה כדי לאחסן את הקבצים שיוצרים בקטע הזה:
mkdir -p ~/container-image-digests-tutorial/skaffold cd ~/container-image-digests-tutorial/skaffoldמשכפלים את מאגר ה-Git של Skaffold:
git clone https://github.com/GoogleContainerTools/skaffold.gitעוברים לספרייה של הדוגמה
getting-started:cd skaffold/examples/getting-startedבודקים את תג ה-Git שמתאים לגרסה של Skaffold:
git checkout $(skaffold version)צפייה בקובץ התצורה
skaffold.yaml:cat skaffold.yamlהקובץ ייראה כך:
apiVersion: skaffold/v4beta6 kind: Config build: artifacts: - image: skaffold-example manifests: rawYaml: - k8s-pod.yaml
בקטע
build.artifactsמופיע שם של פלייסהולדר של תמונה. Skaffold מחפש את ה-placeholder הזה בקובצי המניפסט של הקלט.הקטע
manifestsאומר ל-Skaffold לקרוא מניפסט קלט מהספרייה הנוכחית עם השםk8s-pod.yaml.סקירה כללית של כל האפשרויות הזמינות מופיעה במאמרי העזרה בנושא
skaffold.yaml.הצגת תבנית המניפסט של Kubernetes:
cat k8s-pod.yamlהקובץ הוא:
apiVersion: v1 kind: Pod metadata: name: getting-started spec: containers: - name: getting-started image: skaffold-example
ערך ה-placeholder
skaffold-exampleבשדהimageתואם לערך בשדהimageבקובץskaffold.yaml. Skaffold מחליף את ערך ה-placeholder הזה בשם המלא של התמונה ובערך ה-digest בפלט המעובד.יוצרים את קובץ האימג' ומעבירים אותו בדחיפה ל-Artifact Registry:
skaffold build \ --default-repo=LOCATION-docker.pkg.dev/PROJECT_ID/REPOSITORY \ --file-output=artifacts.json \ --interactive=false \ --push=true \ --update-check=falseבפקודה הזו נעשה שימוש בדגלים הבאים:
- הדגל
--file-outputמציין את הקובץ שבו Skaffold שומר מידע על התמונה שנבנתה, כולל ערך ה-digest. - הדגל
--pushמורה ל-Skaffold להעביר בדחיפה את קובץ האימג' שנוצר למאגר קובצי האימג' של הקונטיינר שצוין בדגל--default-repo. - הדגלים
--interactiveו---update-checkמוגדרים שניהם לערךfalse. בסביבות לא אינטראקטיביות, כמו צינורות build, צריך להגדיר את הדגלים האלה לערךfalse, אבל בסביבות פיתוח מקומיות צריך להשאיר אותם כערכי ברירת המחדל שלהם (trueלשני הדגלים).
אם אתם משתמשים ב-Cloud Deploy כדי לפרוס ל-GKE, אתם צריכים להשתמש בקובץ מהדגל
--file-outputכערך של הדגל--build-artifactsכשאתם יוצרים גרסת הפצה.- הדגל
מעבדים את מניפסט Kubernetes המורחב עם השם, התג והתקציר של קובץ אימג' של קונטיינר מהשלב הקודם:
skaffold render \ --build-artifacts=artifacts.json \ --digest-source=none \ --interactive=false \ --offline=true \ --output=rendered.yaml \ --update-check=falseבפקודה הזו נעשה שימוש בדגלים הבאים:
- הדגל
--build-artifactsמפנה לקובץ הפלט מהפקודהskaffold buildבשלב הקודם. - הדגל
--digest-source=noneמציין ש-Skaffold משתמש בערך ה-digest מהקובץ שצוין בדגל--build-artifacts, במקום לפתור את ה-digest ממאגר קובצי האימג' בקונטיינר. - הדגל
--offline=trueמציין שאפשר להריץ את הפקודה בלי גישה לאשכול Kubernetes. - הדגל
--outputמציין את קובץ הפלט של המניפסט שעבר רינדור.
- הדגל
הצגת המניפסט שעבר עיבוד:
cat rendered.yamlהפלט אמור להיראות כך:
apiVersion: v1 kind: Pod metadata: name: getting-started spec: containers: - image: LOCATION-docker.pkg.dev/PROJECT_ID/REPOSITORY/skaffold-example:TAG@sha256:DIGEST name: getting-started
בפלט הזה מופיעים הערכים הבאים:
-
TAG: התג ש-Skaffold הקצה לתמונה. -
DIGEST: ערך ה-digest של התמונה
-
שימוש במעכל
Digester מוסיף תקצירים לתמונות של קונטיינרים וקונטיינרים של init במפרטים של Kubernetes Pod ו-Pod template. הכלי Digester מחליף הפניות לקובצי אימג' של קונטיינרים שמשתמשות בתגים:
spec: containers: - image: gcr.io/google-containers/echoserver:1.10עם הפניות שמשתמשות ב-digest של התמונה:
spec: containers: - image: gcr.io/google-containers/echoserver:1.10@sha256:cb5c1bddd1b5665e1867a7fa1b5fa843a47ee433bbb75d4293888b71def53229אפשר להריץ את Digester כווּבּוּק קבלה משנה באשכול Kubernetes, או כפונקציית KRM בצד הלקוח באמצעות כלי שורת הפקודה kpt או kustomize.
שימוש בפונקציית KRM של מעכל
ב-Cloud Shell, יוצרים ספרייה ועוברים אליה כדי לאחסן את הקבצים שיוצרים בקטע הזה:
mkdir -p ~/container-image-digests-tutorial/digester-fn cd ~/container-image-digests-tutorial/digester-fnמורידים את הקובץ הבינארי של הכלי digester:
mkdir -p ${HOME}/bin export PATH=${HOME}/bin:${PATH} DIGESTER_VERSION=$(curl -sL https://api.github.com/repos/google/k8s-digester/releases/latest | jq -r .tag_name) curl -L "https://github.com/google/k8s-digester/releases/download/${DIGESTER_VERSION}/digester_$(uname -s)_$(uname -m)" --output ${HOME}/bin/digester chmod +x ${HOME}/bin/digesterיוצרים מניפסט של Kubernetes Pod שמפנה לתמונה
gcr.io/google-containers/echoserverבאמצעות התג1.10:cat << EOF > pod.yaml apiVersion: v1 kind: Pod metadata: name: echo spec: containers: - name: echoserver image: gcr.io/google-containers/echoserver:1.10 ports: - containerPort: 8080 EOFמריצים את הפונקציה digester KRM באמצעות kpt עם המניפסטים בספרייה הנוכחית (
.):kpt fn eval . --exec digesterכשמריצים את הפקודה הזו, kpt מבצע עדכון במקום של המניפסטים בספרייה הנוכחית. אם רוצים ש-kpt יציג את המניפסט המעודכן במסוף וישאיר את קובץ המניפסט ללא שינוי, מוסיפים את הדגל
--output unwrap.צפייה במניפסט המעודכן:
cat pod.yamlהקובץ הוא:
apiVersion: v1 kind: Pod metadata: name: echo spec: containers: - name: echoserver image: gcr.io/google-containers/echoserver:1.10@sha256:cb5c1bddd1b5665e1867a7fa1b5fa843a47ee433bbb75d4293888b71def53229 ports: - containerPort: 8080
שימוש ב-webhook של בקרת כניסה של digester
ב-Cloud Shell, יוצרים ספרייה ועוברים אליה כדי לאחסן את הקבצים שיוצרים בקטע הזה:
mkdir -p ~/container-image-digests-tutorial/digester-webhook cd ~/container-image-digests-tutorial/digester-webhookיצירת אשכול Kubernetes מקומי באמצעות kind:
kind create clusterkind הוא כלי שורת פקודה להרצת אשכולות Kubernetes מקומיים באמצעות Docker.
פורסים את ה-webhook של המעבד:
DIGESTER_VERSION=$(curl -sL https://api.github.com/repos/google/k8s-digester/releases/latest | jq -r .tag_name) kustomize build "https://github.com/google/k8s-digester.git/manifests?ref=${DIGESTER_VERSION}" | kubectl apply -f -יוצרים מרחב שמות של Kubernetes בשם
digester-demoבאשכול מסוג kind:kubectl create namespace digester-demoמוסיפים את התווית
digest-resolution: enabledלמרחב השמותdigester-demo:kubectl label namespace digester-demo digest-resolution=enabledה-webhook של ה-digester מוסיף סיכומים ל-Pods במרחבי שמות עם התווית הזו.
יוצרים מניפסט של פריסת Kubernetes שמפנה לתמונה
gcr.io/google-containers/echoserverבאמצעות התג1.10:cat << EOF > deployment.yaml apiVersion: apps/v1 kind: Deployment metadata: name: echo-deployment spec: selector: matchLabels: app: echo template: metadata: labels: app: echo spec: containers: - name: echoserver image: gcr.io/google-containers/echoserver:1.10 ports: - containerPort: 8080 EOFהחלת המניפסט במרחב השמות
digester-demo:kubectl apply --filename deployment.yaml --namespace digester-demo \ --output jsonpath='{.spec.template.spec.containers[].image}{"\n"}'הדגל
--outputמורה ל-kubectlלהציג את שם התמונה במסוף, ואחריו תו מעבר לשורה חדשה. הפלט שיתקבל:gcr.io/google-containers/echoserver:1.10@sha256:cb5c1bddd1b5665e1867a7fa1b5fa843a47ee433bbb75d4293888b71def53229בפלט הזה אפשר לראות ש-webhook של digester הוסיף את תקציר התמונה למפרט של תבנית ה-Pod במשאב Deployment.
כדי לפנות משאבים בסשן של Cloud Shell, מוחקים את אשכול ה-Kind:
kind delete cluster
שימוש ב-kpt setters
kpt הוא כלי לשורת פקודה לניהול, לעריכה, להתאמה אישית ולהחלה של מניפסטים של משאבי Kubernetes.
אפשר להשתמש בפונקציות
create-settersו-apply-settersKRM מתוך קטלוג הפונקציות של kpt כדי לעדכן את תמציות האימג'ים במניפסטים של Kubernetes כשיוצרים אימג'ים חדשים.ב-Cloud Shell, יוצרים ספרייה ועוברים אליה כדי לאחסן את הקבצים שיוצרים בקטע הזה:
mkdir -p ~/container-image-digests-tutorial/kpt cd ~/container-image-digests-tutorial/kptיוצרים חבילת kpt בספרייה הנוכחית:
kpt pkg init --description "Container image digest tutorial"יוצרים מניפסט של Kubernetes Pod שמפנה לתמונה
gcr.io/google-containers/echoserverבאמצעות התג1.10:cat << EOF > pod.yaml apiVersion: v1 kind: Pod metadata: name: echo spec: containers: - name: echoserver image: gcr.io/google-containers/echoserver:1.10 ports: - containerPort: 8080 EOFמשתמשים ב-kpt כדי ליצור setter בשם
echoimageלשדה המניפסט, כאשר הערך הקיים הואgcr.io/google-containers/echoserver:1.10:kpt fn eval . \ --image gcr.io/kpt-fn/create-setters@sha256:0220cc87f29ff9abfa3a3b5643aa50f18d355d5e9dc9e1f518119633ddc4895c \ -- "echoimage=gcr.io/google-containers/echoserver:1.10"צפייה במניפסט:
cat pod.yamlהקובץ הוא:
apiVersion: v1 kind: Pod metadata: name: echo spec: containers: - name: echoserver image: gcr.io/google-containers/echoserver:1.10 # kpt-set: ${echoimage} ports: - containerPort: 8080
מקבלים את ערך ה-digest של קובץ האימג' של הקונטיינר:
DIGEST=$(gcloud container images describe \ gcr.io/google-containers/echoserver:1.10 \ --format='value(image_summary.digest)')מגדירים את הערך החדש של השדה:
kpt fn eval . \ --image gcr.io/kpt-fn/apply-setters@sha256:4d4295727183396f0c3c6a75d2560254c2f9041a39e95dc1e5beffeb49cc1a12 \ -- "echoimage=gcr.io/google-containers/echoserver:1.10@$DIGEST"כשמריצים את הפקודה הזו, kpt מבצע החלפה במקום של ערך השדה
imageבמניפסט.צפייה במניפסט המעודכן:
cat pod.yamlהקובץ הוא:
apiVersion: v1 kind: Pod metadata: name: echo spec: containers: - name: echoserver image: gcr.io/google-containers/echoserver:1.10@sha256:cb5c1bddd1b5665e1867a7fa1b5fa843a47ee433bbb75d4293888b71def53229 # kpt-set: ${echoimage} ports: - containerPort: 8080
שימוש בטרנספורמציה של תמונות ב-kustomize
kustomize הוא כלי לשורת הפקודה שמאפשר להתאים אישית מניפסטים של Kubernetes באמצעות שכבות-על, תיקונים וטרנספורמציות.
אתם יכולים להשתמש ב-kustomize image transformer כדי לעדכן את שם התמונה, התג והתקציר במניפסט הקיים.
בקטע הקוד הבא
kustomization.yamlמוצג איך להגדיר את הכלי לשינוי תמונות כך שישתמש בערךdigestשל הכלי לשינוי תמונות עבור תמונות שבהן הערךimageשל מפרט ה-Pod תואם לערךnameשל הכלי לשינוי תמונות:images: - name: gcr.io/google-containers/echoserver digest: sha256:cb5c1bddd1b5665e1867a7fa1b5fa843a47ee433bbb75d4293888b71def53229
כדי להשתמש בטרנספורמציה של תמונות ב-Kustomize עם תקציר תמונה, צריך לבצע את הפעולות הבאות:
ב-Cloud Shell, יוצרים ספרייה ועוברים אליה כדי לאחסן את הקבצים שיוצרים בקטע הזה:
mkdir -p ~/container-image-digests-tutorial/kustomize cd ~/container-image-digests-tutorial/kustomizeיוצרים קובץ
kustomization.yaml:kustomize initיוצרים מניפסט של Kubernetes עם מפרט של Pod שמפנה לתמונה
gcr.io/google-containers/echoserverבאמצעות התג1.10:cat << EOF > pod.yaml apiVersion: v1 kind: Pod metadata: name: echo spec: containers: - name: echoserver image: gcr.io/google-containers/echoserver:1.10 ports: - containerPort: 8080 EOFמוסיפים את המניפסט כמשאב בקובץ
kustomization.yaml:kustomize edit add resource pod.yamlמשתמשים בכלי להמרת תמונות כדי לעדכן את הגיבוב של התמונה:
kustomize edit set image \ gcr.io/google-containers/echoserver@sha256:cb5c1bddd1b5665e1867a7fa1b5fa843a47ee433bbb75d4293888b71def53229צפייה בטרנספורמציה של התמונה בקובץ
kustomization.yaml:cat kustomization.yamlהקובץ הוא:
apiVersion: kustomize.config.k8s.io/v1beta1 kind: Kustomization resources: - pod.yaml images: - digest: sha256:cb5c1bddd1b5665e1867a7fa1b5fa843a47ee433bbb75d4293888b71def53229 name: gcr.io/google-containers/echoserver
צפייה במניפסט שנוצר:
kustomize build .הפלט שיתקבל:
apiVersion: v1 kind: Pod metadata: name: echo spec: containers: - image: gcr.io/google-containers/echoserver@sha256:cb5c1bddd1b5665e1867a7fa1b5fa843a47ee433bbb75d4293888b71def53229 name: echoserver ports: - containerPort: 8080
כדי להריץ את הטרנספורמציה של kustomize ולהחיל את המניפסט שמתקבל על אשכול Kubernetes בשלב אחד, אפשר להשתמש בפקודה
kubectl applyעם הדגל--kustomize:kubectl apply --kustomize .אם רוצים להחיל את הפלט מאוחר יותר, אפשר להפנות את הפלט של הפקודה
kustomize buildלקובץ.
שימוש ב-
gke-deploy
gke-deployהוא כלי לשורת הפקודה שמשמש עם Google Kubernetes Engine (GKE). gke-deployעוטף את כלי שורת הפקודהkubectlויכול לשנות את המשאבים שאתם יוצרים בהתאם לשיטות המומלצות של Google.אם משתמשים בפקודות המשנה
gke-deployprepareאוrun,gke-deployתגי התמונה נפתרים ל-digests והמניפסטים המורחבים נשמרים עם ה-digests של התמונה בקובץoutput/expanded/aggregated-resources.yamlכברירת מחדל.אפשר להשתמש ב-
gke-deploy runכדי להחליף את תג התמונה בסיכום וגם כדי להחיל את המניפסט המורחב על אשכול GKE. למרות שהפקודה הזו נוחה, יש לה חיסרון: תג התמונה מוחלף בזמן הפריסה. יכול להיות שהתמונה שמשויכת לתג השתנתה בין הרגע שבו החלטתם להטמיע לבין הרגע שבו הטמעתם, ולכן הטמעתם תמונה לא צפויה. לפריסות בייצור, מומלץ לבצע שלבים נפרדים ליצירה ולהחלה של קובצי מניפסט.כדי להחליף תג תמונה במניפסט של פריסת Kubernetes בגיבוב התמונה, מבצעים את הפעולות הבאות:
ב-Cloud Shell, יוצרים ספרייה ועוברים אליה כדי לאחסן את הקבצים שיוצרים בקטע הזה:
mkdir -p ~/container-image-digests-tutorial/gke-deploy cd ~/container-image-digests-tutorial/gke-deployהתקנה של
gke-deploy:go install github.com/GoogleCloudPlatform/cloud-builders/gke-deploy@latestיוצרים מניפסט של פריסת Kubernetes שמפנה לתמונה
gcr.io/google-containers/echoserverבאמצעות התג1.10:cat << EOF > deployment.yaml apiVersion: apps/v1 kind: Deployment metadata: name: echo-deployment spec: selector: matchLabels: app: echo template: metadata: labels: app: echo spec: containers: - name: echoserver image: gcr.io/google-containers/echoserver:1.10 ports: - containerPort: 8080 EOFיצירת מניפסט מורחב על סמך המניפסט
deployment.yaml:gke-deploy prepare \ --filename deployment.yaml \ --image gcr.io/google-containers/echoserver:1.10 \ --version 1.10צפייה במניפסט המורחב:
cat output/expanded/aggregated-resources.yamlהפלט שיתקבל:
apiVersion: apps/v1 kind: Deployment metadata: labels: app.kubernetes.io/managed-by: gcp-cloud-build-deploy app.kubernetes.io/version: "1.10" name: echo-deployment namespace: default spec: selector: matchLabels: app: echo template: metadata: labels: app: echo app.kubernetes.io/managed-by: gcp-cloud-build-deploy app.kubernetes.io/version: "1.10" spec: containers: - image: gcr.io/google-containers/echoserver@sha256:cb5c1bddd1b5665e1867a7fa1b5fa843a47ee433bbb75d4293888b71def53229 name: echoserver ports: - containerPort: 8080
במניפסט המורחב, תג התמונה מוחלף בערך ה-digest.
הארגומנט
--versionשבו השתמשתם עם הפקודהgke-deployמגדיר את הערך של התוויתapp.kubernetes.io/versionבפריסה ובמטא-נתונים של תבנית ה-Pod במניפסט המורחב.במסמכי התיעוד של Cloud Build בנושא
gke-deployמוסבר איך משתמשים ב-gke-deployעם Cloud Build.
שימוש ב-
ko
koהוא כלי שורת פקודה וספרייה ליצירת קובצי אימג' של קונטיינרים של Go ולפריסתם באשכולות Kubernetes. koיוצר קובצי אימג' בלי להשתמש בשירות Docker, כך שאפשר להשתמש בו בסביבות שבהן אי אפשר להתקין את Docker.פקודת המשנה
kobuildיוצרת קובצי אימג' של קונטיינר ומפרסמת אותם במאגר של קובצי אימג' של קונטיינר, או טוענת אותם ל-Docker daemon המקומי.פקודת המשנה
koresolveמבצעת את הפעולות הבאות:- מזהה את התמונות שצריך ליצור על ידי איתור placeholders בשדות
imageשל מניפסטים של Kubernetes שסיפקתם באמצעות הארגומנט--filename. - יוצר ומפרסם את התמונות.
- הפונקציה מחליפה את ערכי ה-placeholder
imageבשמות ובערכי ה-digest של התמונות שהיא יצרה. - מדפיס את קובצי המניפסט המורחבים.
פקודות המשנה
koapply,create, ו-runמבצעות את אותם השלבים כמוresolve, ואז מריצות אתkubectl apply, אתcreateאו אתrunעם המניפסטים המורחבים.כדי ליצור תמונה מקוד מקור של Go ולהוסיף את ה-digest של התמונה למניפסט של פריסת Kubernetes, מבצעים את הפעולות הבאות
ב-Cloud Shell, יוצרים ספרייה ועוברים אליה כדי לאחסן את הקבצים שיוצרים בקטע הזה:
mkdir -p ~/container-image-digests-tutorial/ko cd ~/container-image-digests-tutorial/koמורידים את
koומוסיפים אותו ל-PATH:mkdir -p ${HOME}/bin export PATH=${HOME}/bin:${PATH} KO_VERSION=$(curl -sL https://api.github.com/repos/ko-build/ko/releases/latest | jq -r .tag_name | cut -c2-) curl -L "https://github.com/ko-build/ko/releases/download/v${KO_VERSION}/ko_${KO_VERSION}_$(uname -s)_$(uname -m).tar.gz" | tar -zxC ${HOME}/bin koיוצרים אפליקציית Go עם שם המודול
example.com/hello-worldבספרייה חדשה בשםapp:mkdir -p app/cmd/ko-example cd app go mod init example.com/hello-world cat << EOF > cmd/ko-example/main.go package main import "fmt" func main() { fmt.Println("hello world") } EOFמגדירים את מאגר התמונות ש-
koמשתמש בו כדי לפרסם תמונות:export KO_DOCKER_REPO=LOCATION-docker.pkg.dev/PROJECT_ID/REPOSITORYבדוגמה הזו נעשה שימוש ב-Artifact Registry, אבל אפשר להשתמש ב-
koעם רישום אחר של קובצי אימג' של קונטיינר.כדי ליצור ולפרסם תמונה לאפליקציה, מבצעים את אחד מהשלבים הבאים:
כדי ליצור ולפרסם קובץ אימג' לאפליקציה, מציינים את הנתיב אל חבילת main של Go:
ko build --base-import-paths ./cmd/ko-exampleהארגומנט האופציונלי
--base-import-pathsמציין ש-koמשתמש בשם הקצר של ספריית החבילה הראשית כשם התמונה.
koמדפיס את שם התמונה ואת ה-digest שלה ב-stdoutבפורמט הבא:LOCATION-docker.pkg.dev/PROJECT_ID/ko-example@sha256:DIGESTבפלט הזה,
DIGESTהוא ערך ה-digest של התמונה.משתמשים ב-
koכדי להחליף פלייסהולדר במניפסט בשם וב-digest של האימג' שהוא יוצר ומפרסם:יוצרים מניפסט של Kubernetes Pod. במניפסט נעשה שימוש בפלייסהולדר
ko://IMPORT_PATH_OF_YOUR_MAIN_PACKAGEכערך של השדהimage:cat << EOF > ko-pod.yaml apiVersion: v1 kind: Pod metadata: name: ko-example spec: containers: - name: hello-world image: ko://example.com/hello-world/cmd/ko-example EOFיוצרים ומפרסמים אימג' לאפליקציה, ומחליפים את הפלייסהולדר של המניפסט בשם האימג' ובערך ה-digest:
ko resolve --base-import-paths --filename ko-pod.yaml
koprints the manifest with the image name and digest tostdout:apiVersion: v1 kind: Pod metadata: name: ko-example spec: containers: - name: hello-world image: LOCATION-docker.pkg.dev/PROJECT_ID/ko-example@sha256:DIGEST
בפלט הזה,
DIGESTהוא ערך ה-digest של התמונה.
הסרת המשאבים
הדרך הקלה ביותר לבטל את החיוב היא למחוק את Google Cloud הפרויקט שיצרתם בשביל המדריך. אפשר גם למחוק את המשאבים הספציפיים.
מחיקת הפרויקט
- In the Google Cloud console, go to the Manage resources page.
- In the project list, select the project that you want to delete, and then click Delete.
- In the dialog, type the project ID, and then click Shut down to delete the project.
מחיקת המשאבים
אם רוצים לשמור את Google Cloud הפרויקט שבו השתמשתם במדריך הזה, צריך למחוק את המשאבים הבודדים:
ב-Cloud Shell, מוחקים את הקבצים שיצרתם במדריך הזה:
cd rm -rf ~/container-image-digests-tutorialמחיקת מאגר קובצי אימג' של קונטיינרים ב-Artifact Registry:
gcloud artifacts repositories delete REPOSITORY \ --location=LOCATION --async --quiet
המאמרים הבאים
- מידע נוסף על תקצירי קובצי אימג' של קונטיינרים
- מידע נוסף על הפונקציה digester client-side KRM ועל Kubernetes mutating webhook
- מומלץ לקרוא את המדריך בנושא פיתוח רציף (continuous delivery) בסגנון GitOps באמצעות Cloud Build.