Table of Contents
File Systems
Definition
- Reference: S&G, Chapter 10
- file system: a collection of files stored either on disk or tape
- maintained by a part of the operating system called the
file system manager
- Features of a File System
- may contain large amounts of information
- persistent: information is retained even when no process
is using it
- a file system can be accessed by many processes at once, where many
processes are between starting and finishing using files
Two Views of the File System
- Logical View (User View): abstraction of the file system presented to the user
- Physical View: how this abstraction is provided by the file manager using disks
-
Logical View of a File System
a)
- commands: create, delete, open, close, read, write, append, seek
- b)
- names for files: main.c , file.bak
- c)
- structure of the file system
- i)
- flat directory (one directory)
- ii)
- two-level directory
- iii)
- tree-structured directory (hierarchial directory)
- iv)
- acyclic graph directory structure (no cycles)
So, what happens when you use cd .. command?
Types of Linking
- a)
-
symbolic linking
- slower in use
- can link to a file whose content changes
- can link across file systems (and machines under NFS)
- In UNIX, adding a symbolic link has no effect on the original
file and in particular has no effect on the linkcount
- if person A creates a file and person B links to it, when A
deletes it, the link fails when B tries to use it
- Example:
% ln -s /usr/w/h usr/local/h
% rm /usr/w/h/
% cat /usr/local/h
UX:cat: ERROR: Cannot open /usr/local/h: No such file or directory
- b)
-
hard link
- creates a new ``true name'' for the file
- the file is only removed when no links to it remain
- you create the file, set linkcount (stored in i-node) = 1
- someone links to the file so linkcount = 2
- you delete the file, so linkcount = 1 but the file is kept
- complication: you own a file that you no longer have any
access to
- Example:
% ln /usr/w/h /usr/local/h
% rm /usr/w/h
% cat /usr/local/h # still works because file still exists
Access Control (File Protection)
- Reference: S&G, Section 10.4 and Chapter 13
- each domain defines a set of objects (i.e., files) and the types
of operations that may be performed on each object
- in the simplest case, a domain is a user
Some Privileges
data:image/s3,"s3://crabby-images/d14cd/d14cd51416babc17bbf4f9c84d0759bb6cee5c66" alt=""
Example Access Matrix
data:image/s3,"s3://crabby-images/2e719/2e719368e0f3fc1fae3674ce95407dc70b57ff48" alt=""
Other Privileges from S & G
data:image/s3,"s3://crabby-images/32498/324986593d12d9e3fcd9c89be91e66fca1297221" alt=""
Capability List
- for every domain, list the objects and their privileges (only
objects for which the subject has some privileges)
/fred/mail /fred/prog /fred/prog.c
freddata:image/s3,"s3://crabby-images/f294c/f294cf9d02eeddd3b4e909216b7bd2b350be5efe" alt=""
data:image/s3,"s3://crabby-images/4337c/4337c857660a18b1ab7bdf7dcfb1af4470fec1ce" alt=""
data:image/s3,"s3://crabby-images/993ac/993ac5037363e68c421ef32221206f22c1f6e98f" alt=""
data:image/s3,"s3://crabby-images/2af85/2af85289913f00f9a45d16bc485f9675c7e0b511" alt=""
/fred/mail /sam/loveletter /fred/prog
samdata:image/s3,"s3://crabby-images/7aac3/7aac399c4be4c16f985fccb622ecd5d03a3043e7" alt=""
data:image/s3,"s3://crabby-images/3b0f8/3b0f86c88e296c38ff5ad9309d0bfc7786eee64c" alt=""
data:image/s3,"s3://crabby-images/d7f4b/d7f4bc2450cc250c4dced27b34ca1f311f7966a2" alt=""
data:image/s3,"s3://crabby-images/b8fff/b8fff04284c6f373790bcf34b407ba2e0dcaad27" alt=""
data:image/s3,"s3://crabby-images/3e4bd/3e4bdd7c1cfd3b13d2604a705a72cd83be7cb600" alt=""
/fred/mail /fred/prog
kellydata:image/s3,"s3://crabby-images/64159/641592247be119703bf3d96cedf85ae15aa95eec" alt=""
data:image/s3,"s3://crabby-images/c76cf/c76cf89deceeab76e2c9b38cdb6e515fd7d819ec" alt=""
data:image/s3,"s3://crabby-images/51efa/51efaea438c7c4403c504f25bf9015c71be58aa2" alt=""
/fred/mail /sam/loveletter /fred/prog.c
margdata:image/s3,"s3://crabby-images/44256/44256b80c091be179cfa0247c39930b07b54010f" alt=""
data:image/s3,"s3://crabby-images/e9b52/e9b524b7f05ca4e7c5cb1d02b269937b332c1a71" alt=""
data:image/s3,"s3://crabby-images/d4b9d/d4b9daa8bb27678c860b265aa7a58f4ed14ba1c2" alt=""
data:image/s3,"s3://crabby-images/3b6b0/3b6b00d796715c8b8fa844a939c10aaccbb29707" alt=""
Access List
- for every object, list the domains and their privileges (only objects for
which the subject has some privileges)
fred sam kelly marg
/fred/maildata:image/s3,"s3://crabby-images/1a5b8/1a5b8377833103220243142f2e92652473c1d22e" alt=""
data:image/s3,"s3://crabby-images/03708/03708e27fb190c32db3c679e5084d091c5be70f5" alt=""
data:image/s3,"s3://crabby-images/36a8d/36a8d5205e593e898bd278ea7b6152e144112443" alt=""
data:image/s3,"s3://crabby-images/da715/da7151b455a8f84e4317f01a77c8055d55b62461" alt=""
data:image/s3,"s3://crabby-images/67872/6787292a3686c30501edb49ac52f9a889ceb00db" alt=""
data:image/s3,"s3://crabby-images/d24a4/d24a427f87aa8e807e8936243119c505bda6e07b" alt=""
sam marg
/sam/loveletterdata:image/s3,"s3://crabby-images/22f95/22f953f5890ab369c0ffaed4be884226c08c3d72" alt=""
data:image/s3,"s3://crabby-images/3485e/3485ea19ae589b76fcaa38938450692b3bcac6dc" alt=""
data:image/s3,"s3://crabby-images/6d316/6d316bd15520244b15e0f5ea563c6d830827477e" alt=""
fred sam kelly
/fred/progdata:image/s3,"s3://crabby-images/76c6b/76c6b107d9ac0f8dab614da1ae82507b0cae0fd4" alt=""
data:image/s3,"s3://crabby-images/57717/5771787d199d3570bf4f9b2773d48f0400b964bd" alt=""
data:image/s3,"s3://crabby-images/f3870/f38704671318495a020efe333000cb0d039ff3db" alt=""
data:image/s3,"s3://crabby-images/35803/35803cb02e5291bc05966c8969f36910fd5b52a5" alt=""
fred marg
/fred/prog.cdata:image/s3,"s3://crabby-images/a8627/a8627d0522057fcd0a23ea3f0b10930801d2c523" alt=""
data:image/s3,"s3://crabby-images/9df12/9df126aa37b88173bca216371457452e5f15c443" alt=""
data:image/s3,"s3://crabby-images/49bfa/49bfa71ccb2e3df4d7513681d740d83ddedcd8ab" alt=""
In UNIX:
- We classify the users into three catagories.
- Thus, from each user's perspective, there are three domains.
- Simplified access list:
- u = user (me)
- g = others in my group (group)
- w = any other user (world)
me mygroup others
file
Return to Contents