UNIX Tutorial Five
UNIX Tutorial Five
Each file (and directory) has associated access rights, which may be found by typing ls -l. Also, ls -lg gives additional information as to which group owns the file (beng95 in the following example): -rwxrw-r-- 1 ee51ab beng95 2450 Sept29 11:52 file1 In the left-hand column is a 10 symbol string consisting of the symbols d, r, w, x, -, and, occasionally, s or S. If d is present, it will be at the left hand end of the string, and indicates a directory: otherwise - will be the starting symbol of the string. The 9 remaining symbols indicate the permissions, or access rights, and are taken as three groups of 3.
The left group of 3 gives the file permissions for the user that owns the file (or directory) (ee51ab in the above example); the middle group gives the permissions for the group of people to whom the file (or directory) belongs (eebeng95 in the above example); the rightmost group gives the permissions for all others.
The symbols r, w, etc., have slightly different meanings depending on whether they refer to a simple file or to a directory.
r (or -), indicates read permission (or otherwise), that is, the presence or absence of permission to read and copy the file w (or -), indicates write permission (or otherwise), that is, the permission (or otherwise) to change a file x (or -), indicates execution permission (or otherwise), that is, the permission to execute a file, where appropriate
r allows users to list files in the directory; w means that users may delete files from the directory or move files into it; x means the right to access files in the directory. This implies that you may read files in the directory provided you have read permission on the individual files.
So, in order to read a file, you must have execute permission on the directory containing that file, and hence on any directory containing that directory as a subdirectory, and so on, up the tree.
Some examples
-rwxrwxrwx a file that everyone can read, write and execute (and delete). -rw------a file that only the owner can read and write - no-one else can read or write and no-one has execution rights (e.g. your mailbox file).
r w x + -
read write (and delete) execute (and access directory) add permission take away permission
For example, to remove read write and execute permissions on the file biglist for the group and others, type % chmod go-rwx biglist This will leave the other permissions unaffected. To give read and write permissions on the file biglist to all, % chmod a+rw biglist
Exercise 5a
Try changing access permissions on the file science.txt and on the directory backups Use ls -l to check that the permissions have changed.
This will wait 10 seconds before returning the command prompt %. Until the command prompt is returned, you can do nothing except wait. To run sleep in the background, type % sleep 10 & [1] 6259 The & runs the job in the background and returns the prompt straight away, allowing you do run other programs while waiting for that one to finish. The first line in the above example is typed in by the user; the next line, indicating job number and PID, is returned by the machine. The user is be notified of a job number (numbered from 1) enclosed in square brackets, together with a PID and is notified when a background process is finished. Backgrounding is useful for jobs which will take a long time to complete.
For example, to restart sleep 1000, type % fg %1 Typing fg with no job number foregrounds the last suspended process.
ps (process status)
Alternatively, processes can be killed by finding their process numbers (PIDs) and using kill PID_number % sleep 1000 & % ps PID TT S TIME COMMAND 20077 pts/5 S 0:05 sleep 1000
21563 pts/5 T 0:00 netscape 21873 pts/5 S 0:25 nedit To kill off the process sleep 1000, type % kill 20077 and then type ps again to see if it has been removed from the list. If a process refuses to be killed, uses the -9 option, i.e. type % kill -9 20077 Note: It is not possible to kill off other users' processes !!!
Summary
Command ls -lag Meaning list access rights for all files
chmod [options] file change access rights for named file command & ^C ^Z bg jobs fg %1 kill %1 ps kill 26152 run command in background kill the job running in the foreground suspend the job running in the foreground background the suspended job list current jobs foreground job number 1 kill job number 1 list current processes kill process number 26152