1 / 25

File System Implementation

File System Implementation. File System Implementation. File-System Structure File-System Implementation Directory Implementation Allocation Methods Efficiency and Performance Recovery. File-System Structure. File structure Logical storage unit Collection of related information

mccollough
Download Presentation

File System Implementation

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. File System Implementation

  2. File System Implementation • File-System Structure • File-System Implementation • Directory Implementation • Allocation Methods • Efficiency and Performance • Recovery

  3. File-System Structure • File structure • Logical storage unit • Collection of related information • File systemresides on secondary storage (disks) why? • Provided user interface to storage, mapping logical to physical • Provides efficient and convenient access to disk by allowing data to be stored, located retrieved easily • Disk provides in-place rewrite and random access • I/O transfers performed in blocks of sectors (usually 512 bytes) • File control block– storage structure consisting of information about a file • Device drivercontrols the physical device • File system organized into layers

  4. Layered File System

  5. Allocation Methods - Contiguous • An allocation method refers to how disk blocks are allocated for files: • Contiguous allocation – each file occupies set of contiguous blocks • Best performance in most cases • Simple – only starting location (block #) and length (number of blocks) are required • Problems include finding space for file, knowing file size, external fragmentation.

  6. Allocation Methods - Contiguous • Example : • The file ‘mail’ in the following figure starts from the block 19 with length = 6 blocks. Therefore, it occupies 19, 20, 21, 22, 23, 24 blocks

  7. Contiguous Allocation • Mapping from logical to physical • Logical address= byte location within a file • Physical address= block address +offset within that block • Let LA be the Logical address and let block size=512 byte • Q=LA/512 (BLOCK NUMBER) • R=LA%512 (OFFSET) Q LA/512 R Block to be accessed = Q + starting address Displacement into block = R

  8. Contiguous Allocation • Mapping from logical to physical Q LA/512 R Block to be accessed = Q + starting address Displacement into block = R

  9. Allocation Methods - Linked • Linked allocation – each file a linked list of blocks • File ends at nil pointer • No external fragmentation • Each block contains pointer to next block • No compaction, external fragmentation • Free space management system called when new block needed • Improve efficiency by clustering blocks into groups but increases internal fragmentation • Locating a block can take many I/Os and disk seeks

  10. A. Frank - P. Weisberg pointer block = Chained Allocation • Each file is a linked list of disk blocks: blocks may be scattered anywhere on the disk. • Simple: need only starting address. • Free-space management: no waste of space. • No random access. You have to follow the link from the first block to the end.

  11. A. Frank - P. Weisberg Chained/Linked Allocation Example

  12. A. Frank - P. Weisberg Linked List Allocation Using a Table in Memory

  13. Linked Allocation

  14. Allocation Methods – Linked (Cont.) • FAT (File Allocation Table) variation • Beginning of volume has table, indexed by block number • Much like a linked list, but faster on disk and cacheable • New block allocation simple

  15. File-Allocation Table

  16. Allocation Methods - Indexed • Indexed allocation • Each file has its own index block(s) of pointers to its data blocks • Logical view

  17. Example of Indexed Allocation

  18. Performance • Best method depends on file access type • Contiguous great for sequential and random • Linked good for sequential, not random • Declare access type at creation -> select either contiguous or linked • Indexed more complex • Single block access could require 2 index block reads then data block read • Clustering can help improve throughput, reduce CPU overhead

  19. Recovery • Consistency checking– compares data in directory structure with data blocks on disk, and tries to fix inconsistencies • Can be slow and sometimes fails • Use system programs to back updata from disk to another storage device (magnetic tape, other magnetic disk, optical) • Recover lost file or disk by restoringdata from backup

  20. Log Structured File Systems • Log structured(or journaling) file systems record each metadata update to the file system as a transaction • All transactions are written to a log • A transaction is considered committed once it is written to the log (sequentially) • The transactions in the log are asynchronously written to the file system structures • When the file system structures are modified, the transaction is removed from the log • If the file system crashes, all remaining transactions in the log must still be performed • Faster recovery from crash, removes chance of inconsistency of metadata

More Related