אפשר לשלוח אירועי שגיאה אל Error Reporting מאפליקציות Ruby באמצעות ספריית Error Reporting ל-Ruby. אפשר להשתמש בספריית Error Reporting ל-Ruby כדי ליצור קבוצות של שגיאות במקרים הבאים:
- קטגוריה ביומן שמכילה את רשומות היומן שלכם כוללת מפתחות הצפנה בניהול הלקוח (CMEK).
- מאגר היומנים עומד באחד מהתנאים הבאים:
- קטגוריית היומן מאוחסנת באותו פרויקט שבו נוצרו רשומות היומן.
- הרשומות ביומן הועברו לפרויקט, ואז הפרויקט הזה אחסן את הרשומות ביומן בקטגוריית יומנים שבבעלותו.
- רוצים לדווח על אירועי שגיאה בהתאמה אישית.
השירות Error Reporting משולב עם חלק מהשירותים, כמו פונקציות של Cloud Run, App Engine, Compute Engine ו-Google Kubernetes Engine. Google Cloud ב-Error Reporting מוצגים אירועי השגיאות שנרשמים ב-Cloud Logging על ידי אפליקציות שפועלות בשירותים האלה. מידע נוסף זמין בקטע הפעלה ב Google Cloud בדף הזה.
אפשר גם לשלוח אירועי שגיאה אל Error Reporting באמצעות Logging. במאמר פורמט של רשומה ביומן לדיווח על אירועי שגיאה מוסבר על הדרישות בנוגע לפורמט הנתונים.
לפני שמתחילים
- נכנסים לחשבון 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 Error Reporting 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, 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 Error Reporting 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.- מתקינים Ruby מגרסה 2.2 ואילך.
התקנת ספריית הלקוח
ספריית Error Reporting ל-Ruby מאפשרת לכם לעקוב אחרי אירועי שגיאה שדווחו על ידי אפליקציות Ruby שפועלות כמעט בכל מקום, ולצפות בהם.
-
מוסיפים את ה-Gem
google-cloud-error_reportingלקובץ Gemfile:gem "google-cloud-error_reporting"
-
משתמשים ב-Bundler כדי להתקין את ה-gem:
bundle install
הפעלת הספרייה
אם אתם משתמשים ב-Ruby on Rails, Bundler טוען את הספרייה באופן אוטומטי לאפליקציה כשמפעילים אותה.
אפליקציות אחרות שמבוססות על Rack יכולות להשתמש ב-Rack Middleware שמסופק על ידי הספרייה:
מידע נוסף על התקנה זמין במסמכי התיעוד של ספריית Error Reporting ל-Ruby. אפשר גם לדווח על בעיות באמצעות הכלי למעקב אחרי בעיות.
הגדרת ספריית הלקוח
אפשר להתאים אישית את ההתנהגות של ספריית Error Reporting ל-Ruby. רשימת אפשרויות ההגדרה האפשריות מופיעה במאמר בנושא הגדרת הספריה.
הפעלת אפליקציות ב- Google Cloud
כדי ליצור קבוצות שגיאות באמצעות projects.events.report, לחשבון השירות שלכם נדרש התפקיד Error Reporting Writer (roles/errorreporting.writer).
חלק משירותי Google Cloud Google Cloud מעניקים באופן אוטומטי את התפקיד Error Reporting Writer (roles/errorreporting.writer) לחשבון השירות המתאים. עם זאת, בשביל שירותים מסוימים, צריך להעניק את התפקיד הזה לחשבון השירות המתאים.
פונקציות Cloud Run ו-Cloud Run
לחשבון השירות שמוגדר כברירת מחדל ב-Cloud Run יש את ההרשאות של התפקיד Error Reporting Writer (roles/errorreporting.writer).
אפשר להשתמש בספריית Error Reporting ל-Ruby בלי לספק פרטי כניסה באופן מפורש.
Cloud Run מוגדר לשימוש ב-Error Reporting באופן אוטומטי. חריגים ב-JavaScript שלא טופלו יופיעו ביומן ויתבצע עיבוד שלהם על ידי Error Reporting בלי שתצטרכו להשתמש בספריית Error Reporting עבור Ruby.
שימוש בממשק ההגדרות של Ruby on Rails
כדי להשתמש בספריית Error Reporting עבור Ruby עם מסגרת Ruby on Rails, צריך לספק את הפרמטרים דרך ממשק ההגדרה של Ruby on Rails:
אפשר גם להגדיר הגדרות משותפות לכל אבני החן של Stackdriver באמצעות הפקודה הבאה:
Error Reporting מופעל כברירת מחדל כש-Rails פועל במצב ייצור. כדי להפעיל את Error Reporting במצב פיתוח, מוסיפים את הקוד הבא:
שימוש בממשק ההגדרות של המכשיר
כדי להשתמש בספריית Error Reporting עבור Ruby באפליקציות אחרות שמבוססות על Rack, צריך לספק את הפרמטרים דרך ממשק ההגדרות:
אפשר גם להגדיר הגדרה משותפת לכל אבני החן של Google Cloud Observability באמצעות הפקודה הבאה:
סביבה גמישה של App Engine
ב-App Engine, לחשבון השירות שמוגדר כברירת מחדל מוענק באופן אוטומטי התפקיד 'כתיבה ביומן' (roles/errorreporting.writer).
אפשר להשתמש בספריית Error Reporting ל-Ruby בלי לספק פרטי כניסה באופן מפורש.
הכלי Error Reporting מופעל באופן אוטומטי באפליקציות של סביבה גמישה ב-App Engine. לא נדרשת הגדרה נוספת.Google Kubernetes Engine
כדי להשתמש ב-Error Reporting עם Google Kubernetes Engine, צריך לבצע את הפעולות הבאות:
מוודאים שלחשבון השירות שבו ישתמש הקונטיינר הוקצה התפקיד 'כתיבה ב-Error Reporting' (
roles/errorreporting.writer).אתם יכולים להשתמש בחשבון השירות שמוגדר כברירת מחדל ב-Compute Engine או בחשבון שירות מותאם אישית.
מידע על הקצאת תפקידים מופיע במאמר ניהול הגישה לפרויקטים, לתיקיות ולארגונים.
יוצרים את האשכול ומעניקים לאשכול את
cloud-platformהיקף הגישה.לדוגמה, בפקודת היצירה הבאה מצוינים היקף הגישה
cloud-platformוחשבון שירות:gcloud container clusters create CLUSTER_NAME --service-account SERVICE_ACCT_NAME --scopes=cloud-platform
Compute Engine
כדי להשתמש ב-Error Reporting עם מכונות וירטואליות ב-Compute Engine, צריך לבצע את הפעולות הבאות:
מוודאים שלחשבון השירות שבו המכונה הווירטואלית משתמשת הוקצה התפקיד 'כותב דוחות שגיאות' (
roles/errorreporting.writer).אתם יכולים להשתמש בחשבון השירות שמוגדר כברירת מחדל ב-Compute Engine או בחשבון שירות מותאם אישית.
מידע על הקצאת תפקידים מופיע במאמר ניהול הגישה לפרויקטים, לתיקיות ולארגונים.
-
נכנסים לדף VM instances במסוף Google Cloud :
אם משתמשים בסרגל החיפוש כדי למצוא את הדף הזה, בוחרים את התוצאה שבה כותרת המשנה היא Compute Engine.
בוחרים את מופע ה-VM שרוצים להעניק לו את
cloud-platformהיקף הגישה.לוחצים על עצירה ואז על עריכה.
בקטע Identity and API access בוחרים חשבון שירות עם התפקיד Error Reporting Writer (
roles/errorreporting.writer).בקטע Access scopes בוחרים באפשרות Allow full access to all Cloud APIs ושומרים את השינויים.
לוחצים על התחלה/המשך.
דוגמה
דיווח על שגיאות במסגרות מבוססות Rack
ספריית Error Reporting ל-Ruby מאפשרת לשלב בקלות את Error Reporting במסגרות אינטרנט פופולריות של Ruby שמבוססות על Rack, כמו Ruby on Rails ו-Sinatra. כשהספרייה מופעלת, היא מדווחת באופן אוטומטי על חריגים שנתפסו ממערך Rack של האפליקציה.
דיווח על שגיאות באופן ידני
אפשר לדווח על שגיאה באופן ידני על ידי הפעלת השיטהreport, כמו בדוגמה הבאה:
הרצת אפליקציות בסביבת פיתוח מקומית
כדי להשתמש בספריית Error Reporting ל-Ruby בסביבת פיתוח מקומית, למשל כדי להריץ את הספרייה בתחנת העבודה שלכם, אתם צריכים לספק לספריית Error Reporting ל-Ruby את פרטי הכניסה המקומיים שמוגדרים כברירת מחדל לאפליקציה. מידע נוסף זמין במאמר אימות ל-Error Reporting.
כדי להשתמש בדוגמאות של Ruby שבדף הזה בסביבת פיתוח מקומית, מתקינים ומפעילים את ה-CLI של gcloud, ואז מגדירים את Application Default Credentials באמצעות פרטי הכניסה של המשתמש.
-
התקינו את ה-CLI של Google Cloud.
-
אם אתם משתמשים בספק זהויות חיצוני (IdP), קודם אתם צריכים להיכנס ל-CLI של gcloud באמצעות המאגר המאוחד לניהול זהויות.
-
אם אתם משתמשים במעטפת מקומית, אתם צריכים ליצור פרטי כניסה לאימות מקומי עבור חשבון המשתמש:
gcloud auth application-default login
אם אתם משתמשים ב-Cloud Shell, אין צורך לבצע את הפעולה הזו.
אם מוחזרת שגיאת אימות ואתם משתמשים בספק זהויות חיצוני (IdP), ודאו ש נכנסתם ל-CLI של gcloud באמצעות המאגר המאוחד לניהול זהויות.
מידע נוסף זמין במאמר הגדרת אימות לסביבת פיתוח מקומית.
מפתחות API נתמכים גם על ידי projects.events.report method.
אם אתם רוצים להשתמש במפתחות API לצורך אימות, לא צריך להגדיר קובץ מקומי של Application Default Credentials.
מידע נוסף זמין במאמר בנושא יצירת מפתח API במסמכי האימות של Google Cloud .
שימוש בממשק ההגדרות של Ruby on Rails
כדי להשתמש בספריית Error Reporting עבור Ruby עם מסגרת Ruby on Rails, צריך לספק את הפרמטרים דרך ממשק ההגדרה של Ruby on Rails:
אפשר גם להגדיר הגדרות משותפות לכל אבני החן של Stackdriver באמצעות הפקודה הבאה:
Error Reporting מופעל כברירת מחדל כש-Rails פועל במצב ייצור. כדי להפעיל את Error Reporting במצב פיתוח, מוסיפים את הקוד הבא:
שימוש בממשק ההגדרות של המכשיר
כדי להשתמש בספריית Error Reporting עבור Ruby באפליקציות אחרות שמבוססות על Rack, צריך לספק את הפרמטרים דרך ממשק ההגדרות:
אפשר גם להגדיר הגדרה משותפת לכל אבני החן של Google Cloud Observability באמצעות הפקודה הבאה:
הצגת קבוצות של שגיאות
נכנסים לדף Error Reporting במסוף Google Cloud :
אפשר גם להשתמש בסרגל החיפוש כדי למצוא את הדף הזה.
מידע נוסף זמין במאמר בנושא הצגה וסינון של קבוצות שגיאות.