Chapter 9 Study Guide
LINUX PROCESSES  User process: a process begun by a user and which runs on a terminal.  Daemons process: a system process and it’s not associated with a terminal.  Process ID (PID): a unique identifier assigned to every process as it begins and it allows the kernel to identify it uniquely.  Parent process ID (PPID): a process that has started other processes (child processes)
VIEWING PROCESS COMMANDS  ps display a list of processes in the current shell  ps –e displays all processes running on terminals as well as processes that do not run on a terminal (daemons)  ps –f displays a full list of information about each process, including the UID, PID, PPID, CPU utilization, start time, terminal, processor time, and command name  ps –l displays a long list of information about each process, including the flag, state, UID, PID, PPID, CPU utilization, priority, nice value, address, size, WCHAN, terminal, and command name  ps –a displays all processes running on terminals  ps –x displays all processes that do not run on terminals  ps –ef display an entire list of processes across all terminals and including daemons  ps –ef | grep bash display only the BASH shells  ps ax | head -11 display all processes across terminals, and the x option, which lists processes that do not run on a terminal  ls /proc display all process information subdirectories  pstree | head -20 displays the lineage of a process  top display an interactive screen listing processes  h to get help KILLING PROCESSES COMMANDS  kill send to kill signals  kill –l displays different kill signal names [root@server1 ~]# kill -l 1)SIGHUP 2) SIGINT 3) SIGQUIT 4) SIGILL 5)SIGTRAP 6) SIGABRT 7) SIGBUS 8) SIGFPE 9)SIGKILL 10) SIGUSR1 11) SIGSEGV 12) SIGUSR2 13)SIGPIPE 14) SIGALRM 15) SIGTERM 17) SIGCHLD 18)SIGCONT 19) SIGSTOP 20) SIGTSTP 21) SIGTTIN 22)SIGTTOU 23) SIGURG 24) SIGXCPU 25) SIGXFSZ 26)SIGVTALRM 27) SIGPROF 28) SIGWINCH 29) SIGIO 30)SIGPWR 31) SIGSYS 33) SIGRTMIN 34) SIGRTMIN+1 35)SIGRTMIN+2 36) SIGRTMIN+3 37) SIGRTMIN+4 38) SIGRTMIN+5 39)SIGRTMIN+6 40) SIGRTMIN+7 41) SIGRTMIN+8 42) SIGRTMIN+9 43)SIGRTMIN+10 44) SIGRTMIN+11 45) SIGRTMIN+12 46) SIGRTMIN+13 47)SIGRTMIN+14 48) SIGRTMIN+15 49) SIGRTMAX-15 50) SIGRTMAX-14 51)SIGRTMAX-13 52) SIGRTMAX-12 53) SIGRTMAX-11 54) SIGRTMAX-10 55)SIGRTMAX-9 56) SIGRTMAX-8 57) SIGRTMAX-7 58) SIGRTMAX-6 59)SIGRTMAX-5 60) SIGRTMAX-4 61) SIGRTMAX-3 62) SIGRTMAX-2 63)SIGRTMAX-1 64) SIGRTMA  kill -3 9999 (3 = SIGQUIT, 9999 = PID) use to send a kill signal to a process  killall -3 SAMPLE (3=SIGQUIT, SAMPLE=process name) use to send a kill signal to process
Scheduling commands in Linux. 
at daemon (atd) – used to schedule a command to be executed one time in the future. 
cron daemon (crond) – used to schedule a command to be executed repeatedly in the future.
AT:
The shells environment and scheduled commands are stored in the /var/spool/at directory.
Schedule a job. 
at (timespec)
               at>date
               at>time
               CTRL-Z to end. 
 
Display a list of AT jobs:
at –l
Display variables for Job ID:
at –c 1
Delete a AT job:
at –d 1
To process a script:
at 12:01am July 4 –f /home/user1/Happy4th.sh
Limiting access to the at daemon:
§ Access to scheduling at jobs can be limited with the /etc/at.allow and /etc/at.deny files. ú If the files do not exist, only root can schedule tasks with the at daemon. ú To allow users, create the /etc/at.allow file and add the username, one per line. ú To deny users, create the /etc/at.deny file. Anyone not in the file is then allowed to use the at daemon. Note: if both files exist, the system only processes the /etc/at.allow file and ignores /etc/at.deny.
 
CRON: The table is separated into 6 fields by a space or tab. The first five field specify the times to run the command and the sixth field is the absolute path to the command to be run.
Access to scheduling at jobs can be limited with the /etc/cron.allow and /etc/cron.deny files. 
§  On a newly installed Fedora system, all users have the ability to schedule tasks with cron daemon as the /etc/cron.deny contains only a single blank line. 
ú  To allow users, create the /etc/cron.allow file and add the username, one per line. This would then limit the system compared to a clean install to only those users. 
ú  To deny users, create the /etc/cron.deny file. Anyone not in the file is then allowed to use the at daemon. 
Note: if both files exist, the system only processes the /etc/cron.allow file and ignores /etc/cron.deny. 
 
To create or edit a user cron table use the –e option. The editor for crontab entries is the vi editor crontab –e Note: The crontab information is stored in the /var/spool/cron/username directory. Username is the name of the user that executed the crontab –e command.
Examples: /var/spool/cron/dave or /var/spool/cron/root
To list the contents of your user cron table use the –l option. 
§  crontab –l
To remove a cron table and all the scheduled jobs you can use the –r option. § crontab –r
Note: all the previous commands are specific for the user running them. Note: root can list, edit or remove other users cron tables by using the -u option with the username.
Examples: crontab –l –u dave or crontab –r –u randy
 
- Example of job definition:
- .---------------- minute (0 - 59)
- | .------------- hour (0 - 23)
- | | .---------- day of month (1 - 31)
- | | | .------- month (1 - 12) OR jan,feb,mar,apr ...
- | | | | .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
- | | | | |
- * * * * * command to be executed
§ The fields are separated by a space and * indicates a wild card for all time periods. § If you want more than one consecutive day, you can specify the day range with a –(dash). § If you want more than one time period non-consecutive you can separate them by a comma. § If you want to specify a particular time period, every 10 min, you can specify the *(every minute) /10.
§  Administrative tasks that are performed on an hourly, daily, weekly or monthly basis can be scheduled simply by placing the shell script in the following directories. 
ú  Scripts to be executed hourly - /etc/cron.hourly directory.  
ú  Scripts to be executed daily  - /etc/cron.daily directory. 
ú  Scripts to be executed weekly - /etc/cron.weekly directory. 
ú  Scripts to be executed monthly - /etc/cron.monthly directory. 
§  The cron daemon runs the /etc/cron.d/Øhourly script which executes the files in the directory /etc/cron.hourly one minute past the hour, every hour. 
§  For troubleshooting purposes: The /etc/cron.hourly/Øanacron file starts the anacron daemon which then executes the contents  of the /etc/cron.daily, /etc/cron.weekly, and the /etc/cron.monthly directories at the times specified in the /etc/anacrontab file.
Process Execution Types of commands: Binary programs *examples of binary programs: *ls, find, grep, jre-1_5_0-linux-i586.bin
Shell scripts *Example: scripts created in editor, made executable
Binary programs *Example:Executable file created in a text editor
Shell functions :*Examples:cd, exit, wait
- A shell function is a compound command that has been given a name. It stores a series of commands for later execution. The name becomes a command in its own right and can be used in the same way as any other command. Its arguments are available in the positional parameters, just as in any other script. Like other commands, it sets a return code.
 
- A function is executed in the same process as the script that calls it. This makes it fast, because no new process has to be created. All the variables of the script are available to it without having to be exported, and when a function changes those variables, the changes will be seen by the calling script. That said, you can make variables local to the function so that they do not affect the calling script; the choice is yours.
 
- Not only do functions encapsulate code for reuse in a single script, but they can make it available to other scripts. They make top-down design easy and improve legibility. They break scripts into manageable chunks that can be tested and debugged separately.
 
- At the command line, functions can do things that an external script cannot, such as change directories. They are much more flexible and powerful than aliases, which simply replace the command you type with a different command. Chapter 11 presents a number of functions that make working at the prompt more productive.
 
	Running Processes in the Background (Processes ran in background eliminate the wait function from the shell)
How Programs Executed
- Step 1: From the working terminal using the shell creates a sub shell – this process is forking, then executes a wait function
 
- Step 2:Subshell executes the program/script shell is unavailable to the user while executing (foreground process)
 
- Step 3:Program/script completes , shell calls its exit function to kill the subshell and return control to original shell
 
To determine if file is binary:
- Use “file” command to determine if file is binary
- View contents using “od” or “strings” (ch 3)
 
To run a process in the background (freeing up the shell for additional input append “&” to command
Terminating Background Processes
- 1. issue 'jobs' command to locate job num ber
- 2. issue 'kill -2 %[job number]
- example: assume your killing job #2
- kill -2 %2
 
 
 
To run jobs in the background prefixed job with an & character
- Example: jre-1_5_0-linux-i586.bin &
 
Moving Processes Between Background and Foreground
- Step 1: Pause foreground processes with Ctrl+z
- Step 2: locate job number
- Step 3: issue fg command with job number
- Example: fg %1
 
 
	
Move foreground process to the background using the 'bg' command
- Step 1: Pause foreground processes with Ctrl+z
- Step 2: locate job number
- Step 3: issue bg command with job command
- Example: bg %1
 
 
- Summary: Send processes to foreground with ‘fg’
 
Move background process to the foreground using the 'fg' command
- Step 1: locate job number with the job command
- Step 2: Pause processes with Ctrl+z
- Step 3: issue bg command with job number
- Example: fg %1
 
 
- Summary: Send processes to background with ‘bg’
 
Use ‘jobs’ to all jobs running in the background
Process Priorities
- Time Slice – amount of time available to a process
- More time slices a process has, the more CPU it has, therefore the faster it executes
 
- PRI (process priority) ranges:
- 0 = highest
- 127 lowest
 
 
- PRI (process priority) ranges:
Adjust priorities with ‘nice’
- Users can lower their priority
- only the root user has the ability to increase the priority
 
- Example: nice -n 19 ps -l
- Processes start out with nice value of 0 by default
 
- Users can lower their priority
Changing priority of a running process using ‘renice’
- “renice +[nice value] [PID]
 
'Adjusting Priority
- Use ‘top’ to change nice value, press r ,the enter the PID
- Root can ‘renice’ a user or a group’s processes
- renice [+/-] [priority] –u [user]
- renice [+/-] [priority] –g [group]