KEMBAR78
Module 4 Unix | PDF | Process (Computing) | Shell (Computing)
0% found this document useful (0 votes)
37 views8 pages

Module 4 Unix

Uploaded by

Shashank Katti
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
37 views8 pages

Module 4 Unix

Uploaded by

Shashank Katti
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 8

1

MODULE 5. PROCESS AND SYSTEM


ADMINISTRATION
5.1 PROCESS BASICS
A process is an instance of a running program. A process is said to be born when the
program starts execution and remains alive till the program is active. Once the program
execution is completed, the process is said to die. A process has a name, usually same as
that of the program. For example, when we execute date command, a process name date
is created. But, a process cannot be considered synonymous with a program. Because,
when two users run the same program, there is only one program on the disk, but there will
be two processes in memory.

Processes are managed by kernel. Kernel allocates CPU resources based on time and
priorities attached to each process. That is, CPU scheduling and memory management etc.
are done by kernel. Processes have attributes, stored in a separate structure called as
process table. Two important attributes of a process are –
Process ID (PID): Each process is uniquely identified by an integer called PID,
which is allotted by the kernel when the process is born. The PID is useful in
controlling the processes, for example, killing it.
Parent PID (PPID): The PID of the parent process is known as PPID. When a child
process is spawn through its parent, then it will have PPID. When there are several
processes with same PPID, it is ideal to kill the parent rather than each of the
children.

Sometimes, process may not get completed in the expected time. Then, one may need to
suspend it, or move it the background or to kill it. UNIX provides tools for all such actions to
be carried out on processes.

5.1.1 The Shell Process


Whenever we log into UNIX system, the shell process is created, which may be sh (Bourne
Shell), ksh(Korn shell), csh(C Shell) or bash (Bourne again shell). Any command that we
give in UNIX later, will be treated as standard input to the shell process. This shell process
remains alive till we logout.

The shell maintains a set of environment variables like PATH, SHELL etc. The pathname of
shell is stored in SHELL and PID is stored in a special variable $$. So, to check the PID of
the current shell, use the command –
$ echo $$
11662

The PID of your login shell cannot change till you are logged in. Once you logout and login
again, it may be different. The lower value of PID indicates that the process was initiated
quite early.
2

5.1.2 Parents and Children


Every process has a parent process. If you run the command,
$ cat emp.lst
then the process representing cat command is created by the shell process. Now, the shell
is said to be parent process of cat. The hierarchy of every process is ultimately traced to
the first process (PID 0), which is set up when the system is booted. It is like the root
directory of the file system.

A process can have only one parent, but multiple children. The following command creates
two processes cat and grep both are spawned by the shell –
$cat emp.lst | grep ‘director’

5.2 ps: PROCESS STATUS


The ps command is used to display some of the process attributes. This command reads
the data structure of kernel and process tables to fetch the characteristics of processes. By
default, ps display the processes owned by the user running the command. For example –

$ ps
PID TTY TIME CMD
11703 pts/1 00:00:00 bash
11804 pts/1 00:00:00 ps

After the head, every line shows the PID, terminal (TTY) with which the process is
associated (controlling terminal), the cumulative processor time (TIME) that has been
consumed since the process has been started and the process name (CMD).

5.2.1 ps Options
Some of the options of ps command are discussed hereunder.
Full Listing (-f): The –f option is used to get detailed listing of process attributes.
$ ps -f
UID PID PPID C STIME TTY TIME CMD
John 11703 11701 0 06:43 pts/1 00:00:00 -bash
John 11857 11703 0 07:27 pts/1 00:00:00 ps -f

It shows the parent (PPID) and the owner (UID) of every process. STIME shows the
starting time of process.

Displaying Processes of a User ( - u): The system admin may need to use –u
option to know the activities by any user, by specifying user name as shown below–
$ ps -u chetana
PID TTY TIME CMD
11703 pts/1 00:00:00 bash
11894 pts/1 00:00:00 ps

Displaying all User Processes (-a): This option is to list all the processes by all the
users, excluding the system processes.
3

$ ps -a
PID TTY TIME CMD
11899 pts/1 00:00:00 ps

5.3 MECHANISM OF PROCESS CREATION


There are three major steps in the creation of a process. Three important system calls or
functions viz. fork, exec and wait are used for this purpose. The concept of process
creation cycle will help to write the programs that create processes and helps in debugging
shell scripts. The three steps are explained here –
Fork: A process in UNIX is created with the help of system call fork. It creates a
copy of the process that invokes it. The process image is identical to that of the
calling process, except few parameters like PID. When a process is forked, the child
gets a new PID. The forking mechanism is responsible for the multiplication of
processes in the system.

Exec: A new process created through fork is not capable of running a new program.
The forked child needs to overwrite its own image with the code and data of the new
program. This mechanism is known as exec. The child process is said to exec a
new program.

Wait: The parent then executes the system call wait for the child process to
complete. It picks up the exit status of the child and then continues with its other
functions. A parent may not need to wait for the death of its child.

For illustration, consider you are running a cat command from the shell. Now, the shell first
forks another shell process. The newly forked shell then overlays itself with the executable
image of cat, and then it starts to run. The parent shell waits for cat to terminate and then
picks up the exit status of the child. This is a number is returned to kernel by the child
process.

When a process is forked, the child has different PID and PPID compared to parent. But, it
inherits most of environment of its parent.

5.4 INTERNAL AND EXTERNAL COMMANDS


From the process point of view, the shell can recognize three types of commands as
below–
External Commands: The most commonly used UNIX utilities and programs like
cat, ls, date etc. are called as external commands. The shell creates a process for
each of such commands when they have to be executed. And, the shell remains as
their parent.
Shell Scripts: The shell spawns another shell to execute shell scripts. This child
shell then executes the commands inside the script. The child shell becomes the
parent of all the commands within that script.
Internal Commands: Some of the built-in commands like cd, echo etc. are internal
commands. They don’t generate a process and are executed directly by the shell.
Similarly variable assignment statements like x=10 does not create a child process.
4

5.5 RUNNING JOBS IN BACKGROUND


UNIX is a multitasking system, which allows to run multiple jobs at a time. As there can be
only one process in the foreground, the other jobs must run in the background. There are
two different ways of running the jobs in background – using & operator and using nohup
command. These methods are discussed here.

5.5.1 No Logging out: &


The & operator of shell is used to run a process in the background. The usage is as shown
below –

$ sort –o newlist.lst emp.lst & #terminate line with & symbol


4080 # PID is displayed
$ #prompt is displayed to run another job

The & symbol at the end of the command line will make the job to run in the background.
Immediately, the shell returns PID of the invoked command. And the parent shell will not
wait till the job is completed (or the death of the child process), instead, the prompt is
appeared so that a new job can be executed by the user. However, the shell remains as
the parent of background process. Using & symbol, any number of jobs may be run in the
background, if the system can sustain the load.

5.5.2 Log Out Safely : nohup


Normally, when the background processes are running, the user cannot logout. Because,
shell is the parent of all the background processes and logging out kills the shell. And, by
default when the parent shell is killed, all child processes will also die automatically. To
avoid this, UNIX provides an alternative command nohup (no hangup). When this
command is prefixed with any command, even after logging out, the background process
keeps running. Note that the symbol & has to be used even in this case. For example,

$nohup sort emp.lst &


4154
nohup: appending output to ‘nohup.out’

Here, the shell returns the PID and some shells display the message as shown. When
nohup command is run, it sends the standard output of the command to the file nohup.out.
Now, one can safely logout the system, without aborting the command.

5.6 JOB EXECUTION WITH LOW PRIORITY: nice


In UNIX system, processes are executed with equal priority, by default. But, if high-priority
jobs make demand, then they have to be completed first. The nice command with &
operator is used to reduce the priority of jobs. Then more important jobs have greater
access to the system resources.

To run a job with a low priority, use the command prefixed with nice as shown –
$nice wc emp.lst
15 31 741 emp.lst
5

If we would like to make it as a background process, use as –


$nice wc emp.lst &

The nice command is built-in command in C Shell. The value of nice is system dependent
and usually ranges from 1 – 19. Commands execute with a nice value is generally in the
middle of the range, say 10. The higher nice value implies lower priority. The nice
command reduces priority of any process, and hence raising its nice value. The nice value
can be explicitly given using –n option as –
$nice –n 3 wc emp.lst & #nice value is incremented by 3 units

The priority of a process can be raised only by the super-user.

5.7 KILLING PROCESSES WITH SIGNALS


The UNIX system (in fact, any OS) needs to communicate with a process about the
occurrence of any event. Such communication is done by sending signal to the process.
Each signal is identified by a number, and has a specific meaning/functionality. Every
signal is represented by their symbolic names with a prefix SIG. The kill command is used
to send specific signal to the process.

If a program is running longer than expected, we may need to terminate it. So, we may
press interrupt key. This action sends the SIGINT (with number 2) signal to process. By
default, this will kill the process. A process may ignore a signal or it may execute a user-
defined code to handle that signal. But, there are two signals viz. SIGKILL and SIGSTOP,
which are never ignored by a process.

5.7.1 Premature Termination of a Process: kill


The kill command sends a signal with the intention of killing one or more processes. It is an
internal command in most of the shells. The external command /bin/kill is executed only
when the shell lacks the kill capability. One or more PID are given as arguments to kill
command and by default, it uses the SIGTERM (number 15) signal.

$kill 12815

The above command kills the process with PID as 12815. If you don’t know the PID, use
ps command and then kill required process.

When there are more than on jobs (either in the background or in different windows), all of
them can be killed with a single kill command by specifying their PIDs as below –

$kill 12815 23165 22810 22845

If all these processes have same parent, we can just kill the parent and the child processes
will be automatically gets killed. However, any job is running in the background with the
help of nohup, the parent cannot be killed as init has acquired its parentage. Then each
process has to be killed individually.
6

Killing the last background job: In most of the shells, the system variable $! stores the
PID of the last background job. So, without giving actual PID, it can be killed. For example,
$sort –o new.lst emp.lst & #running in background
23166
$ kill $! # background process will be killed.

Using kill with other signals: By default, kill uses SIGTERM signal to terminate the
process. But, some processes may ignore it and continue execution. In such situations, the
process can be killed with SIGKILL (number 9) signal. It is done as below –
$kill –s KILL 23165 #process with PID 23165 is killed

5.8 EXECUTE LATER: at AND batch


The user can schedule a job to run at a specific time of a day. When system is loaded with
many jobs, it is ideal to run low-priority (or less urgent) jobs whenever system overhead is
low (that is, when system is considerably free). There are two commands at and batch for
job scheduling in UNIX.

5.8.1 One-Time Execution: at


The at command takes one argument as the time specifying when the job has to be
executed. For example,
$ at 10:44 #press enter by giving time
at> ls –l > out.txt #Give the command to be executed
at> <EOT> #Press [CTRL+d]
job 10 at 2018-01-01 10:44

The job goes to the queue and at 10.44 on Jan 1st, 2018 the command ls –l will be
executed and the output would be stored in the file out.txt. One can check this file later
for the output.

5.8.2 Execute in Batch Queue: batch


The batch command schedules the job when the system overhead reduces. This
command does not use any arguments, but it uses internal algorithm to determine the
actual execution time. This will prevent too many CPU-hungry jobs from running at the
same time.

$ batch < evalEx.sh #evalEx.sh will be executed later


job 15 at 2007-01-09 11:44

Any job scheduled with batch goes to special at queue from where it will be taken for
execution.

5.9 RUNNING JOBS PERIODICALLY: cron


The cron is a software utility (NOT a command) which behaves as a time-based job
scheduler. Certain jobs in OS need to be executed in regular intervals of time. For example,
system maintenance or administration may need to download/update general purpose
utilities at regular intervals. Instructions (or commands) to be executed like this are stored
7

in a control file (crontab file) in the path - /var/spool/cron/crontabs. The cron


utility is usually will be in a sleeping status. It wakes up every minute and checks the above
control file whether any command has to be executed. User may keep a crontab file named
after his/her name (like /var/spool/cron/crontabs/john) and the format of the entry
would be like –
00-10 17 * 3,6,9,12 5 cat emp.lst

There are six fields in the above line:


1st Field : It specifies the number of minutes after the hour when the command is to be
executed. It may range from 00 to 59. In the above example, 00-10 indicates
that execution should happen every minute in the first 10 minutes of the hour.
2nd Field : Indicates the hour in 24-hour format. It may range from 1 to 24. In the above
example, 17 indicates 5pm.
rd
3 Field : It is day of the month. Here, * means every day. Hence, the command has to
be executed every minute for the first 10 minutes starting at 5pm every day.
4th Field : Specifies month (can be 1-12). Here, 3, 6, 9 and 12 indicates months March,
June, September and December.
5th Field : Indicates day of the week (Sunday is treated as 0. Hence, values can be 0
to 6). In the above example, 5 indicates Friday.
6th Field : The actual command to be executed.

One can observe that 3rd field and 5th field are contradictory here. Because, 3rd fields says
‘execute every day’ and 5th field says ‘execute on every Friday’. But, 5th field appears after
3rd field and hence it overrides 3rd field. Thus, meaning of above statement would be –
execute the command cat emp.lst on every Friday for 10 minutes after 5 pm (ie. 5pm to
5:10pm) on the months March, June, September and December of every year.

5.10 TIMING PROCESSES: time


The time command is used to determine the duration of execution of a particular
command/program. This required to check how efficiently the system resources are being
used by the programs. The time command executes the program and also displays the
time usage. For example,

$ time ls
avgSal.awk elist.lst myf1 Shell1.sh test.bak
caseEx.sh emp1.lst myfile Shell2.sh test.lst
cmdArg.sh emp.lst myFirstShell t1 test.sh

real 0m0.004s
user 0m0.000s
sys 0m0.000s

Here, we are checking execution time required for ls command. It first executes ls (displays
all files/directories) command and then displays time. The real time is the clock elapsed
time from invocation of the command until its termination. The user time is the time spent
by the program in executing itself. The sys time is the time required by the kernel in doing
8

work on behalf of the user process. Ideally, the sum of user time and sys time must be
equal to CPU time. But, due to system load (multiple tasks running at a time), it may differ.

You might also like