Skip to content

Processes and Users

Razvan Deaconescu edited this page Apr 15, 2019 · 7 revisions

Processes and Users

The goal of the computing system is to run actions as instructed by the user. Instructions are run by the CPU (Central Processing Unit) in execution abstractions that we call processes. Processes are running programs, i.e. executable code that now uses system resources. Processes hide CPU, memory and complexity from the user. It is the role of the operating system to ensure fair access for all processes to system resources.

In this chapter we delve into key concepts related to processes and process scheduling. We present the POSIX API for working with processes. We look into shell internals: running commands, redirections, pipes, subshells.

You will get accustomed to the POSIX process API: creating, waiting and terminating processes. As a critical component of the operating system, you will be understand the importance of monitoring and fine-tuning process resource use (CPU, memory, I/O). The shell is arguably the most used process in the operating system; you will get a better grasp of the shell inner workings.

Contents

running actions, run instructions on CPU, multiple instructions separation, processes CPU, memory, I/O abstractions scheduling processes, priorities, I/O-bound vs CPU-bound creating and terminating processes process investigation shell processes, subshells, foreground, background redirection

Process runs and uses CPU, memory, I/O. Show CPU time/percentage, virtual memory and resident memory for process. Use shell as test case.

Run processes with nice priority altered, see time duration. Difference between user time, system time, wall time. 04-processes/nice

Show redirection using dup() and dup2(). 04-processes/redirect.

Show the use of fork() to create new process. Show use of fork() + exec(). 04-processes/fork-exec

Show adoption of orphan child processes. 04-processes/orphan.

Inspect shell using strace when using internal commands vs external commands. Inspect running in background. Use shell and strace -p <shell_pid>.

Show example with pipe(). Inspect with lsof. 04-processes/pipe.

Inspect process with environment variable set.

Show what happens when we use echo "a" | read v, vs read v <<<"a".

Redirecting output of two chained commands. (a ; b) > f

Tasks

Inspect tee. Use tee -a.

What does the daemon() call do?

Start process as root and create child process as another user using setuid().

Programmatically get resource usage for process through getrusage().

Start process using spawn.... Start process using popen().

Update 04-processes/pipe to use exec to do cat /etc/passwd | grep 10.

Clone this wiki locally