workshop 4: agenda
DESCRIPTION
Workshop 4: Agenda. Homework review Collect study group papers Lecture & discussion on file concepts Group activity – file structures & access methods (30 minutes) Lecture & discussion on file management Group activity – file system efficiency & performance (30 m.) - PowerPoint PPT PresentationTRANSCRIPT
![Page 1: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/1.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.1
Workshop 4: Agenda
• Homework review
• Collect study group papers
• Lecture & discussion on file concepts
• Group activity – file structures & access methods (30 minutes)
• Lecture & discussion on file management
• Group activity – file system efficiency & performance (30 m.)
• Summary and next week preview
• Midterm! (1 hour)
![Page 2: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/2.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.2
Workshop 4: Homework Review
• Chapter 10– 10.9
• Chapter 11– 11.1.
![Page 3: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/3.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.3
Module 10: File-System Interface
• File Concept
• Access :Methods
• Directory Structure
• Protection
• Consistency Semantics
![Page 4: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/4.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.4
File Concept
• Contiguous logical address space
• Types:
– Data numeric character binary
– Program
![Page 5: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/5.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.5
File Structure
• None - sequence of words, bytes
• Simple record structure
– Lines
– Fixed length
– Variable length
• Complex Structures
– Formatted document
– Relocatable load file
• Can simulate last two with first method by inserting appropriate control characters.
• Who decides:
– Operating system
– Program
![Page 6: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/6.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.6
File Attributes
• Name – only information kept in human-readable form.
• Type – needed for systems that support different types. (Some systems such as the MAC have a separate “resource fork”)
• Location – pointer to file location on device.
• Size – current file size.
• Protection – controls who can do reading, writing, executing.
• Time, date, and user identification – data for protection, security, and usage monitoring.
• Information about files are kept in the directory structure, which is maintained on the disk.
![Page 7: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/7.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.7
File Operations
• create
• write
• read
• reposition within file – file seek
• delete
• truncate
• open(Fi) – search the directory structure on disk for entry Fi, and move the content of entry to memory.
• close (Fi) – move the content of entry Fi in memory to directory structure on disk.
![Page 8: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/8.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.8
File Types – name, extension
Executable exe, com, bin ornone
ready-to-run machine-language program
Object obj, o complied, machinelanguage, not linked
Source code c, p, pas, 177,asm, a
source code in variouslanguages
Batch bat, sh commands to thecommand interpreter
Text txt, doc textual data documents
Word processor wp, tex, rrf, etc. various word-processorformats
Library lib, a libraries of routines
Print or view ps, dvi, gif ASCII or binary file
Archive arc, zip, tar related files groupedinto one file, sometimescompressed.
File Type Usual extension Function
![Page 9: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/9.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.9
Access Methods
• Sequential Accessread nextwrite next resetno read after last write
(rewrite)
• Direct Accessread nwrite nposition to n
read nextwrite next
rewrite n
n = relative block number
![Page 10: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/10.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.10
Directory Structure
• A collection of nodes containing information about all files.
F 1 F 2F 3
F 4
F n
Directory
Files
• Both the directory structure and the files reside on disk.
• Backups of these two structures are kept on tapes.
![Page 11: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/11.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.11
Information in a Device Directory
• Name
• Type
• Address
• Current length
• Maximum length
• Date last accessed (for archival)
• Date last updated (for dump)
• Owner ID (who pays)
• Protection information (discuss later)
![Page 12: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/12.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.12
Operations Performed on Directory
• Search for a file
• Create a file
• Delete a file
• List a directory
• Rename a file
• Traverse the file system
![Page 13: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/13.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.13
Organize the Directory (Logically) to Obtain
• Efficiency – locating a file quickly.
• Naming – convenient to users.
– Two users can have same name for different files.
– The same file can have several different names.
• Grouping – logical grouping of files by properties, (e.g., all Pascal programs, all games, …)
![Page 14: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/14.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.14
Single-Level Directory
• A single directory for all users.
• Naming problem
• Grouping problem
![Page 15: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/15.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.15
Tree-Structured Directories
![Page 16: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/16.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.16
Tree-Structured Directories (Cont.)
• Efficient searching
• Grouping Capability
• Current directory (working directory)
– cd /spell/mail/prog
– type list
![Page 17: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/17.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.17
Tree-Structured Directories (Cont.)
• Absolute or relative path name
• Creating a new file is done in current directory.
• Delete a file
rm <file-name>
• Creating a new subdirectory is done in current directory.
mkdir <dir-name>
Example: if in current directory /spell/mail
mkdir count
prog copy prt exp count
• Deleting “mail” deleting the entire subtree rooted by “mail”.
![Page 18: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/18.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.18
Shared Directories
• Have shared subdirectories and files.
![Page 19: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/19.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.19
Shared Directories (Cont.)
• Two different names (aliasing)
• Common in Unix systems because of long paths
• Shortcuts in Windows and Aliases on the MAC are a somewhat similar concept
![Page 20: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/20.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.20
Protection
• Can apply to both files and directories
• File owner/creator should be able to control:– what can be done– by whom
• Types of access– Read– Write– Execute– Append– Delete– List– Scan (Novell directory right)– Etc.
![Page 21: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/21.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.21
Access Lists and Groups
• Mode of access: read, write, execute
• Three classes of usersRWX
a) owner access 7 1 1 1RWX
b) groups access 6 1 1 0RWX
c) public access 1 0 0 1
• Ask manager to create a group (unique name), say G, and add some users to the group.
• For a particular file (say game) or subdirectory, define an appropriate access. owner group public
chmod 761 game
• Attach a group to a file
chgrp G game
![Page 22: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/22.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.22
Group Activity – File Structures
• Select an area– Access methods– Directory structures– Protection– Security– Consistency– Partition– Paging
• Identify– Key uses– Characteristics
• 1 Presenter
• 5-10 minutes
![Page 23: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/23.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.23
Module 11: File-System Implementation
• File-System Structure
• Allocation Methods
• Free-Space Management
• Directory Implementation
• Efficiency and Performance
• Recovery
![Page 24: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/24.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.24
File-System Structure
• File structure
– Logical storage unit
– Collection of related information
• File system resides on secondary storage (disks).
• File system organized into layers.
• File control block – storage structure consisting of information about a file.
![Page 25: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/25.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.25
Contiguous Allocation
• Each file occupies a set of contiguous blocks on the disk.
• Simple – only starting location (block #) and length (number of blocks) are required.
• Random access.
• Wasteful of space (dynamic storage-allocation problem).
• Files cannot grow except through system calls
• Very efficient technique – used by many databases
![Page 26: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/26.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.26
Linked Allocation
• Each file is a linked list of disk blocks: blocks may be scattered anywhere on the disk.
pointerblock =
![Page 27: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/27.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.27
• Allocate as needed, link together; e.g., file starts at block 9
![Page 28: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/28.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.28
Linked Allocation (Cont.)
• Simple – need only starting address
• Free-space management system – no waste of space
• No random access
• Ex: File-allocation table (FAT) – disk-space allocation used by MS-DOS and OS/2.
![Page 29: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/29.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.29
Indexed Allocation
• Brings all pointers together into the index block.
• Logical view.
index table
![Page 30: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/30.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.30
Example of Indexed Allocation
![Page 31: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/31.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.31
Indexed Allocation (Cont.)
• Need index table
• Random access
• Dynamic access without external fragmentation, but have overhead of index block.
![Page 32: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/32.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.32
Indexed Allocation – Mapping (Cont.)
outer-index
index table file
![Page 33: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/33.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.33
Combined Scheme: UNIX (4K bytes per block)
![Page 34: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/34.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.34
Free-Space Management
• Bit vector (n blocks)
…
0 1 2 n-1
bit[i] = 0 block[i] free
1 block[i] occupied
• Block number calculation
(number of bits per word) *(number of 0-value words) +offset of first 1 bit
![Page 35: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/35.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.35
Free-Space Management (Cont.)
• Bit map requires extra space. Example:
block size = 212 bytes
disk size = 230 bytes (1 gigabyte)
n = 230/212 = 218 bits (or 32K bytes)
• Easy to get contiguous files
• Linked list (free list)
– Cannot get contiguous space easily
– No waste of space
• Grouping
• Counting
![Page 36: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/36.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.36
Free-Space Management (Cont.)
• Need to protect:
– Pointer to free list
– Bit map Must be kept on disk Copy in memory and disk may differ. Cannot allow for block[i] to have a situation where bit[i] =
1 in memory and bit[i] = 0 on disk.
– Solution: Set bit[i] = 1 in disk. Allocate block[i] Set bit[i] = 1 in memory
![Page 37: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/37.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.37
Directory Implementation
• Linear list of file names with pointer to the data blocks.
– simple to program
– time-consuming to execute
• Hash Table – linear list with hash data structure.
– decreases directory search time
– collisions – situations where two file names hash to the same location
– fixed size
![Page 38: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/38.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.38
Efficiency and Performance
• Efficiency dependent on:
– disk allocation and directory algorithms
– types of data kept in file’s directory entry
• Performance
– disk cache – separate section of main memory for frequently sued blocks
– free-behind and read-ahead – techniques to optimize sequential access
– improve PC performance by dedicating section of memroy as virtual disk, or RAM disk.
![Page 39: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/39.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.39
Various Disk-Caching Locations
![Page 40: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/40.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.40
Recovery
• Consistency checker – compares data in directory structure with data blocks on disk, and tries to fix inconsistencies.
– Scandisk (MS-DOS)
– fsck (Unix)
• Use system programs to back up data from disk to another storage device (floppy disk, magnetic tape).
• Recover lost file or disk by restoring data from backup.
![Page 41: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/41.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.41
Group Activity – Efficiency, Etc.
• Select an area– Free space management– Directory implementation– Recovery– Security
• Identify:– Key uses– Characteristics
• Choose presenter
• 5-10 minutes “whiteboard”
![Page 42: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/42.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.42
Next Week: Workshop 5
• Midterm review
• Homework review: 12.4, 13.2, 14.1
• Study group mini presentation
• Lecture & discussion on I/O devices
• Group activity – secondary storage (30 minutes)
• Lecture 7 discussion on I/O control
• Group activity – I/O performance (40 minutes)
• Summary & preview of next workshop
![Page 43: Workshop 4: Agenda](https://reader036.vdocuments.site/reader036/viewer/2022062809/5681582b550346895dc59039/html5/thumbnails/43.jpg)
Operating System Concepts Silberschatz and Galvin1999 10.43
Next Study Group Milestone
• Peripherals & I/O– I/O design– Interfaces– Internal system structures
• 3-5 page paper
• Presentation