RH033读书笔记(10)-Lab 11 Process Control
Lab 11 Process Control
Sequence 1: Job Control
1. [student@stationX ~]$ su -
2. Begin some jobs in the background:
[root@stationX ~]# tail -n0 -f /var/log/messages &
[root@stationX ~]# updatedb &
3. [root@stationX ~]# service syslog restart
4. [root@stationX ~]# jobs
5. [root@stationX ~]# kill %1
[root@stationX ~]# jobs
6. Next, start an instance of vim
[root@stationX ~]# vim
7. While in vim, press Ctrl-z to suspend the current program.
8. Run jobs again and note vim's job ID.
9. [root@stationX ~]# fg 3
Sequence 2: Conditional Execution
1. ping -c1 -w2 $TARGET &> /dev/null
2. vi ~/bin/reach.sh
#!/bin/bash
TARGET=$1
ping -c1 -w2 $TARGET &> /dev/null
3. [student@stationX ~]$ chmod a+x ~/bin/reach.sh
4. [student@stationX ~]$ reach.sh server1; echo $?
0
[student@stationX ~]$ reach.sh station100; echo $?
1
5. Now use the conditional operators && and || to report success or failure based on ping's
exit value.
#!/bin/bash
TARGET=$1
ping -c1 -w2 $TARGET &> /dev/null &&
echo "$TARGET is UP" ||
echo "$TARGET is DOWN"
6. [student@stationX ~]$ reach.sh server1; echo $?
server1 is UP
0
[student@stationX ~]$ reach.sh station100; echo $?
station100 is DOWN
0
7. The script returns 0 for both tests because the last command run is now echo, not ping.
Since echo does not fail, it returns success.
8. Modify the script again
#!/bin/bash
TARGET=$1
ping -c1 -w2 $TARGET &> /dev/null
RESULT=$?
if [ $RESULT -ne 0 ]
then
echo "$TARGET is DOWN"
else
echo "$TARGET is UP"
fi
exit $RESULT
9. Test the script.
[student@stationX ~]$ reach.sh server1; echo $?
server1 is UP
0
[student@stationX ~]$ reach.sh station100; echo $?
station100 is DOWN
1
10. [student@stationX ~]$ sudo mv ~/bin/reach.sh /usr/local/bin/
Sequence 3: Scheduling One-Time Jobs
Scenario: In this sequence you will schedule a job for one-time execution at a specified
time using the tool you developed in the previous sequence.
Instructions:
1. Start in a shell, either on a virtual console or a graphical shell, such as gnome-terminal. You should be signed in as student.
2. Schedule your reach.sh tool to check all stations five minutes from now:
[student@stationX ~]$ at now+5min
at> for x in $(seq 1 40); do
at> reach.sh station$x
at> done
at> Ctrl-d
job 7 at 2007-01-23 08:40
Note: Since your script only emits output when there is a problem, you do not have to worry
about redirecting STDOUT or STDERR in regular usage. Your job will only notify you of
unreachable stations!
3. The system responded with a job number, but list your scheduled jobs to see any others that
you may have created (or that root may have created for you!):
[student@stationX ~]$ at -l
job 7 at 2007-01-23 08:40 a student
4. For detailed information, cat the job:
[student@stationX ~]$ at -c 7
Read the output, observing that each at job stores the environment for the user that created
the job. The job's command is listed near the bottom of the output.
5. Optionally, watch the job list until your job executes.
[student@stationX ~]$ watch -n1 'at -l'
6. Check your mail after the job executes to review its output.
[student@stationX ~]$ mutt
Sequence 4: Finding Processes
Scenario: In this sequence you will find the process on your system that is using the most
CPU time. Finding it will require the use of ps and tail.
Instructions:
1. Start in a shell, either on a virtual console or a graphical shell, such as gnome-terminal. You should be signed in as student.
2. Review the ps man page to find the standard format specifier for displaying the PID,
program name, and percent CPU utilization.
man ps
Within the man page, search for the -o option:
/-o
Press n until you find the section on the -o option. Instead of listing the available columns,
it refers you to the STANDARD FORMAT SPECIFIERS section of the man page, so try
searching for that at this point:
/STANDARD FORMAT SPECIFIERS
Find the list of columns to determine which codes are appropriate.
3. List all processes on your system, limiting output to PID, program name, and percent CPU
utilization.
ps axo pid,comm,pcpu
You should see a long list of processes scroll by.
4. Now open up the man page for ps to determine if it has the ability to sort output.
man ps
/sort
5. Once you find the correct sort option, add it to your previous command:
ps axo pid,comm,pcpu --sort=pcpu
6. The output looks right, so now pipe it through another command to restrict output to a
single process:
ps axo pid,comm,pcpu --sort=pcpu | tail -n1
Sequence 5: Recurring Jobs
Scenario: In this sequence you will take the command you developed in the previous sequence and adapt it for use in a recurring job. You would like the output mailed to student's email complete with column headings.
Instructions:
1. Observing that ps automatically outputs column headings, review the man page to
determine how to reverse the sort order, such that the job with the most CPU time is at the
top of the ouput, along with the column headings.
Add the reverse sort indicator (-) in front of the sort column:
ps axo pid,comm,pcpu --sort=-pcpu
2. Now restrict output to the top two lines:
ps axo pid,comm,pcpu --sort=-pcpu | head -n2
The output is now suitable for job scheduling.
3. Review the man page for crontab to check the field order:
man crontab
4. Oops! There are two man pages for crontab, so open up the one in section 5, which deals
with configuration files:
man 5 crontab
5. Use information in the man page to determine how would you write a crontab entry that
should run every five minutes?
*/5 * * * *
6. Use your answer to the previous question to add a crontab entry that runs the ps command
from earlier every five minutes.
You can do this either by running crontab -e and using a text editor or by piping directly to
crontab like this:
echo '*/5 * * * * ps axo pid,comm,pcpu --sort=-pcpu | head -n2' | crontab
7. Once you have added the job, list your crontab to confirm:
crontab -l
8. Now add lines to run your reach.sh command on server1 and station100 every two minutes.
Because /usr/local/bin is not in the PATH used by cron, you will need to use an
absolute path to the script.
Your crontab should now look like this:
*/5 * * * * ps axo pid,comm,pcpu --sort=-pcpu | head -n2
*/2 * * * * /usr/local/bin/reach.sh server1
*/2 * * * * /usr/local/bin/reach.sh station100
9. Once a few minutes have passed, check your mail with the mutt command to see the output
of your jobs. See the instructions at the beginning of this lab if you are unfamiliar with
mutt.
Some observations about what you should see:
• You did not receive any mail regarding the reachability of server1; your script correctly
avoids output on successful completion
• You received at least one message regarding the failure to reach station100
10. For cleanup, remove your crontab:
crontab -r; crontab -l
RH033读书笔记(10)-Lab 11 Process Control的更多相关文章
- RH033读书笔记(9)-Lab 10 Understanding the Configuration Tools
Lab 10 Understanding the Configuration Tools Sequence 1: Configuring the Network with system-config- ...
- RH033读书笔记(15)-Lab 16 The Linux Filesystem
Lab 16 The Linux Filesystem Goal: Develop a better understanding of Linux filesystem essentials incl ...
- RH033读书笔记(16)-Lab 17 Installation and Administration Tools
Lab 17 Installation and Administration Tools Goal: Become familiar with system configuration tools a ...
- RH033读书笔记(5)-Lab 6 Exploring the Bash Shell
Lab 6 Exploring the Bash Shell Sequence 1: Directory and file organization 1. Log in as user student ...
- RH033读书笔记(3)-Lab 4 Browsing the Filesystem
Lab 4 Browsing the Filesystem Sequence 1: Directory and File Organization 1. Log in as user student ...
- RH033读书笔记(7)-Lab 8 Introduction to String Processing
Lab 8 Introduction to String Processing Sequence 1: Exercises in string processing 1. Other than the ...
- RH033读书笔记(8)-Lab 9 Using vim
Lab 9 Using vim Sequence 1: Navigating with vim 1. Log in as user student 2. [student@stationX ~]$ c ...
- RH033读书笔记(13)-Lab 14 Network Clients
Goal: Practice using a variety of tools to transfer files between your system and a remote system. S ...
- RH033读书笔记(14)-Lab 15 Switching Users and Setting a Umask
Lab 15 Switching Users and Setting a Umask Goal: Become familiar with the use of several essential c ...
随机推荐
- hdu5172(线段树)
传送门:GTY's gay friends 题意:判断区间[l,r]内的数字是否符合1~len(r-l+1)的一个全排列. 分析:pos[i]记录数字i出现的最大位置,pre[i]记录在位置i的数字a ...
- poj1836--Alignment(dp,最长上升子序列变形)
Alignment Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 13319 Accepted: 4282 Descri ...
- 断言Assert的使用
转载地址:http://www.cnblogs.com/moondark/archive/2012/03/12/2392315.html 我一直以为assert仅仅是个报错函数,事实上,它居然是个宏 ...
- jdk1.6与1.7垃圾回收
最近项目中遇到了个关于JVM中GC线程数的问题,做一下简单的总结 问题场景: server:均为 sun公司的solaris 系统 CPU 128个 项目8.1时使用的 java版本: jdk1. ...
- HttpClient 4.3教程(转载)
HttpClient 4.3教程(转载) 转自:http://www.yeetrack.com/?p=779 前言 Http协议应该是互联网中最重要的协议.持续增长的web服务.可联网的家用电器等都在 ...
- 《Android内核剖析》读书笔记 第13章 View工作原理【View树遍历】
View状态分类 在View视图中定义了多种和界面效果相关的状态,比如拥有焦点Focused.按下Pressed等,不同的状态一般会显示不同的界面效果,而且视图状态会随着用户的操作而改变,一般通过xm ...
- java 常用的包 默认导入的包
1.java.lang----包含一些Java语言的核心类,如String.Math.Integer.System和Thread,提供常用功能. 2.java.awt----包含了构成抽象窗口工具集( ...
- Linux查看进程线程个数
1.根据进程号进行查询: # pstree -p 进程号 # top -Hp 进程号 2.根据进程名字进行查询: # pstree -p `ps -e | grep server | awk '{pr ...
- hdu2089不要62(数位dp)
#include <stdio.h> #include <string.h> ][]; ]; /* dp[i][0] 不含62,4 dp[i][1] 2开头 dp[i][2] ...
- Oracle SQL Lesson (4) - 使用转换函数和条件表达式
隐式转换select * from emp where empno='7788'字符(char,varchar2)转换为数字(number)或日期(date)数字或日期转换为字符 显式转换字符转换为数 ...