Presentation is loading. Please wait.

Presentation is loading. Please wait.

מערכות הפעלה ( אביב 2008) חגית עטיה © 1 מימוש מערכת הקבצים  תכונות של דיסקים.  מימושים בסיסיים.  קצת על מימושים מתקדמים.  אמינות מערכת הקבצים.

Similar presentations


Presentation on theme: "מערכות הפעלה ( אביב 2008) חגית עטיה © 1 מימוש מערכת הקבצים  תכונות של דיסקים.  מימושים בסיסיים.  קצת על מימושים מתקדמים.  אמינות מערכת הקבצים."— Presentation transcript:

1 מערכות הפעלה ( אביב 2008) חגית עטיה © 1 מימוש מערכת הקבצים  תכונות של דיסקים.  מימושים בסיסיים.  קצת על מימושים מתקדמים.  אמינות מערכת הקבצים.

2 מערכות הפעלה ( אביב 2008) חגית עטיה ©2 היררכית האחסון אמצעי גיבוי, DVD, CD DISK זיכרון ראשי / פיזי DRAM מטמון רגיסטרים גדול יותר ( וזול יותר ) מהיר יותר נדיף לא - נדיף Persistent Volatile

3 מערכות הפעלה ( אביב 2008) חגית עטיה ©3 זיכרון משני  בניגוד לזיכרון הראשי, אינו מאפשר ביצוע ישיר של פקודות או גישה לבתים.  שומר על מידע לטווח ארוך ( לא - נדיף, non-volatile ).  גדול, זול, ואיטי יותר מזיכרון ראשי.  נתרכז בדיסקים שהגישה אליהם באמצעות כתיבה או קריאה של רצפי מידע גדולים. גישה סידרתית מהירה. קיבולת גבוהה.

4 מערכות הפעלה ( אביב 2008) חגית עטיה ©4 מבנה הדיסק head sector track cylinder מבנה כתובת (CHS) Cylinder, Head, Sector או (LBA) Logical Block Array plate

5 מערכות הפעלה ( אביב 2008) חגית עטיה ©5 שימו לב! זמן ממוצע לגישה לסקטור אקראי: זמן העברה פנימי של סקטור 4KB: ביצועים של דיסק " שרת " דוגמא - Seagate r – סיבובים לדקה l – זמן ממוצע מהגעה ל-track עד להגעה לסקטור s – זמן ממוצע להזזת זרוע מ- track ל-track tr – קצב העברת נתונים פנימי עלות - 1000$

6 מערכות הפעלה ( אביב 2008) חגית עטיה ©6 ביצועים של דיסק " מחשב שולחני " דוגמא - IBM עלות - 100$

7 מערכות הפעלה ( אביב 2008) חגית עטיה ©7 מבנה מערכת קבצים טיפוסית Application File System API System-call Interface Logical File System  logical file system קוד כללי, בלתי תלוי במערכת קבצים ספציפית  קוד שמקבל מסלול, ומחזיר את קובץ היעד  ניהול מידע כללי עבור קבצים פתוחים, כמו מיקום בקובץ... פעולות על מדריכים. הגנה ובטיחות.

8 מערכות הפעלה ( אביב 2008) חגית עטיה ©8 מבנה מערכת קבצים טיפוסית Application File System API System-call Interface Logical File System Virtual File System Interface  logical file system  virtual file system interface מנשק אחיד לכל מערכות הקבצים הספציפיות. למשל vfs_read, vfs_write, vfs_seek.

9 מערכות הפעלה ( אביב 2008) חגית עטיה ©9 מבנה מערכת קבצים טיפוסית Application File System API System-call Interface Logical File System Virtual File System Interface Physical File System 1 Physical File System 4 llogical file system vvirtual file system interface pphysical file system מימוש מנשק ה -VFS עבור מערכת קבצים ספציפית ללמשל, מעל דיסק, דיסקט, RAM, CD, רשת וכו ‘ מתכנן איך לפזר את הבלוקים. בהמשך, נתרכז בו.

10 מערכות הפעלה ( אביב 2008) חגית עטיה ©10 מבנה מערכת קבצים טיפוסית Application File System API System-call Interface Logical File System Virtual File System Interface Physical File System 1 Physical File System 4 Device Driver IBM Device Driver Seagate  logical file system  virtual file system interface  physical file system  device drivers קוד שיודע איך לפנות להתקן ספציפי דיסקים ( לפי מודל ), DVD, וכדומה. מתחיל את הפעולה הפיזית, ומטפל בסיומה. מתזמן את הגישות, על מנת לשפר ביצועים.

11 מערכות הפעלה ( אביב 2008) חגית עטיה ©11 מדדים להערכת מימוש מערכת הקבצים  מהירות גישה סדרתית  מהירות גישה אקראית ( ישירה )  שיברור פנימי וחיצוני  יכולת להגדיל קובץ  התאוששות משיבושי מידע

12 מערכות הפעלה ( אביב 2008) חגית עטיה ©12 מיפוי קבצים : הקצאה רציפה  בבלוקים באורך קבוע כפולה של גודל סקטור ( נע בין 512B – 4KB)  המשתמש מצהיר על גודל הקובץ עם יצירתו.  מחפשים בלוקים רצופים שיכולים להכיל את הקובץ.  הכניסה במדריך מצביעה לבלוק הראשון בקובץ. file1 file2 file35 6 6

13 מערכות הפעלה ( אביב 2008) חגית עטיה ©13 מיפוי קבצים : הקצאה רציפה גישה מהירה ( סדרתית וישירה )  שיברור פנימי וחיצוני  קשה להגדיל קובץ file1 file2 file35 6 6

14 מערכות הפעלה ( אביב 2008) חגית עטיה ©14 מיפוי קבצים : הקצאה משורשרת  כל בלוק מצביע לבלוק הבא.  הכניסה במדריך מצביעה לבלוק הראשון בקובץ file1

15 מערכות הפעלה ( אביב 2008) חגית עטיה ©15 מיפוי קבצים : הקצאה משורשרת קל להגדיל קובץ. מעט שיברור חיצוני.  גישה איטית, בעיקר לגישה ישירה. שימוש בבלוקים גדולים מקטין את הבעיה, אך מגדיל שיברור פנימי.  שיבוש מצביע בבלוק גורם לאיבוד חלקים של קובץ. file1

16 מערכות הפעלה ( אביב 2008) חגית עטיה ©16 הקצאה משורשרת : מצב הדיסק מדריך קובץהתחלהסוף foo 814

17 מערכות הפעלה ( אביב 2008) חגית עטיה ©17 File Allocation Table (FAT)  החזקת שרשרת המצביעים בנפרד. file1

18 מערכות הפעלה ( אביב 2008) חגית עטיה ©18 File Allocation Table (FAT)  החזקת שרשרת המצביעים בנפרד.  בעצם, טבלה שמתארת את התוכן של הדיסק כולו.  מצביע הקובץ ( במדריך ) מראה על הכניסה הראשונה.  MS-DOS. file1

19 מערכות הפעלה ( אביב 2008) חגית עטיה ©19 מגבלות של FAT  הטבלה נמצאת במקום נוח בדיסק / זיכרון ראשי, ומכילה 2 16 כניסות ( אינדקס של 16 ביטים ) 2 32 בגרסת FAT-32  כאשר גדלים הדיסקים, גודל החתיכות גדל. דיסק של 6.4GB היה מחולק לחתיכות של 100KB ( אך במציאות משתמשים ב -FAT-32 מעל 2GB) ïמגדיל את השיברור הפנימי ( בזבוז של 10-20% הוא שכיח ).  כל קובץ דורש לפחות חתיכה אחת. ïלכל היותר 64K קבצים ב -FAT, 4G ב -FAT-32.  טבלת ה FAT מהווה משאב קריטי. צוואר בקבוק בגישה. ïלאובדן הטבלה או לפגיעה בה יש משמעות קטסטרופאלית... ולכן היא מוחזקת בשני עותקים

20 מערכות הפעלה ( אביב 2008) חגית עטיה ©20 מיפוי קבצים : אינדקס  המשתמש מצהיר על גודל קובץ מקסימלי.  המצביעים לבלוקים מרוכזים בשטח רצוף משפר במקצת את זמן הגישה הישירה לעומת הקצאה משורשרת.  צריך להצהיר מראש על גודל קובץ file1

21 מערכות הפעלה ( אביב 2008) חגית עטיה ©21 אינדקס : מצב הדיסק מדריך קובץ בלוק אינדקס foo 15

22 מערכות הפעלה ( אביב 2008) חגית עטיה ©22 מיפוי קבצים : אינדקס מרובה רמות mode owners timestamps #blocks … inodedirectory file1 file2 file3 file4 direct blocks single indirection double indirection triple indirection data

23 מערכות הפעלה ( אביב 2008) חגית עטיה ©23 מבנה מערכת הקבצים ב Unix 4.1  inodes (index nodes) אינם מדריכים.  מדריכים הינם קבצים רגילים אשר ממפים שמות קבצים ל inodes. לאחר שימוש ממושך במערכת הקבצים :  בלוקים שונים של אותו קובץ נמצאים רחוק זה מזה.  inodes ובלוקי אינדקס נמצאים רחוק מבלוקים של מידע.

24 מערכות הפעלה ( אביב 2008) חגית עטיה ©24 Unix 4.2 Fast File System (FFS)  קבוצות של צילינדרים קרובים ( על הדיסק ).  בתוך אותה קבוצת צילינדרים משתדלים לשים : בלוקים של אותו קובץ בלוקים של אותו מדריך ( כולל inodes).  בתוך קבוצות שונות שמים : בלוקים של קבצים ממדריכים שונים.  שומרים על ~10% מקום פנוי בכל קבוצת צילינדרים.

25 מערכות הפעלה ( אביב 2008) חגית עטיה ©25 ניהול בלוקים פנויים : bitmap  מערך ובו סיבית לכל בלוק. 0 – הבלוק תפוס ; 1 הבלוק פנוי.  מאוחסן במקום קבוע בדיסק. עותק בזיכרון הראשי, ליעילות.  עם בלוקים של 4KB, נזדקק לבלוק של ביטים עבור 8*4096 בלוקים.  קל לזהות רצף של בלוקים פנויים. 0 1 0 1 1 0 1 1 1 0 1 1

26 מערכות הפעלה ( אביב 2008) חגית עטיה ©26 ניהול בלוקים פנויים : רשימה מקושרת  מציאת בלוק פנוי בודד מהירה.  הקצאה של מספר בלוקים לאותו קובץ : במקומות המרוחקים זה מזה. מציאת הבלוקים מחייבת תזוזות של הדיסק.  מבנה הנתונים נהרס אם בלוק באמצע הרשימה השתבש.  ב FAT, הבלוקים הפנויים מנוהלים כקובץ אחד.

27 מערכות הפעלה ( אביב 2008) חגית עטיה ©27 ניהול בלוקים פנויים : קיבּוּץ  שימוש ברשימה מקושרת של אלמנטים : grouping - כל אלמנט מכיל טבלה של מצביעים לבלוקים פנויים רצופים ומצביע לאלמנט הבא counting – כל אלמנט מכיל מצביע לבלוק הפנוי הראשון מקבוצת בלוקים פנויים רצופים, מספר הבלוקים בקבוצה ומצביע לאלמנט הבא  ניתן למצוא בצורה יעילה מספר גדול של בלוקים פנויים ורציפים.

28 מערכות הפעלה ( אביב 2008) חגית עטיה ©28 אמינות  המידע בדיסק מתחלק ל - user data: נתוני המשתמש ( בתוך הקבצים ). metadata: מידע על ארגון הקבצים.  בלוקים של אינדקס, inodes...  איבוד / שיבוש metadata עלול לגרום לאיבוד user data רב. נפילת חשמל באמצע כתיבה עלולה לשבש את הסקטור שכעת נכתב.  מתי כתיבות עוברות מהזיכרון הראשי לדיסק ? write-through – כל כתיבה עוברת מיידית לדיסק. write-back – הדיסק מעודכן באופן אסינכרוני, אולי לא לפי סדר.

29 מערכות הפעלה ( אביב 2008) חגית עטיה ©29 אמינות נתוני המשתמש ב -Unix  במערכות Unix משתמשים במדיניות write-back נתוני המשתמש נכתבים באופן מחזורי לדיסק. תואם את סמנטיקת POSIX. פקודות fsync, sync מאלצות לכתוב את הבלוקים המלוכלכים לדיסק.

30 מערכות הפעלה ( אביב 2008) חגית עטיה ©30 אמינות ה -metadata  משתמשים במדיניות write-through עדכונים נכתבים מידית לדיסק  נתונים מסוימים נשמרים במספר עותקים למשל, שורש ה -file system  כאשר מערכת הקבצים עולה אחרי נפילה, מתקנים את מבני הנתונים. במערכות קבצים מסוימות, דורש מעבר על כל הדיסק  ScanDisk, fsck (file system check)

31 מערכות הפעלה ( אביב 2008) חגית עטיה ©31 רישום (logging)  שיטה יעילה לתחזוקת ה -metadata מוכרת גם כ -journaling  רושמים ב -log סדרתי את העדכונים לפני שהם נכתבים לדיסק ( write-ahead logging ).  הבלוקים שהשתנו נכתבים לדיסק לאחר - מכן. אולי לא לפי הסדר. אפשר לקבץ מספר שינויים ולכתוב אותם בכתיבה אחת.  ניתן למחוק מה -log עדכונים שכבר נכתבו לדיסק.

32 מערכות הפעלה ( אביב 2008) חגית עטיה ©32 התאוששות עם log  לאחר נפילה, עוברים על כל הכניסות ב -log בצע את הפעולה.  ביצוע נוסף של פקודה שהתבצעה במלואה או חלקית נותן תוצאה שקולה לביצוע הפעולה המקורית (idempotent). אם הכניסה האחרונה ב -log אינה שלמה, מתעלמים ממנה.

33 מערכות הפעלה ( אביב 2008) חגית עטיה ©33 יתרונות וחסרונות של logging כתיבה לדיסק באופן אסינכרוני התאוששות יעילה. תלויה במספר השינויים שלא נכתבו לדיסק, ולא בגודל מערכת הקבצים.  דורש כתיבות נוספות. בערך מכפיל את מספר הכתיבות.

34 מערכות הפעלה ( אביב 2008) חגית עטיה ©34 שיטות נוספות לשיפור ביצועים  ניתן לשפר ביצועים ע " י Caching שמירת חלק מהבלוקים הכי שימושיים בזכרון הראשי במטמון מיוחד המנוהל ע " י מ " ה - disk cache שמירת metadata בזכרון הראשי בנוסף להתקנים עצמם יש cache  למשל disk controller יש cache RAM  (read-ahead) Prefetching  Reducing disk arm motion לשים בלוקים שניגשים אליהם ביחד אחד ליד השני בדיסק

35 מערכות הפעלה ( אביב 2008) חגית עטיה ©35 סימנטיקה של מערכת הקבצים Consistency Semantics  חשוב להגדיר מה התוצאה מכך שכמה משתמשים / תהליכים מעדכנים קובץ במקביל..  Unix Semantics כל כתיבה לקובץ נראית מיידית לכל המשתמשים המחזיקים אותו קובץ פתוח  בשיטה הזאת ניתן לאפשר לכמה משתמשים להחזיק באותו מצביע מיקום ( שיתוף file pointer בין תהליכים )  מימוש ע " י image ( עותק ) יחיד לכל קובץ - יש לבדוק כל read ו - write הסמנטיקה לא מתקיימת במערכות קבצים המשותפות למספר מחשבים ברשת  למשל NFS

36 מערכות הפעלה ( אביב 2008) חגית עטיה ©36 סימנטיקה של מערכת הקבצים Consistency Semantics  Session Semantics session - סדרה של פעולות read ו - write המתבצעות בין פעולת open ופעולת close כתיבה לקובץ לא נראית מיידית לכל המשתמשים המחזיקים אותו קובץ פתוח. כשסוגרים את הקובץ, השינויים שביצענו נראים לכל ה - sessions שהתחילו מאוחר יותר. נתמכת למשל במערכת AFS - מערכת קבצים מבוזרת  בשימוש מעל LAN ו WAN  מאפשר caching של כל קובץ פתוח אצל הלקוח


Download ppt "מערכות הפעלה ( אביב 2008) חגית עטיה © 1 מימוש מערכת הקבצים  תכונות של דיסקים.  מימושים בסיסיים.  קצת על מימושים מתקדמים.  אמינות מערכת הקבצים."

Similar presentations


Ads by Google