ניתוח כושל והתמודדות עם מסד נתונים בעייתי

חבר עובד על מערכת שהוא בונה, ומשתמש ב Firebird כמסד נתונים שהוא embedded, אך הוא ביצע טעות בטבלה שיצר, ורצה למחוק אותה אבל גילה כי אינו יכול.

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

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

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

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

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

$ gfix -shut -user sysdba -password masterkey <database>.fdb

ואז להעזר ב gbak אשר מאפשר לעשות גיבוי "חם", כלומר בזמן שדברים בד"כ רצים, על ידי יצירת מצב של snapshot לדברים, אך ללא שימוש ב Garbage Collection:

$ gbak -b -g <database>.fdb

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

$ gbak -c database.gbak  db2.fdb

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

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

מחשבה אחת על “ניתוח כושל והתמודדות עם מסד נתונים בעייתי

כתיבת תגובה

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

הלוגו של WordPress.com

אתה מגיב באמצעות חשבון WordPress.com שלך. לצאת מהמערכת / לשנות )

תמונת Twitter

אתה מגיב באמצעות חשבון Twitter שלך. לצאת מהמערכת / לשנות )

תמונת Facebook

אתה מגיב באמצעות חשבון Facebook שלך. לצאת מהמערכת / לשנות )

תמונת גוגל פלוס

אתה מגיב באמצעות חשבון Google+ שלך. לצאת מהמערכת / לשנות )

מתחבר ל-%s