אינטרנט ישראל
  • ראשי
  • אודות רן בר-זיק ואינטרנט ישראל
  • ערוץ טלגרם
  • מסטודון
  • התחברו אלי בטוויטר
  • התחברו אלי בלינקדאין
  • ספר ג'אווהסקריפט
  • ראשי
  • אודות רן בר-זיק ואינטרנט ישראל
  • ערוץ טלגרם
  • מסטודון
  • התחברו אלי בטוויטר
  • התחברו אלי בלינקדאין
  • ספר ג'אווהסקריפט
ראשי » פיתוח אינטרנט » פתרונות ומאמרים על פיתוח אינטרנט » לעבוד עם Slow Query log ב-MySQL

לעבוד עם Slow Query log ב-MySQL

רן בר-זיק אוקטובר 23, 2014 7:07 am אין תגובות

הכירו את הכלי הבסיסי לניטור שאילתות איטיות ב-MySQL

כדאי תמיד להשאר מעודכנים! אם יש לכם טלגרם, בדקו את ערוץ הטלגרם של האתר שבו אני מעדכן על פוסטים חדשים 🙂 אם אתם רוצים ללמוד תכנות באופן מקיף ומסודר, הצטרפו לאלפי הלומדים בפרויקט "ללמוד ג'אווהסקריפט בעברית" שמלמד לתכנת בג'אווהסקריפט, ב-Node.js ובריאקט וגם מלמד על תרומה לקוד פתוח. גם ספרים דיגיטליים וגם ספרים מודפסים. בשיתוף הקריה האקדמית אונו ובתמיכת חברות מובילות כגון Wix, Outbrain, Elementor, Iron Source, Chegg, Really Good ועוד.

כשאתר שמבוסס על LAMP מתחיל לקרטע, או שמקרטע מההתחלה, אחד החשודים המידיים הוא ה-MySQL. מסד הנתונים בדרך כלל מהווה את צוואר הבקבוק שגורם לביצועים לג'עג'ע. זה יכול להיות (למשל) בגלל שאילתה שבודקת user לפי שם. משהו בסגנון


SELECT user.id FROM users WHERE user.name LIKE '%S%';

יכולה לעבוד מעולה אם יש לנו 100 או 200 משתמשים. היא תהיה מאוד איטית אם יש הרבה יותר. השאלה הנשאלת היא איך אני יכול לדעת את זה? התשובה היא לבדוק את השאילתות האיטיות ב-MySQL. אלו שלוקחות המון המון זמן, או אלו שמחזיקות ה-מ-ו-ן תוצאות. כאלו שצד השרת צריך להזיע עליהן באופן רציני ביותר. איך עושים את זה? עם MySQL Query Log.

מדובר בלוג מיוחד אשר שומר שאילתות איטיות. כמה איטיות? אנחנו קובעים! איך בדיוק? יש גם בלינוקס וגם בחלונות קובץ הגדרות של MySQL. בלינוקס הוא נקרא my.cnf ונמצא ב: /etc/mysql/my.cnf. אם אתם משתמשים ב-WAMP אז אפשר לגשת אליו מהתפריט ב-System tray. אם אתם משתמשים ב-MySQL בחלונות אז אללה ירחמו.
בבתחילת הקובץ אפשר למצוא את:


[mysqld]
# -- @LT enable logging
log_slow_queries        = /var/log/mysql/mysql-slow.log
long_query_time = 1
log-queries-not-using-indexes

הקובץ מכיל את השאילתות האיטיות: /var/log/mysql/mysql-slow.log. מה זה איטיות? כאלו שעוברות את משך השניות שמפורטות ב -long_query_time.

אנחנו יכולים לגשת אל הקובץ הזה ידנית, או עם tail -f על מנת שיציג לנו את השינויים האחרונים. אבל יותר חכם להשתמש בכלי שיציג לנו את השאילתות האיטיות. יש המוני כלים כאלו, אבל ל-MySQL יש את הכלי שלו שתמיד זמין עם כל גרסה של MySQL. הכלי הזה הוא mysqldumpslow ואני אסביר מעט עליו.

איך משתמשים בו? באופן עקרוני בדרך הזו:


mysqldumpslow /var/log/mysql/mysql-slow.log

הוא יציג לי תקציר מנהלים של ה-Queries האיטיות שנאספו בלוג. שימו לב שאם אתם משנים את long_query_time, זה לא ישפיע על מה שנכנס ללוג בעבר אלא רק מהנקודה ששיניתם (ועשיתם ריסטרט ל-MySQL כמובן).

מה אני אקבל? משהו כזה:


Count: 47  Time=0.08s (3s)  Lock=0.00s (0s)  Rows=1.0 (47), '[email protected]
  SELECT DISTINCT u.uid, u.name, u.access FROM users u LEFT JOIN users_things r ON u.uid = r.uid WHERE (u.uid = N OR r.rid IN (N)) AND u.status > N ORDER BY u.access DESC LIMIT N, N

כאשר זה מאוד ברור מה אני מקבל פה – ה-count הוא מספר הפעמים שהשאילתה רצה. ה-Time הוא הזמן הממוצע של כל שאילתה. ה-Lock הוא משך הזמן שהשאילתה נעלה את הטבלה. ה-Rows הוא מספר השורות שהוחזרו.

מה שחזק בפקודה הוא האופרטורים המפורטים בדוקומנטציה:

Format Description
-a Do not abstract all numbers to N and strings to S
-n num Abstract numbers with at least the specified digits
–debug Write debugging information
-g pattern Only consider statements that match the pattern
–help Display help message and exit
-h name Host name of the server in the log file name
-i name Name of the server instance
-l Do not subtract lock time from total time
-r Reverse the sort order
-s value How to sort output
-t num Display only first num queries
–verbose Verbose mode

בעזרתם אני יכול ממש לבקש מ-mysqldumpslow דו"חות מפורטים עם אגרגציות שונות.

בגדול slow query log הוא הצעד הראשון והבסיסי ביותר בכל מה שקשור לבדיקה למה אפליקציה עובדת לאט. במקרה של אפליקציות מבוססות LAMP, בחלק גדול של המקרים תוכלו לעשות אופטימיזציות מספקות באמצעות מעבר ותיקון השאילתות המופיעות בלוג.

ישנן לא מעט מוצרים של חברות שונות שמתחברות ללוג ונותנות ניתוח מקיף יותר – אבל כאן מדובר בתוכנה שבאה כבר עם ההפצה של MySQL ושווה להכיר אותה.

כדאי תמיד להשאר מעודכנים! אם יש לכם טלגרם, בדקו את ערוץ הטלגרם של האתר שבו אני מעדכן על פוסטים חדשים 🙂 אם אתם רוצים ללמוד תכנות באופן מקיף ומסודר, הצטרפו לאלפי הלומדים בפרויקט "ללמוד ג'אווהסקריפט בעברית" שמלמד לתכנת בג'אווהסקריפט, ב-Node.js ובריאקט וגם מלמד על תרומה לקוד פתוח. גם ספרים דיגיטליים וגם ספרים מודפסים. בשיתוף הקריה האקדמית אונו ובתמיכת חברות מובילות כגון Wix, Outbrain, Elementor, Iron Source, Chegg, Really Good ועוד.
MySQL

השארת תגובה

ביטול

ללמוד ג'אווהסקריפט בעברית

ללמוד לתכנת ג'אווהסקריפט בעברית שגייס יותר משלוש מאות אלף שקל ולמעלה מ-2000 תומכים - בואו ללמוד עכשיו איך לתכנת.

רשימת הנושאים
  • מדריכים
    • ריאקט
    • טייפסקריפט
    • ECMAScript 6
    • ES20XX
    • Node.js
    • Express
    • רספברי פיי
    • Babel
    • docker
    • MongoDB
    • Git
    • לימוד MySQL
    • SASS
    • jQuery
    • CSS3
    • HTML 5
    • SVN
    • LESS
  • פיתוח אינטרנט
    • פתרונות ומאמרים על פיתוח אינטרנט
    • jQuery Scripts
    • jQuery למתקדמים
    • יסודות בתכנות
    • נגישות אינטרנט
  • חדשות אינטרנט
  • מידע כללי על אינטרנט
    • רשת האינטרנט
    • בניית אתרי אינטרנט
  • rss logo

    לכל המאמרים

    לכל המאמרים שפורסמו באינטרנט ישראל משנת 2008 ועד עכשיו.
  • rss logo

    RSS Feed

    משתמשים בקורא RSS? אם כן, עקבו אחרי אינטרנט ישראל באמצעות פיד ה-RSS!
    מה זה RSS?
  • Twitter logo

    עקבו אחרי בטוויטר

    בחשבון הטוויטר שלי אני מפרסם עדכונים מהירים על חדשות בתחום התכנות והיזמות, התרעות על מצבי חירום ורכילות בוערת על תחום הווב.
    מה זה טוויטר?
  • facebook like image

    ערוץ הטלגרם של אינטרנט ישראל

    בערוץ הטלגרם של אינטרנט ישראל אני מפרסם את הפוסטים של באתר וכן עדכונים טכנולוגיים נוספים.
    מה זה טלגרם?
  • github logo

    הפרויקטים שלי בגיטהאב

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

כל הזכויות שמורות לרן בר-זיק ולאינטרנט ישראל | מדיניות הפרטיות של אתר אינטרנט ישראל | אתר אינטרנט ישראל נגיש לפי תקן WCAG 2.0 AA | הצהרת הנגישות של האתר | אבטחת מידע ודיווח על בעיית אבטחת מידע

גלילה לראש העמוד