מעקב אחרי שאילתות פעילות

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

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

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

כדי לעקוב אחרי שאילתות פעילות, אפשר להשתמש במהדורת Cloud SQL Enterprise או במהדורת Cloud SQL Enterprise Plus.

כדי להפסיק סשן או טרנזקציה שפועלת לאורך זמן בשאילתות פעילות, צריך להשתמש במופע Cloud SQL ב-Cloud SQL Enterprise Plus Edition.

מידע נוסף על מהדורות Cloud SQL זמין במאמר מבוא למהדורות Cloud SQL.

תפקידים והרשאות נדרשים

כדי לקבל את ההרשאות שדרושות בשביל לראות את השאילתות הפעילות, צריך לבקש מהאדמין להקצות לכם את תפקידי ה-IAM הבאים בפרויקט שמארח את מופע Cloud SQL:

להסבר על מתן תפקידים, ראו איך מנהלים את הגישה ברמת הפרויקט, התיקייה והארגון.

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

ההרשאות הנדרשות

כדי לראות את השאילתות הפעילות, צריך את ההרשאות הבאות:

  • צפייה בסיכום של פעילות מסד הנתונים ובעסקאות שפועלות במשך זמן רב:
    • databaseinsights.activeQueries.fetch
    • databaseinsights.activitySummary.fetch

יכול להיות שתקבלו את ההרשאות האלה באמצעות תפקידים בהתאמה אישית או תפקידים מוגדרים מראש אחרים.

הפעלת שאילתות פעילות

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

השבתת שאילתות פעילות

אי אפשר להשבית שאילתות פעילות בלי להשבית את התובנות לגבי שאילתות. כדי להשבית שאילתות פעילות ותובנות לגבי שאילתות, אפשר לעיין במאמר בנושא השבתת תובנות לגבי שאילתות.

הצגת שאילתות פעילות

כדי לראות את השאילתות הפעילות:

  1. נכנסים לדף Cloud SQL Instances במסוף Google Cloud .

    כניסה לדף Cloud SQL Instances

  2. כדי לפתוח את הדף סקירה כללית של מכונה, לוחצים על שם המכונה.

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

    • לוחצים על הכרטיסייה תובנות לגבי שאילתות.
    • לוחצים על מעבר לתובנות לגבי שאילתות לקבלת מידע מעמיק יותר על שאילתות וביצועים. מרכז הבקרה Query insights ייפתח. בחלק העליון מוצגים פרטים על המופע.
  4. לוחצים על הכרטיסייה שאילתות פעילות.

    מכאן אפשר לשנות את פרטי השאילתה שמופיעים בטבלה Longest running transactions:

    • מסד נתונים: מסנן את עומס השאילתות במסד נתונים ספציפי או בכל מסדי הנתונים.
    • משתמש: מסנן את עומס השאילתות מחשבון משתמש ספציפי.

הצגת שאילתות פעילות שעברו נרמול

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

  • שאילתות רגילות

    • 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 ולהפעיל את התכונה 'תובנות לגבי שאילתות' ב-Cloud SQL Enterprise Plus.

יכול להיות שייקח יותר זמן לסיים פעולות ממושכות.

כדי להפסיק שאילתה או עסקה:

  1. בטבלה Longest running transaction (העסקה עם זמן הריצה הארוך ביותר), בוחרים שאילתה.
  2. בעמודה פעולה, לוחצים על סיום ההפעלה.
  3. בחלון סיום ההפעלה, לוחצים על אישור.

שאילתות פעילות שנחסמו

אם שאילתה פעילה ספציפית נחסמת או פועלת הרבה יותר זמן מהצפוי, היא יכולה לחסום שאילתות אחרות שתלויות בה.

ב-Cloud SQL יש אפשרות להפסיק שאילתות פעילות ספציפיות שפועלות במשך זמן רב או חסומות.

הפעלת ניתוח של שאילתות פעילות שנחסמו

כברירת מחדל, Google Cloud במסוף לא מוצגות שאילתות פעילות שנחסמו.

כדי לנתח שאילתות פעילות שנחסמו, צריך לעמוד בדרישות הבאות:

כדי להפעיל ניתוח של שאילתות פעילות חסומות:

המסוף

  1. נכנסים לדף Cloud SQL Instances במסוף Google Cloud .

    כניסה לדף Cloud SQL Instances

  2. כדי לפתוח את הדף סקירה כללית של מכונה, לוחצים על שם המכונה.
  3. לוחצים על Edit.
  4. מרחיבים את הקטע תובנות לגבי שאילתות.
  5. בוחרים באפשרות Enable Query insights (הפעלת תובנות לגבי שאילתות) וגם באפשרות Enable Enterprise Plus features (הפעלת התכונות של Enterprise Plus). שתי ההגדרות נדרשות.
  6. בוחרים באפשרות ניתוח שאילתות חסומות.
  7. לוחצים על Save.

זיהוי וסיום של שאילתה פעילה חסומה

בשלבים הבאים מוסבר איך לזהות שאילתה פעילה ספציפית שחוסמת שאילתות אחרות, ולהפסיק אותה.

המסוף

  1. נכנסים לדף Cloud SQL Instances במסוף Google Cloud .

    כניסה לדף Cloud SQL Instances

  2. כדי לפתוח את הדף סקירה כללית של מכונה, לוחצים על שם המכונה.
  3. בתפריט הניווט של SQL, לוחצים על תובנות לגבי שאילתות.
  4. לוחצים על הכרטיסייה שאילתות פעילות.

    אם אין לכם כבר שאילתות פעילות שפועלות, עוברים אל Cloud SQL Studio ומריצים את השאילתות שרוצים לבדוק.

  5. עוברים לקטע Longest running transactions (העסקאות שהפעולה שלהן נמשכה הכי הרבה זמן). תוכלו לראות עד 50 מהשאילתות הפעילות שהפעילו את המודעות הכי הרבה זמן בכל קטגוריה.

    כל רשומה שמוצגת כוללת פרטים של שאילתה פעילה, כולל:

    • Session ID: מזהה הסשן של השאילתה. לוחצים על הרחבה כדי לראות את הרשומה. יוצג אחד משני הסמלים הבאים:
      • סמל של שעון חול: הסמל הזה מציין שהשאילתה נמצאת בהמתנה עד ששאילתה אחרת תסתיים. אם מופיע מספר לצד הסמל, הוא מציין כמה שאילתות תלויות ממתינות לסיום השאילתה הזו.
      • סמל החסימה: הסמל הזה מציין שלא ניתן להשלים את השאילתה, ויכול להיות שהיא חוסמת שאילתות אחרות.
    • שאילתה: הטקסט של שאילתת ה-SQL.
    • מצב הסשן: מצב הסשן.
    • משך השאילתה (בשניות): כמה זמן השאילתה פועלת.
    • CPU time(ms): זמן המעבד (CPU) באלפיות השנייה שבו נעשה שימוש בבקשה.
    • סוג אירוע ההמתנה: סוג אירוע ההמתנה, אם הבקשה חסומה להרצת שאילתה.
    • משאב בהמתנה: המשאב שהבקשה ממתינה לו כרגע, אם הבקשה חסומה להרצת שאילתה.
    • משך ההמתנה לעסקה (בשניות): משך ההמתנה הנוכחי, אם הסשן חסום.
    • פעולה: פעולות אפשריות, כמו סיום הסשן.

    לוחצים כדי להרחיב את מזהה הסשן שרוצים לבדוק. אפשר להרחיב את התהליכים הבסיסיים עד שלוש רמות עומק בעץ החקירה.

  6. מאתרים את השאילתה הספציפית שחסומה ולוחצים על סיום הסשן. אחרי שמסיימים את הסשן, אפשר לעבור אל Cloud SQL Studio ולהריץ שוב את השאילתות הפעילות.

הצגת פרטים על חסימת סשנים במצב שינה

בכרטיסייה Active queries (שאילתות פעילות) מוצגים סשנים שבהם מתבצע כרגע עיבוד של בקשה. ביקורים במצב 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 במזהה של הסשן שגורם לחסימה.

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

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