Solaris Files and Directory 2015
Solaris Files and Directory 2015
Solaris Files and Directory 2015
Ordinary
- This contains data. One form of file is a text file however this
category also includes files created by applications or indeed the applications
themselves.
Directory
- This is a special kind of file that acts like a table of contents
allowing the organisation of files (see later in this section).
Special Files - UNIX operating systems allow you to access logical devices
by creating virtual files that refer to them. These are found in the /dev
directory. For example /dev/tty1 refers to a TTY screen, /dev/cd0 refers to a
CD-ROM etc. One particular file is /dev/null which is a pointer to nothing.
You may wonder why you would want a file that didn't point at anything,
however this can be useful where you get an output that is not needed.
Redirecting the output to /dev/null will cause it to disappear.
The number of files on a computer can be in the thousands. To have these in one place
would make it very difficult to find what you wanted. Searching a list of thousands of
files would be equivalent to searching for a needle in a haystack. The files are
therefore collected together by commonality. These are put into groups called
directories. To make it even easier these are sorted into a hierarchical tree. Moving
down the hierarchical structure allows you to find more specific files.
The files and directories are referred to by filenames. The filenames can be quite long
(up to several hundred characters with some implementations). They can contain any
letters, digits and punctuation (including spaces). It is however better to avoid any
special characters and especially spaces. This is particularly important in a command
line environment like UNIX where it is necessary to interpret the differences between
a single filename with spaces and two separate parameters. See creating a new file for
more rules on filenames.
The directory structure starts at the root directory which is known by a forward slash
'/'. Each directory below the root has it's own name and is separated by the forward
slash '/'. Below the root directory are a number of "Top level Directories" Common
top level directories include home; usr; var; tmp and etc
These are used for the following purposes:
home - This directory is used as a starting point for users home directories. These are
directories that are given to users for them to store any files they create. The
users directory is a subdirectory to home normally the same name as the
username. e.g. /home/stewart
usr - This directory is used to store installed user applications.
34
var - This is used for files of variable length. Files that change a lot such as log files
would be kept here.
tmp - If used this directory is used for temporary files that are only needed for a short
period of file. Some systems use housekeeping jobs to periodically delete files
in this directory so important files should not be stored here.
etc - This directory holds many of the configuration files used by applications.
bin or sbin - Whilst you may see bin or sbin directories at the top level these are
normally symbolic links to the directories /usr/bin or /usr/sbin respectively.
The bin directory carries executable programs that can normally be run by
anyone, whereas the sbin directory is for programs intended for the superuser
only.
lib This directory holds additional binary files used by programs. It is actually a link
to /usr/lib
export This directory is used by NFS when configured as an NFS server
opt Used to install programs. The name refers to optional programs, although
effectively applications (or the installer) can choose to install in either
/usr/local or in /opt. The opt directory is normally used for complete
applications and /usr/local for smaller command line programs.
There are some other top level directories that are used as starting points for other
directories.
dev - This is used to hold the devices available on the system. For example the first
hard disk (hdisk0) can be referred to as /dev/hdisk0
devices This directory holds the actual device drivers. This is different to /dev which
provides an easier to use logical representation of the devices.
mnt - This is the mount point which is used as a convenient place to attach other
devices such as floppy disk drives and CD-ROM Drives. For example the
CDROM drive may be mounted as /mnt/cd0/ although the name does not have
to be the same as the device name.
proc This is a special case directory holding information about the running system.
kernel Another special directory used to represent the running kernel.
These then subdivide into further directories, the are known as subdirectories. The
directory structure can be represented as a tree.
35
stewart
bin
home
/
(root)
usr
local
bin
sbin
sbin
man
man1
man2
etc
The above tree is far from complete there can actually be over a hundred directories
on a UNIX installation.
The full directory path name starts with the root directory (/) and move up the tree
with each directory separated by a forward slash. For example the man2 directory
would have a full path of
/usr/local/man/man2
Relative Directories
So far we've been looking at the directory name in full this is known as the "absolute
directory". As well as being able to specify the directory in full (starting with root) it's
also possible to specify a "relative directory". To specify the relative directory start
from the current position and specify the rest of the directory name. The difference
between an absolute and relative directory is that an absolute directory always have a
'/' at the start of the path whereas a relative directory will not. If already positioned at
the directory /usr/local the man2 directory can be referenced by man/man2
Special Directories
There are 2 special directory names that apply to all the subdirectories. The current
directory is marked by a single dot (.) whereas the further up can be referenced by a
double dot (..) .
The man2 directory can be referenced from the /usr/local/bin directory with the
relative path ../man/man2
36
You can check the current directory at any time by issuing the pwd command (this
stands for print working directory).
You can move around the directories by using the cd (change directory command). To
change directory use cd followed by either the absolute or relative directory (as
detailed earlier).
Here's a few examples of how to change directory
Command
cd
cd /
cd /usr/local/man
cd local/man
cd ..
What it does
Moves to your home directory. Normally
/home/username
Moves to the root directory
Moves to the man directory (absolute path) this
will work no matter what directory you are
currently in.
Moves from the current directory (relatively). If
you are currently in the /usr directory this
command is identical to the above command.
Moves up a level. If you were at /usr/local/man
you would now be at /usr/local
Here I've moved to the usr directory. Displayed the current working directory and
then listed the contents of the directory. In my home directory is one file and one
subdirectory. You cannot tell for certain from the view above (although you could
guess from there names) which is the file and which is the subdirectory.
One way of telling is to use ls with the -l option which shows a lot more information.
37
$ ls -l
total 636
drwx------rw-------
2 stewart
1 stewart
users
users
Using this display you can tell that docs is the directory.
As far as UNIX is concerned a directory is just a special type of file so is displayed
along with the other files. From the mode display (this is the 10 characters at the left
of each file displayed) the first character shows what type of file it is. The remaining 9
characters show the file permissions however these will be dealt with later.
There are seven different file types, which are listed in the table below.
File Type
Letter
d
l
b
c
p or s
Description
Regular File
Directory
Symbolic Link
Block Special File
Character Special File
Other Special files (not covered)
Here's an explanation of the Listing format shown earlier with the ls -l option.
38
(1)
drwx------rw-------
1.
2.
3.
4.
5.
6.
7.
(2) (3)
2 stewart
1 stewart
(4)
users
users
(5)
(6)
(7)
512 Sep 16 17:42 docs
124 Sep 16 17:26 readme.txt
(filename)
(Absolute)
(relative)
There is also another way of referring to the current directory using a single dot '.' .
This is particularly important when running a program. Some programs that haven't
been installed in the standard program directories need to be run by specifying it's
directory and filename. The directory can be absolute or relative however when the
file is in the current directory the filename alone is not sufficient. To get around this
the file is referred to using the dot directory. For example is there is a program called
exec in the current directory this would be run by using ./exec
Hidden Files
Whilst you can normally see the files in a directory using the ls command it is also
possible to hide some. The normal reason for hiding a file is so that curious users
dont edit or delete the file by mistake.
To hide a file all that is needed is for the name to begin with a period .
For example the file .profile is normally hidden from view. To view a hidden file use
the a option when using the ls command.
Lost + Found
There is a special directory name called lost+found. Sometimes when the system
crashes it may "lose" a file. If this happens when the system runs it's checks it will
store them in the lost+found directory so that any information held in them can be
recovered.
39
41
Chapter
43
Whilst this is often the most common use of the touch command it has other uses as
well. For example the touch command can be used to change the creation date or
other properties of a file.
44
The safest way to delete a directory is to first remove all files from the directory. Then
check the directory is empty by issuing ls -a (the -a will show all files even if they are
hidden). Then change to the directory above and type
rmdir dirname
The rmdir command will only work when the directory is already empty which
provides a little protection against accidentally deleting files.
For a more cavalier way of removing a directory or multiple directories the rm
command can be used. To do this type rm -r followed by the directory name. For
example:
rm -r dirname
45
Files can be copied using the cp command. Enter cp followed by the existing file and
then the new file (can include paths). Putting the 2nd parameter (new file) as a
directory name will copy the file to another with the same name in the new directory.
Using the -i option will prevent accidentally overwriting an existing file if it exists.
Wildcards can also be used to copy multiple files into different directories.
There is also a cpio command that is more versatile and allows the copying of
directories and files within them. View the man pages for more information on the
cpio command.
46
additions to the file. If however the file has not been changed then the previous output
will be redisplayed or if the file has changed too much then some lines may be
missed. The better way is to use the -f option, which will display any new lines that
are added to a file.
tail -f filename
Printing a file
To put a file on the print queue use the following command.
lp filename
You may need to specify the printer (see man lp for more details). If you are using an
X-Windows application then there is normally a print function included within the
application and this could be used instead.
File Permissions
UNIX systems are designed to have multiple people using them, and as such there are
controls on what each user can be done. So a user may create a file on the system that
others can view, but not change, or that only certain people can see. You cannot
however prevent the root user from accessing the file as they have full permissions to
all files on the system.
File permissions are split into 3 different categories. These apply to:
user - the owner of the file
group - a group of people, e.g. a project team or department
others - anyone else that has a login to the computer
these are then split into 3 different permissions, that of being able to:
47
read - Look at the contents of a file / find out what files are in a directory
write - Change or delete the contents of a file / create or remove files in a directory
execute - Can execute (run as a program) a file / can change to the directory or copy
from the directory.
These are represented by the letters r, w and x respectively.
These can be seen by using ls l on a file:
/home/stewart/test $ ls
total 14
drwxr-x--2 stewart
-rw-r--r-1 stewart
-rw-rw---1 stewart
-rw-rw-rw1 stewart
-l
stewart
group01
group01
stewart
512
27
31
3502
Jan
Jan
Jan
Jan
7
7
7
7
15:13
15:14
15:14
15:15
dir1
file1
groupedit.txt
public.txt
The first few columns represent the file type and permissions:
d rwx rwx rwx
others
group
user
Is a directory
If the entry is filled in then it has affect if it is dashed out '-' then it does not apply.
There are also further permissions that can be set, however these are more advanced
and are outside of the scope of the user guide.
48
In symbolic format permissions are added or deleted using the following symbols:
u = owner of the file (user)
g = groups owner (group)
o = anyone else on the system (other)
+ = add permission
- = remove permission
r = read permission
w = write permission
x = execute permission (if the file is a program then this gives permission to run it)
For example from the previous ls entry we have a file called file1 which we would
like the group to be able to write to:
-rw-r--r--
1 stewart
group01
27 Jan
7 15:14 file1
Using symbolic format we just need to add write access to the group which can be
done using:
chmod g+w file1
In Octal format the mode is based upon a octal number representing the different
mode permissions, where each of the permission groups (user, group, others) has an
octal value representing the read, write and execute bits. This requires a little bit of
knowledge on binary and octal number bases.
To use the octal format we dont just put the changes, but issue the command on the
entire permissions for the file.
Symbolic
Binary
Octal
User
rwx
111
4+2+1
7
Group
rw110
4+2+0
6
Others
r-100
4+0+0
4
The file permissions would therefore have the octal number 764 and would therefore
be changed using the command
chmod 764 file1
A basic way of working this out is to add the following numbers depending upon the
permission required.
Read = 4
Write = 2
Execute = 1
49
Therefore if you wanted to set read to yes, write to no and execute to yes, this would
be 4+1=5
51
Chapter
53
Whilst the number of options on each UNIX command may seam overwhelming at
first this is part of what makes UNIX so powerful. Another of the features that makes
UNIX so powerful is the ability to combine several commands to make them more
useful. This can be achieved either by stringing commands together on the command
line or by bundling the commands together into a script file which can range from
something very trivial to a program in it's own right. I will not discuss scripts further
in this book (see volume 7) however I will show how multiple commands can be
combined.
$ ls
docs
readme.txt
smit.log
smit.script
$ ls -l
total 636
drwx------rw-------
2 stewart
1 stewart
users
users
54
The first command is entered first followed by the pipe command and then followed
by the second command. Any output from the first command is then used as input to
the second command.
For example to sort a basic directory listing by name the ls command is piped through
the sort command.
ls | sort
The output can be redirected through any number of pipes each one changing the
output in someway. The full command is referred to as a pipeline.
55
It is also possible to write both stdout and the standard error stream to the same file.
This is not simply a case of using the same file name in the above command as you
might expect. The reason for this is that a file can only be opened for writing by one
process at a time. The two redirects are two different processes and would not allow
both streams to write to the same file. This can however be achieved by redirecting
the error data stream to the stdout data stream using 2>&1. Which now gives:
command >output.file 2>&1
In a similar light you cannot use a file used as input to the command to redirect the
output to. For example it is not valid to issue the following command
sort file1 >file1
instead the output would have to be redirected to a temporary file and then renamed to
the required name.
sort file1 >/temp/tmp$$
mv /tmp/tmp$$ file1
The file ending in $$ will actually be created by the system with a unique number.
This is useful for temporary files as it prevents you overwriting a temporary file in use
by a different process.
The use of stdin, stdout and stderr is possible using only the single less than / greater
than signs because of the way that processes are assigned to a file descriptor table.
The file descriptor table is a list of numbers relating to open files. The first 3 files to
be opened are stdin, stdout and stderr, these are numbered 0 for stdin, 1 for stdout and
2 for stderr. Therefore stdin and stdout can be referred to by < and > respectively (no
further filename) whereas stderr requires 2> to ensure it is output stream numbered 2
that is to be redirected.
These redirects are fine for use in batch programs that are run without anyone
monitoring the system. Sometimes it is necessary for someone to monitor the output
of the command but also for it to be duplicated into a file for logging purposes or to
perform further processing on.
The tee command is used within a pipeline and whatever input it receives it both puts
into a file and forwards on the pipeline.
command | tee file1
The line above will take any output from the command and put a copy in file1 as well
as sending it to the screen. This could be combined further by allowing the output to
be further processed by another command. The tee command can be used any number
of times in a pipeline like this.
command1 | tee file1 | command2
56
If you want tee to append to a file rather than overwrite it the -a option is used.
The same basic redirect can also be done in the reverse direction in that an interactive
program that requires input from a user can be automated. For example with an
interactive program such as ftp (file transfer protocol). The ftp program allows files to
be transferred from one computer to another over a network. This however needs a
user to type the commands in to transfer the file. Instead the commands should be
entered into a text file the same as how they would be entered from the keyboard. The
file is then directed into the program in place of the stdin.
ftp rs6k.mynet.com <commands.txt
Redirecting to a file can have an unfortunate consequence if the file already exists and
does not want to be replaced. By using the redirects incorrectly it is possible to
accidentally overwrite an important file. In the korn shell there is an option that allows
us to prevent overwriting files by mistake. This is the noclobber option and is set by
typing
set -o noclobber
If an attempt is now made to overwrite a file the shell will issue an error message and
prevent the file being written to. The no clobber option can be turned off using
set + noclobber
If required the noclobber option could be put an a users .profile to have this set
automatically.
57
Chapter
59
Whenever you login to a UNIX machine using your username then certain things will
be automatically setup. These will be different for different users on the system and to
an extent can be customised by you. I will explain where some of the settings
originate from, even though you may not be able to change them. At least then you
will appreciate why the machine is behaving as it does.
Shell Variables
Whilst you are in the shell there are a number of variables that the shell needs to be
aware of. These could typically hold information about you, about the shell you are
running in, or about your personal preferences. For example the shell needs to know
what your home directory is, so that you can easily change directory or save files. It
stores this in the $HOME variable.
Another variable commonly used is the $TERM variable. This describes the type of
terminal you have so that the shell or applications know how to send control the
60
screen. For example a vt100 terminal may have a different command to clear the
screen than is used by a Wyse Terminal.
There is another one that you may need to change which is the $PATH variable. This
indicates which directories the shell will look in to find a program that youve asked
to be run.
Normally all system defined variables are in uppercase whereas user variables are in
lowercase.
You can list all variables by using the set command.
e.g.
$ set
HOME=/export/home/stewart
IFS=
LOGNAME=stewart
MAIL=/var/mail/stewart
MAILCHECK=600
OPTIND=1
PATH=/usr/bin:/bin:/usr/sbin:/sbin
PS1=$
PS2=>
SHELL=/sbin/sh
SSH_CLIENT=192.168.2.3 62880 22
SSH_TTY=/dev/pts/5
TERM=ANSI
TZ=GB
USER=stewart
One instance that you may need to change a setting is if you connect to the Solaris
machine by using telnet from a Windows 9x machine. If you use the standard telnet
client then you will probably end up with a terminal type of ANSI (see TERM in
above screenshot). Whilst you may be able to issue commands normally many full
screen applications will not work. See the following error when trying to use the vi
editor:
$ echo $TERM
ANSI
$ vi test.txt
ANSI: Unknown terminal type
[Using open mode]
Segmentation Fault
$
The echo command is used to display the value of $TERM to confirm what it is
defined as.
The rather cryptic error message is basically saying that it cannot run because it does
not know how to control a terminal defined with type ANSI.
61
To overcome this you first need to change the value of the variable. The windows
telnet command supports ANSI/vt100 under the same profile, therefore we can try the
vt100 terminal type which is better supported by UNIX. The following shows what
the effect of changing the value is:
$ TERM=vt100
$ echo $TERM
vt100
$ vi test.txt
ANSI: Unknown terminal type
[Using open mode]
Segmentation Fault
$
Note that I have used the correct command to change the TERM variable (ie.
TERM=vt100). The $ sign is not used when changing the variable.
The echo command confirms that it has been changed however the application still
failed.
Looking at the error message he problem is that it does not know about the ANSI
terminal type. But havent we just changed it to vt100, why is it complaining about us
having a ANSI terminal defined? Either Im lying or the program is still trying to use
the old value.
The reason that this doesnt work is that the value changed is the variable being used
by the current shell we are using (remember this is a program normally either sh or
ksh). When we start a new program, or indeed a new shell it runs as a child and does
not have access to the variable changed in the new shell. See the following example:
$ echo $TERM
vt100
$ ksh
$ echo $TERM
ANSI
$ exit
Here I have displayed the $TERM variable (vt100). I then started a new child shell
(ksh) and then displayed the $TERM variable again. Inside the child shell the variable
is now back to the original ANSI. A similar thing is happening whenever we run a
program. Fortunately there is a command that lets you set a variable so that it is
passed to any new child shells. The command is export. Now we try the commands
again:
$ TERM=vt100
$ export TERM
$ vi test.txt
This time the vi program runs successfully. If you run the ksh command again and
echo the $TERM variable you will notice that that too has changed to $TERM.
62
You can get rid of a variable by using the unset command. It is better not to remove
any system-defined variables (unless you really do know what your doing), however
you may have created your own variable that is no longer needed. The following
example creates a new variable before removing it.
$ MYVARIABLE="UNIX is great"
$ echo $MYVARIABLE
UNIX is great
$ unset MYVARIABLE
$ echo $MYVARIABLE
$
Below are a list of some other variables you may come across:
LOGNAME - This holds your login name for use by certain commands. This
is one variable that cannot be changed.
MAIL - This holds the name of the file where your mail is sent
MAILCHECK - How often the shell will check to see if you have new mail
TERM - The terminal type you are using / emulating
umask - This determines what permission bits will be set when a new file is
created. This is a mask so an inversion will give you the default file settings.
E.g. the default of 022 will create a new directory with 755 (user can read,
write, execute everyone else can read, execute). When a regular file is created
the execute bit is not set so you would get 644. You may want to make this a
little more secure by setting to 027 (don't give any permissions to other users)
or even 077 (only give owner permissions). See the book on security for more
details.
PATH - This is a colon separated list of all the directories that will be
searched to find a command typed in by the user. Some people add a :. to this
string to say if the command is not found in the rest of the path then try the
current directory, however there are security issues associated with this (see
security section) and certainly this should not be set for the root user.
PS1 - This is the system prompt and is set to a $ by default. You may want to
change this to include your current directory name using the command:
PS1='$PWD $'
ENV - Not included by default it can be useful to add this to your .profile. To
set the shell environment file to .kshrc (this is the normal name for the Korn
Shell) you would include the following line:
export ENV=$HOME/.kshrc
This is especially useful if using a X-Windows where the .profile is not called
when you start a new xterm.
.profile
The previous chapter explained how to change your $TERM variable so that you can
run full screen programs when logging in from a Windows 9x machine. Whilst the
commands were straightforward enough you can probably appreciate it would be
awfully annoying to have to type that in every time you logged in. There are several
63
places that these variables can be defined, however there is one that is run every time
you login that you are allowed to edit yourself. This file is called .profile and is
located in your home directory (the directory stored in $HOME).
To add anything just use your preferred editor (the vi later is explained in a later
chapter). If the file does not exist then the editor will normally create a blank file on
your behalf. To automatically change the Terminal type to vt100 enter the following
lines.
TERM=vt100
export TERM
The problem here is that you may logon to the computer using different methods
(physically on the machine; from a windows machine; from a dumb terminal located
in a different room etc.). If you do then you may find that your choice of terminal on
one screen may conflict with another. The following lines show how you could add an
entry that would only select vt100 if you connect with an ANSI terminal (ie. Windows
Telnet).
if [ $TERM="ANSI" ]
then TERM=vt00
export TERM
fi
I will not explain this here; just accept that it works. The if statement is explained in
volume 7 Unix Scripts.
Another common complaint with Solaris users is that the Backspace key doesnt
work as expected. This can be a common frustration but you can get around it by
running the following command.
stty erase ^H
Here the ^H is generated by pressing the backspace key.
You could add this to the .profile however you may find that when you press the
backspace key to generate the ^H it will actually work as a backspace key (just when
you dont want it to). To get around this then enter the following command (note: do
not enter the stty command prior to this as it will prevent you being able to create the
^H).
echo stty erase ^H >> $HOME/.profile
The echo command displays the entered line, but it is then redirected onto the last line
of the .profile file. Then when you login the backspace key will work as expected.
Note that anything added to the .profile file will not take effect until you logout and
then login again.
64
.kshrc
This file is similar to the .profile file however is run whenever the Korn shell is started
rather than when you login. Again this is located in the $HOME directory.
When using X the .profile is loaded when X-Windows is started. This sets up the
system wide variables, however there are commands that can be set that are specific to
the shell and not to the overall session. Normally these will not be passed onto the
virtual terminal unless they are put in the .kshrc file.
The name of the file is not important, however it must be the same as the ENV
variable set in the .profile file. It is not normally in the .profile by default (unless your
system administrator has set it up that way), so you need to add the following line in
your .profile file first.
export ENV=$HOME/.kshrc
An example of a command that would work differently if it is in .profile and .kshrc is
set -o vi
including the above command is the same as starting the shell with
ksh -o vi
which sets the shell environment into the vi style input.
If this was in the .profile then whenever a login was made into a terminal it would
take effect, however when starting a terminal from X it is not a new login and
therefore would not be invoked. If however this is included in the .kshrc then
whenever the Korn Shell was started it would be invoked and as the Korn Shell is
invoked by both a login and a new terminal started in X this would happen all the
time.
Some of the commands that could be put into the .kshrc file.
set -o vi This command sets the environment into the vi style input. What this
does is to provide a level of command recall for the shell. To really understand
this you need to understand how to use the vi editor (see the chapter on the vi
editor). To use the recall keys you first need to press the escape key (this may
be mapped differently on your system however is normally the key marked
Esc). Then you are in command mode and can recall commands and move
around using the keys "hjkl" ('h'=left, 'j'=down, 'k'=up, 'l'=right). You can then
delete a character by using the 'x' key. Pressing the 'i' key will insert before
the cursor and pressing the 'a' key will insert after the cursor. Pressing either 'i'
or 'a' will put you into insert mode and to return to command mode you press
the escape key again. This may all sound very complex however if you are
able to use the vi editor (a useful skill to acquire) then you will find this very
familiar.
alias - The alias command is used to set up alternative names for commands.
The format of the command is:
65
alias newcmdname='normalcmdname -args'
What will happen then when you enter newcmdname is that it will be replaced
with normalcmdname -args. Note: this will happen only on commands entered
at the command line and will have no effect on script files. A few examples of
where this would be useful is shown below:
alias rm='rm -i'
This will include the -i option on any delete command. What this does is provide
interactive prompting so that you will be asked if you want to delete each file.
alias up='cd ..'
Whenever you enter the up command it will take you one level up the directory tree.
This is useful if you, or a user have trouble remembering a command as you can make
easy to remember alias names.
alias computer2='telnet computer2.mynet.com'
If you often telnet to another computer (computer2) this will save you having to type
in the whole command instead of entering 26 characters you just need to enter 9
characters.
History
It is possible to recall previous commands using the o vi option explained earlier,
however it is also possible using the history command.
Issuing the history command will show the last few commands entered.
$ history
52
clear
53
ls
54
cd test
55
ls
56
pwd
57
cd ..
58
vi temp.txt
59
history
$