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/e37b0/e37b03fbec18c40ef9141e6bb3619fb880701ed4" alt=""
Example Access Matrix
data:image/s3,"s3://crabby-images/47668/47668b78e1ca32d9c27fb409a8bb27535189c20b" alt=""
Other Privileges from S & G
data:image/s3,"s3://crabby-images/36843/368433d32d10447e2ae3703a977e259e20b1a2fd" 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/9258c/9258c809b1952381d41d679f55a003eae27d56d3" alt=""
data:image/s3,"s3://crabby-images/20374/203747dd6c306329730b0edc193ac0f4bbaf4e3d" alt=""
data:image/s3,"s3://crabby-images/66dba/66dbacfd2696fc3ff4d0215afa7440817bf28074" alt=""
data:image/s3,"s3://crabby-images/a0d0a/a0d0ad2e3783c359f4a31be9954f538be0ca5299" alt=""
/fred/mail /sam/loveletter /fred/prog
samdata:image/s3,"s3://crabby-images/69fef/69fef0508d054f578cb5994d6fefbd6347cb67c7" alt=""
data:image/s3,"s3://crabby-images/4da63/4da6338162473b900af9346a3ee4613d6a749fc6" alt=""
data:image/s3,"s3://crabby-images/7d2f9/7d2f951729fd41c661117f862109b217023c025f" alt=""
data:image/s3,"s3://crabby-images/4b070/4b0708fbf5b6cae7dd173197fe9835c22009a70f" alt=""
data:image/s3,"s3://crabby-images/2afc1/2afc172196af31f221dd88c4bc521f0b3a6e8139" alt=""
/fred/mail /fred/prog
kellydata:image/s3,"s3://crabby-images/df690/df69082b84b589b7172835990c6578d2812db369" alt=""
data:image/s3,"s3://crabby-images/19eeb/19eeb79efcf806ebb8274f954270ba0c2034b7a1" alt=""
data:image/s3,"s3://crabby-images/9fea4/9fea4006cfc0e66245b9e3daf1468d7538894ca8" alt=""
/fred/mail /sam/loveletter /fred/prog.c
margdata:image/s3,"s3://crabby-images/84f30/84f3043b1af83143aead5a9636cd98fb4313f11d" alt=""
data:image/s3,"s3://crabby-images/d99d3/d99d36ef90144f67c4787453c8adb664a6226081" alt=""
data:image/s3,"s3://crabby-images/5541c/5541c3b401464c87847b88a771ec47bb7cdee22e" alt=""
data:image/s3,"s3://crabby-images/09346/093466f3c84b8cfcb5dc39c3ea0720d69d48cafa" 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/353a6/353a6748d9eb11e87f06503eccc668f7963869f1" alt=""
data:image/s3,"s3://crabby-images/687c5/687c545d5020d0cfa0f223199f8b414a1e593a4f" alt=""
data:image/s3,"s3://crabby-images/6d4c7/6d4c70a69da2f2c1c9084e38a7d36c18bc51275a" alt=""
data:image/s3,"s3://crabby-images/29f02/29f02f22315f5a2f6a408809e7715a3d29b31470" alt=""
data:image/s3,"s3://crabby-images/37c6a/37c6ace9994b96c6ca66e408c641cb33d9f73fd2" alt=""
data:image/s3,"s3://crabby-images/c50e0/c50e0739622d309511718304b54bce94b54c6929" alt=""
sam marg
/sam/loveletterdata:image/s3,"s3://crabby-images/cbb51/cbb5134052ce1ca33ed998b3fb1a16783c5c11f0" alt=""
data:image/s3,"s3://crabby-images/d6010/d6010f6a54ba4034814de8cf9e7096be690fa168" alt=""
data:image/s3,"s3://crabby-images/12c74/12c74c5eabe1f7f97e72ab0bc86fccab0b771aff" alt=""
fred sam kelly
/fred/progdata:image/s3,"s3://crabby-images/ee3e2/ee3e2b575e7bbdbd338144dbde7b3246643074cb" alt=""
data:image/s3,"s3://crabby-images/5a235/5a235909797fe904f8254e34557bdc1be1a2c4a9" alt=""
data:image/s3,"s3://crabby-images/f2e00/f2e00b499be35504e3ebaeedf4385c709c23c4f0" alt=""
data:image/s3,"s3://crabby-images/8d411/8d411482b915a0feea4760e27fe42094b9cbf3d3" alt=""
fred marg
/fred/prog.cdata:image/s3,"s3://crabby-images/2063d/2063d391ecab864d0c990bb9e2d0aa93df2aa9af" alt=""
data:image/s3,"s3://crabby-images/1706e/1706e77aa2023fe2535bf35e9aae0ee51ab0bc0d" alt=""
data:image/s3,"s3://crabby-images/994d1/994d17133fdaa8ebe31a80fd99410851db50c88e" 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