בדף הזה מוסבר איך לעקוב אחרי השאילתות שפעילות במסד הנתונים ולפתור בעיות שקשורות אליהן. מעקב אחרי השאילתות האלה יכול לעזור לזהות את הסיבות לחביון המערכת ולשימוש גבוה ב-CPU.
במרכז הבקרה של תובנות לגבי שאילתות אפשר לראות סיכום של טרנזקציות פעילות ורשימה של טרנזקציות עם שאילתות ונתונים סטטיסטיים משויכים. העסקאות מוצגות לפי שעת ההתחלה של העסקה. אם פועלות מספר רב של שאילתות, יכול להיות שהתוצאות יוגבלו לקבוצת משנה של השאילתות הכוללות.
לפני שמתחילים
כדי לעקוב אחרי שאילתות פעילות, אפשר להשתמש במהדורת Cloud SQL Enterprise או במהדורת Cloud SQL Enterprise Plus.
כדי להפסיק סשן או טרנזקציה שפועלת לאורך זמן בשאילתות פעילות, צריך להשתמש במופע Cloud SQL במהדורת Enterprise Plus.
מידע נוסף על מהדורות Cloud SQL זמין במאמר מבוא למהדורות Cloud SQL.
תפקידים והרשאות נדרשים
כדי לקבל את ההרשאות שדרושות בשביל לראות את השאילתות הפעילות, צריך לבקש מהאדמין להקצות לכם את תפקידי ה-IAM הבאים בפרויקט שמארח את מופע Cloud SQL:
-
צפייה בסיכום הפעילות של המכונה:
Cloud SQL Viewer (
roles/cloudsql.viewer) -
צפייה בסיכום הפעילות במסד הנתונים ובעסקאות שפועלות במשך זמן רב:
צפייה בתובנות לגבי מסד הנתונים (
roles/databaseinsights.viewer) -
סיום סשן או עסקה ממושכת:
- Cloud SQL Editor (
roles/cloudsql.editor) - אדמין של פעולות ב-Database Insights (
roles/databaseinsights.operationsAdmin)
- Cloud SQL Editor (
להסבר על מתן תפקידים, ראו איך מנהלים את הגישה ברמת הפרויקט, התיקייה והארגון.
התפקידים המוגדרים מראש האלה כוללים את ההרשאות שנדרשות לצפייה בשאילתות פעילות. כדי לראות בדיוק אילו הרשאות נדרשות, אפשר להרחיב את הקטע ההרשאות הנדרשות:
ההרשאות הנדרשות
כדי לראות את השאילתות הפעילות, צריך את ההרשאות הבאות:
-
כדי לראות סיכום של פעילות מסד הנתונים ועסקאות שפועלות במשך זמן רב:
-
databaseinsights.activeQueries.fetch -
databaseinsights.activitySummary.fetch
-
יכול להיות שתקבלו את ההרשאות האלה באמצעות תפקידים בהתאמה אישית או תפקידים מוגדרים מראש אחרים.
הפעלת שאילתות פעילות
כשמפעילים את התובנות לגבי שאילתות, השאילתות הפעילות מופעלות באופן אוטומטי. כדי להפסיק סשן או עסקה ארוכה בשאילתות פעילות, צריך להשתמש ב-Query Insights במהדורת Cloud SQL Enterprise Plus.
השבתת שאילתות פעילות
אי אפשר להשבית שאילתות פעילות בלי להשבית את התכונה 'תובנות לגבי שאילתות'. כדי להשבית שאילתות פעילות ותובנות לגבי שאילתות, אפשר לעיין במאמר בנושא השבתת תובנות לגבי שאילתות.
הצגת שאילתות פעילות
כדי לראות את השאילתות הפעילות:
נכנסים לדף Cloud SQL Instances במסוף Google Cloud .
כדי לפתוח את הדף סקירה כללית של מכונה, לוחצים על שם המכונה.
כדי להציג את מרכז הבקרה תובנות לגבי שאילתות:
- לוחצים על הכרטיסייה תובנות לגבי שאילתות.
- לוחצים על מעבר לתובנות לגבי שאילתות לקבלת מידע מעמיק יותר על שאילתות וביצועים. מרכז הבקרה Query insights ייפתח. בחלק העליון מוצגים פרטים על המופע.
לוחצים על הכרטיסייה שאילתות פעילות.
מכאן אפשר לשנות את פרטי השאילתה שמופיעים בטבלה Longest running transactions (העסקאות עם זמן הריצה הארוך ביותר):
- מסד נתונים: מסנן את עומס השאילתות במסד נתונים ספציפי או בכל מסדי הנתונים.
- משתמש: מסנן את עומס השאילתות מחשבון משתמש ספציפי.
הצגת שאילתות פעילות שעברו נרמול
בלוח הבקרה Query insights אפשר לראות רשימה של העסקאות המובילות שפועלות במשך זמן רב, עם שאילתות פעילות שעברו נורמליזציה. שאילתה פעילה שעברה נורמליזציה מסירה מידע אישי רגיש ומחזירה סיכום. התקציר זהה לערכים שונים שמשמשים בדוגמה הבאה:
שאילתות רגילות
select * from test_table where id=1;select * from test_table_where id=2;
תמצית או שאילתה מנורמלת
select * from test_table where id=?;
שאילתה שמופעלת בסשנים שונים מוצגת כרשומות שונות בלוח הבקרה.
הצגת העסקאות הארוכות ביותר
הטבלה Longest running transactions בלוח הבקרה Query insights כוללת את העמודות הבאות:
| שם עמודה | תיאור |
|---|---|
| מזהה הסשן | מזהה ייחודי של הסשן. |
| שאילתה | טקסט של שאילתת SQL. |
| מצב הסשן | מצב הסשן. |
| משך השאילתה | כמה זמן השאילתה פועלת. |
| מזהה סשן החסימה | המזהה של הסשן שחוסם את הסשן. |
| סוג אירוע ההמתנה | סוג אירוע ההמתנה, אם הבקשה נחסמת להרצת שאילתה. |
| משאב המתנה | המשאב שהבקשה ממתינה לו כרגע, אם הבקשה חסומה להרצת שאילתה. |
| משך ההמתנה של העסקה | משך ההמתנה הנוכחי, אם הסשן חסום. |
| קריאות לוגיות | מספר הקריאות הלוגיות שבוצעו על ידי הבקשה. |
| קריאות | מספר הקריאות שבוצעו על ידי הבקשה. |
| כותב | מספר הפעולות של כתיבה שבוצעו על ידי הבקשה. |
| מסד נתונים | מסד הנתונים שבו הסשן פועל. |
| משתמש | השם של המשתמש שמחובר למסד הנתונים. |
| כתובת הלקוח | כתובת ה-IP הספציפית של הלקוח ששלח שאילתה. |
| זמן CPU (אלפיות השנייה) | זמן המעבד (CPU) באלפיות השנייה שבו נעשה שימוש בבקשה. |
| שם האפליקציה | שם האפליקציה שיזמה את הסשן. |
| שורות של עסקאות ששונו | מספר השורות שהוחזרו ללקוח על ידי השאילתה הזו. |
| % הושלמו | אחוז העבודה שהושלמה, אם השאילתה מדווחת על התקדמות. |
| זיכרון שהוקצה לשאילתה | מספר הדפים שהוקצו לביצוע הבקשה. |
| פעולה | האימייל יכלול קישור לסיום הסשן. |
התצוגה מתעדכנת אוטומטית כל 60 שניות.
בעזרת התפריט האנכי Content display options... אפשר לסנן את העמודות שרוצים להציג.
סיום סשן
כדי להפסיק סשן או טרנזקציה שפועלת במשך זמן רב, צריך להשתמש ב-Cloud SQL Enterprise Plus edition ולהפעיל את Query Insights ב-Cloud SQL Enterprise Plus edition.
יכול להיות שייקח יותר זמן לסיים פעולות שפועלות במשך זמן רב.
כדי להפסיק שאילתה או עסקה:
- בטבלה Longest running transaction (העסקה עם משך הפעולה הכי ארוך), בוחרים שאילתה.
- בעמודה פעולה, לוחצים על סיום ההפעלה.
- בחלון סיום ההפעלה, לוחצים על אישור.
שאילתות פעילות שנחסמו
אם שאילתה פעילה ספציפית נחסמת או פועלת הרבה יותר זמן מהצפוי, היא יכולה לחסום שאילתות תלויות אחרות.
ב-Cloud SQL יש אפשרות להפסיק שאילתות פעילות ספציפיות שפועלות במשך זמן רב או חסומות.
הפעלת ניתוח של שאילתות פעילות חסומות
כברירת מחדל, Google Cloud במסוף לא מוצגות שאילתות פעילות שנחסמו.
כדי לנתח שאילתות פעילות שנחסמו, צריך לעמוד בדרישות הבאות:
- חובה להשתמש במופע של מהדורת Cloud SQL Enterprise Plus.
- צריך להפעיל את התכונות של Enterprise Plus.
כדי להפעיל ניתוח של שאילתות פעילות חסומות:
המסוף
-
נכנסים לדף Cloud SQL Instances במסוף Google Cloud .
- כדי לפתוח את הדף סקירה כללית של מכונה, לוחצים על שם המכונה.
- לוחצים על Edit.
- מרחיבים את הקטע תובנות לגבי שאילתות.
- בוחרים באפשרות Enable Query insights (הפעלת תובנות לגבי שאילתות) וגם באפשרות Enable Enterprise Plus features (הפעלת התכונות של Enterprise Plus). צריך להפעיל את שתי ההגדרות.
- בוחרים באפשרות ניתוח שאילתות חסומות.
- לוחצים על Save.
זיהוי וסיום של שאילתה פעילה חסומה
בשלבים הבאים מוסבר איך לזהות שאילתה פעילה ספציפית שחוסמת שאילתות אחרות, ולסיים את הפעולה שלה.
המסוף
-
נכנסים לדף Cloud SQL Instances במסוף Google Cloud .
- כדי לפתוח את הדף סקירה כללית של מכונה, לוחצים על שם המכונה.
- בתפריט הניווט של SQL, לוחצים על תובנות לגבי שאילתות.
- לוחצים על הכרטיסייה שאילתות פעילות.
אם אין לכם כבר שאילתות פעילות שפועלות, עוברים אל Cloud SQL Studio ומריצים את השאילתות שרוצים לבדוק.
- עוברים לקטע Longest running transactions (העסקאות שפועלות הכי הרבה זמן). תוכלו לראות עד 50 מהשאילתות הפעילות שהפעילו את המודעות הכי הרבה זמן בכל קטגוריה.
לכל רשומה שמוצגת יש פרטים של שאילתה פעילה, כולל הפרטים הבאים:
- מזהה הפעילות: מזהה הפעילות של השאילתה. לוחצים על הרחבה
כדי לראות את הרשומה. יוצג אחד משני הסמלים הבאים:
- סמל של שעון חול: הסמל הזה מציין שהשאילתה נמצאת בהמתנה עד ששאילתה אחרת תסתיים. אם מופיע מספר לצד הסמל, הוא מציין כמה שאילתות תלויות ממתינות לסיום השאילתה הזו.
- סמל החסימה: הסמל הזה מציין שלא ניתן להשלים את השאילתה, ויכול להיות שהיא חוסמת שאילתות אחרות.
- שאילתה: הטקסט של שאילתת ה-SQL.
- מצב הסשן: מצב הסשן.
- משך השאילתה (בשניות): כמה זמן השאילתה פועלת.
- זמן CPU(אלפיות השנייה): זמן ה-CPU באלפיות השנייה שבו נעשה שימוש בבקשה.
- סוג אירוע ההמתנה: סוג אירוע ההמתנה, אם הבקשה חסומה להרצת שאילתה.
- משאב בהמתנה: המשאב שהבקשה ממתינה לו כרגע, אם הבקשה חסומה להרצת שאילתה.
- משך ההמתנה לעסקה (בשניות): משך ההמתנה הנוכחי, אם הסשן חסום.
- פעולה: פעולות אפשריות שאפשר לבצע, כמו סיום הסשן.
לוחצים כדי להרחיב את מזהה הסשן שרוצים לבדוק. אפשר להרחיב את הפגישות הבסיסיות עד שלוש רמות בעומק בעץ החקירה.
- מזהה הפעילות: מזהה הפעילות של השאילתה. לוחצים על הרחבה
כדי לראות את הרשומה. יוצג אחד משני הסמלים הבאים:
- מאתרים את השאילתה הספציפית שחסומה ולוחצים על סיום הסשן. אחרי שמסיימים את הסשן, אפשר לעבור אל Cloud SQL Studio כדי להריץ שוב את השאילתות הפעילות.
הצגת פרטים על חסימת סשנים במצב שינה
בכרטיסייה שאילתות פעילות מוצגים סשנים שבהם מתבצע כרגע עיבוד של בקשה. ביקורים במצב SLEEPING מוחרגים מהתצוגה הזו.
כדי לראות את הפקודה האחרונה שהופעלה בסשן במצב שינה, משתמשים בסקריפט הבא:
SELECT c.session_id, st.text,s.login_name, s.open_transaction_count, s.host_name, s.program_name
FROM sys.dm_exec_connections AS c JOIN sys.dm_exec_sessions AS S ON c.session_id=s.session_id
CROSS APPLY sys.dm_exec_sql_text(c.most_recent_sql_handle) AS st
WHERE s.session_id=BLOCKING_SESSION_ID
מחליפים את BLOCKING_SESSION_ID במזהה של הסשן שגורם לחסימה.
למידע נוסף שיעזור לכם לפתור בעיות שקשורות לחסימה, תוכלו לעיין במקורות המידע הבאים: