יצירת אפליקציית .NET בסביבה הגמישה של App Engine
מזהה אזור
REGION_ID הוא קוד מקוצר ש-Google מקצה על סמך האזור שבוחרים כשיוצרים את האפליקציה. הקוד לא תואם למדינה או למחוז, למרות שחלק ממזהי האזורים עשויים להיראות דומים לקודים נפוצים של מדינות ומחוזות. באפליקציות שנוצרו אחרי פברואר 2020, המחרוזת REGION_ID.r כלולה בכתובות ה-URL של App Engine. באפליקציות קיימות שנוצרו לפני התאריך הזה, מזהה האזור הוא אופציונלי בכתובת ה-URL.
במדריך למתחילים הזה נסביר איך ליצור ולפרוס אפליקציה שמציגה הודעה קצרה.
אתם יכולים להשתמש באפליקציה לדוגמה שבמדריך הזה לכל גרסה נתמכת של .NET. לשם כך, צריך לציין את גרסת זמן הריצה ואת מערכת ההפעלה בקובץ app.yaml.
כברירת מחדל, App Engine משתמש בגרסת ה-LTS העדכנית ביותר של .NET אם לא מציינים גרסת זמן ריצה בקובץ app.yaml.
לפני שמתחילים
- נכנסים לחשבון Google Cloud . אם אתם משתמשים חדשים ב- Google Cloud, צרו חשבון כדי שתוכלו להעריך את הביצועים של המוצרים שלנו בתרחישים מהעולם האמיתי. לקוחות חדשים מקבלים בחינם גם קרדיט בשווי 300$ להרצה, לבדיקה ולפריסה של עומסי העבודה.
-
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 Cloud Build 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.-
התקינו את ה-CLI של Google Cloud.
-
אם אתם משתמשים בספק זהויות חיצוני (IdP), קודם אתם צריכים להיכנס ל-CLI של gcloud באמצעות המאגר המאוחד לניהול זהויות.
-
כדי לאתחל את ה-CLI של gcloud, הריצו את הפקודה הבאה:
gcloud init -
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 Cloud Build 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.-
התקינו את ה-CLI של Google Cloud.
-
אם אתם משתמשים בספק זהויות חיצוני (IdP), קודם אתם צריכים להיכנס ל-CLI של gcloud באמצעות המאגר המאוחד לניהול זהויות.
-
כדי לאתחל את ה-CLI של gcloud, הריצו את הפקודה הבאה:
gcloud init
התפקידים הנדרשים
כדי לקבל את ההרשאות שדרושות להשלמת המדריך הזה, אתם צריכים לבקש מהאדמין להקצות לכם את תפקידי ה-IAM הבאים:
- אדמין App Engine (
roles/appengine.appAdmin) בפרויקט - עריכה ב-Cloud Build (
roles/cloudbuild.builds.editor) בפרויקט - אדמין של אובייקט אחסון (
roles/storage.objectAdmin) בפרויקט - מציג היומנים (
roles/logging.viewer) בפרויקט - משתמש בחשבון שירות (
roles/iam.serviceAccountUser) בחשבון השירות -
מבקשים מהאדמין להקצות את התפקידים הבאים לחשבון השירות שמוגדר כברירת מחדל של App Engine:
- קורא של Artifact Registry (
roles/artifactregistry.reader) בפרויקט - חשבון השירות של Cloud Build (
roles/cloudbuild.builds.builder) בפרויקט - צפייה באובייקטים באחסון (
roles/storage.objectViewer) בפרויקט
- קורא של Artifact Registry (
להסבר על מתן תפקידים, ראו איך מנהלים את הגישה ברמת הפרויקט, התיקייה והארגון.
יכול להיות שאפשר לקבל את ההרשאות הנדרשות גם באמצעות תפקידים בהתאמה אישית או תפקידים מוגדרים מראש.
דרישות מוקדמות נוספות
מאתחלים את אפליקציית App Engine עם הפרויקט ובוחרים את האזור שלה:
gcloud app create --project=[YOUR_PROJECT_ID]כשמופיעה בקשה, בוחרים את האזור שבו רוצים למקם את אפליקציית App Engine.
מתקינים את הרכיבים הבאים במחשב המקומי:
מתקינים את גרסת ה-LTS של .NET Core SDK.
אם אתם משתמשים ב-Visual Studio, אתם צריכים להשתמש בגרסה 2015 ואילך. התמונות זמינות לאפליקציות ASP.NET Core שנכתבו ל- .NET Core 1.0, 1.1, 2.0 ו-2.1.
המיקומים של App Engine
App Engine הוא אזורי, כלומר התשתית שמריצה את האפליקציות שלכם ממוקמת באזור ספציפי, ו-Google מנהלת אותה כך שהיא זמינה באופן יתירתי בכל התחומים באזור הזה.
הקריטריונים העיקריים לבחירת האזור שבו האפליקציות יפעלו הם זמן האחזור, הזמינות והעמידות. בדרך כלל אפשר לבחור את האזור הקרוב ביותר למשתמשים באפליקציה, אבל כדאי גם לבדוק איפה App Engine זמין ואיפה מוצרים ושירותים אחרים שבהם האפליקציה משתמשת. שימוש בשירותים בכמה מיקומים יכול להשפיע על זמן האחזור של האפליקציה וגם על התמחור שלה.Google Cloud
אחרי שמגדירים את האזור של אפליקציה, אי אפשר לשנות אותו.
אם כבר יצרתם אפליקציית App Engine, תוכלו לראות את האזור שלה באחת מהדרכים הבאות:
מריצים את הפקודה
gcloud app describe.פותחים את מרכז הבקרה של App Engine במסוף Google Cloud . האזור מופיע בחלק העליון של הדף.
הורדת אפליקציית Hello World
יצרנו אפליקציית Hello World ל-App Engine כדי שתוכלו להתרשם במהירות מפריסת אפליקציה ב- Google Cloud.
אפליקציית Hello World דומה לאפליקציה שנוצרת על ידי Visual Studio כשיוצרים אפליקציית ASP.NET Core ריקה. אפליקציית הדוגמה מוסיפה קובץ app.yaml. הקובץ app.yaml הוא קובץ הגדרות של App Engine שמציין את זמן הריצה והגדרות אחרות של App Engine.
משכפלים את מאגר האפליקציות לדוגמה Hello World למחשב המקומי.
git clone https://github.com/GoogleCloudPlatform/dotnet-docs-samplesאפשרות נוספת היא להוריד את הדוגמה כקובץ ZIP ולחלץ אותה.
עוברים לספרייה שמכילה את הקוד לדוגמה.
cd dotnet-docs-samples/appengine/flexible/HelloWorld
הפעלת Hello World במחשב המקומי
מריצים את הפקודות הבאות מהספרייה
dotnet-docs-samples/appengine/flexible/HelloWorld/HelloWorld.Sample:dotnet restore dotnet runבדפדפן האינטרנט, עוברים אל http://localhost:5000. ההודעה Hello World מאפליקציית הדוגמה מוצגת בדף. בחלון הטרמינל, מקישים על Ctrl+C כדי לצאת משרת האינטרנט.
פריסה והפעלה של Hello World ב-App Engine
- מריצים את הפקודה
gcloud app deployמשורת הפקודה. - מפעילים את הדפדפן ומציגים את האפליקציה בכתובת
https://PROJECT_ID.REGION_ID.r.appspot.comgcloud app browse
הפעם, הדף שמציג את ההודעה Hello World מועבר על ידי שרת אינטרנט שפועל במופע App Engine.
מזל טוב! פרסתם את האפליקציה הראשונה שלכם ב-App Engine בסביבה הגמישה של App Engine.
אם נתקלתם בשגיאות כלשהן במהלך פריסת האפליקציה, תוכלו להיעזר בטיפים לפתרון בעיות.בקטעים הבאים מפורט מידע על ניקוי, וגם קישורים לפעולות אפשריות שאפשר לבצע.
הסרת המשאבים
כדי להימנע מחיובים, אפשר למחוק את הפרויקט כדי להפסיק את החיוב על כל המשאבים שנעשה בהם שימוש במסגרת הפרויקט. Google Cloud
- במסוף Google Cloud , נכנסים לדף Manage resources.
- ברשימת הפרויקטים, בוחרים את הפרויקט שרוצים למחוק ולוחצים על Delete.
- כדי למחוק את הפרויקט, כותבים את מזהה הפרויקט בתיבת הדו-שיח ולוחצים על Shut down.
המאמרים הבאים
לומדים את כל הפלטפורמה
עכשיו, אחרי שהבנתם איך מפתחים ומפעילים אפליקציות App Engine, אתם יכולים לעיין בשאר התוכן של Google Cloud. כבר מותקן אצלכם Google Cloud CLI, שכולל את הכלים שמאפשרים לכם ליצור אינטראקציה עם מוצרים כמו Cloud SQL, Cloud Storage, Firestore ועוד.
מידע על סביבה גמישה של App Engine
הנה כמה נושאים שיעזרו לכם להמשיך ללמוד על App Engine:
סקר קוד של Hello World
האפליקציה Hello World היא האפליקציה הכי פשוטה שאפשר ליצור ב-App Engine, כי היא מכילה רק שירות אחד, יש לה רק גרסה אחת וכל הקוד שלה נמצא בספריית השורש של האפליקציה. בקטע הזה מתואר כל אחד מקובצי האפליקציה בפירוט.
Program.cs
אפליקציית Hello World היא אפליקציית ASP.NET פשוטה:
app.yaml
בקובץ app.yaml מפורטות ההגדרות הבאות של האפליקציה:
- הערך
env: flexמציין שהאפליקציה משתמשת בסביבה הגמישה של App Engine. מציינת את זמן הריצה שבו האפליקציה משתמשת. <0x
מידע נוסף על אופן הפעולה של זמן הריצה של .NET זמין במאמר בנושא זמן הריצה של .NET.
לפרטים נוספים על תכנון האפליקציה כדי לנצל את היתרונות של גרסאות ושירותים, אפשר לעיין במאמר סקירה כללית של App Engine.
פרטים נוספים על הגדרות התצורה של App Engine זמינים במאמר בנושא הגדרת האפליקציה באמצעות app.yaml.