一、进程基本概念
程序是静态概念,本身作为一种软件资源长期保存;而进程是程序的执行过程,它是动态概念,有一定的生命期,是动态产生和消亡的。
内核功用:进程管理、文件系统、网络功能、内存管理、驱动程序、安全功能等
- Process: 运行中程序的一个副本,是被载入内存的一个指令集合
- 进程ID(Process ID,PID)号码被用来标记各个进程
- UID、GID、和SELinux语境决定对文件系统的存取和访问权限
- 通常从执行进程的用户来继承
- 存在生命周期
二、进程的基本状态
- 创建状态:进程在创建时需要申请一个空白PCB(process control block进程控制块),向其中填写控制和管理进程的信息,完成资源分配。如果创建工作无法完成,比如资源无法满足,就无法被调度运行,把此时进程所处状态称为创建状态
- 就绪状态:进程已准备好,已分配到所需资源,只要分配到CPU就能够立即运行
- 执行状态:进程处于就绪状态被调度后,进程进入执行状态
- 阻塞状态:正在执行的进程由于某些事件(I/O请求,申请缓存区失败)而暂时无法运行,进程受到阻塞。在满足请求时进入就绪状态等待系统调用
- 终止状态:进程结束,或出现错误,或被系统终止,进入终止状态。无法再执行
三、进程的基本形态
- 运行态:running
- 就绪态:ready
- 睡眠态:
可中断:interruptable
不可中断:uninterruptable - 停止态:stopped,暂停于内存,但不会被调度,除非手动启动
- 僵死态:zombie,结束进程,父进程结束前,子进程不关闭
四、进程基本管理
ps命令: 打印进程的快照信息
语法:ps [OPTION]...
- 支持三种选项:
UNIX选项 如-A -e
BSD选项 如a
GNU选项 如--help
选项:默认显示当前终端中的进程
a 选项包括所有终端中的进程
x 选项包括不链接终端的进程
u 选项显示进程所有者的信息
f 选项显示进程树,相当于 --forest
k|--sort 属性 对属性排序,属性前加- 表示倒序
o 属性… 选项显示定制的信息 pid、cmd、%cpu、%mem
L 显示支持的属性列表
-C cmdlist 指定命令,多个命令用,分隔
-L 显示线程
-e: 显示所有进程,相当于-A
-f: 显示完整格式程序信息
-F: 显示更完整格式的进程信息
-H: 以进程层级格式显示进程相关信息
-u userlist 指定有效的用户ID或名称
-U userlist 指定真正的用户ID或名称
-g gid或groupname 指定有效的gid或组名称
-G gid或groupname 指定真正的gid或组名称
-p pid 显示指pid的进程
--ppid pid 显示属于pid的子进程
-M 显示SELinux信息,相当于Z
ps 输出属性
- VSZ: Virtual memory SiZe,虚拟内存集,线性内存
- RSS: ReSident Size, 常驻内存集
- STAT:进程状态
R:running(运行)
S: interruptable sleeping(可中断的睡眠)
D: uninterruptable sleeping(不可终端的睡眠)
T: stopped(停止)
Z: zombie(僵尸)
+: 前台进程
l: 多线程进程
L:内存分页并带锁
N:低优先级进程
<: 高优先级进程
s: session leader,会话(子进程)发起者
ni: nice值
pri: priority 优先级
psr: processor CPU编号
rtprio: 实时优先级
示例1:查询自身拥有的所有进程
ps -x
结果:
PID TTY STAT TIME COMMAND
1 ? Ss 0:03 /usr/lib/systemd/systemd --switched-root --system --deseriali
2 ? S 0:00 [kthreadd]
3 ? S 0:00 [ksoftirqd/0]
5 ? S< 0:00 [kworker/0:0H]
示例2:显示统计占用系统内存最多的进程,并排序。
ps -eo pid,ppid,cmd,%mem,%cpu --sort=-%mem | head -2
结果:
PID PPID CMD %MEM %CPU
7871 7869 db2sysc 0 21.4 0.2
示例3:显示统计占用系统CPU最多的进程,并排序。
ps -eo pid,ppid,cmd,%mem,%cpu --sort=-%cpu | head -2
结果:
PID PPID CMD %MEM %CPU
7871 7869 db2sysc 0 21.4 0.2
五、Shell流程控制
编程中的逻辑处理:
- 顺序执行
- 选择执行
- 循环执行
5.1 循环执行
- 将某代码段重复运行多次
- 重复运行多少次
- 循环次数事先已知
- 循环次数事先未知
- 具备进入条件和退出条件
for, while
for循环
for 变量名 in 列表;do
循环体
done
执行机制:
依次将列表中的元素赋值给“变量名”; 每次赋值后即执行一次循环体; 直到列表中的元素耗尽,循环结束
for示例:实现192.168.0.0/24网段内,地址是否能够ping通,若ping通则输出"success!",若ping不通则输出"fail!"
cat for_scanip_1.sh
#!/bin/bash
NETID=192.168.1
for HOSTID in {1..254};do
{
ping -c1 -W1 $NETID.$HOSTID &> /dev/null && echo "$NETID.$HOSTID is success." || echo "$NETID.$HOSTID is fail."
} &
done
执行结果
192.168.1.1 is success.
192.168.1.2 is fail.
192.168.1.3 is fail.
192.168.1.4 is fail.
192.168.1.5 is fail.
192.168.1.6 is fail.
192.168.1.7 is fail.
192.168.1.8 is fail.
192.168.1.9 is fail.
……
while循环
语句:
while CONDITION; do
循环体
done
CONDITION:循环控制条件;进入循环之前,先做一次判断;每一次循环之后会再次做判断;条件为“true”,则执行一次循环;直到条件测试状态为“false”终止循环
因此:CONDTION一般应该有循环控制变量;而此变量的值会在循环体不断地被修正
进入条件:CONDITION为true
退出条件:CONDITION为false
while示例:实现192.168.0.0/24网段内,地址是否能够ping通,若ping通则输出"success!",若ping不通则输出"fail!"
cat while_scanip.sh
#!/bin/bash
NETID=192.168.1.
seq 1 254 |while read HOSTID;do
ping -c1 -W1 $NETID$HOSTID &> /dev/null && echo $NETID$HOSTID is success. || echo $NETID$HOSTID is fail. &
done
执行结果
192.168.1.1 is success.
192.168.1.100 is success.
192.168.1.102 is success.
192.168.1.107 is success.
192.168.1.101 is success.
192.168.1.32 is fail.
……
六、Linux 计划任务
未来的某时间点执行一次任务
- at 指定时间点,执行一次性任务
- batch 系统自行选择空闲时间去执行此处指定的任务
周期性运行某任务
- cron
crontab命令:
语法:crontab [-u user] [-l | -r | -e] [-i]
选项:
-l 列出所有任务
-e 编辑任务
-r 移除所有任务
-i 与 -r 一同使用,以交互式模式移除指定任务
-u user 仅root可运行,指定用户管理cron任务
时间表示法:
(1) 特定值
给定时间点有效取值范围内的值
(2) *
给定时间点上有效取值范围内的所有值
表示“每...”
(3) 离散取值
#,#,#
(4) 连续取值
#-#
(5) 在指定时间范围上,定义步长
/#: #即为步长时间格式
@reboot Run once after reboot
@yearly 0 0 1 1 *
@annually 0 0 1 1 *
@monthly 0 0 1 * *
@weekly 0 0 * * 0
@daily 0 0 * * *
@hourly 0 * * * *
示例1:创建一个定时任务,要求每周的工作日1:30,将/etc备份至/backup目录中,保存的文件名称格式 为“etcbak-yyyy-mm-dd-HH.tar.xz”,其中日期是前一天的时间
crontab -e
30 1 * * 1-5 tar -Jcvf /backup/etcbak-$(date -d '1 days ago' +%F-%H).tar.xz /etc
检查结果:
crontab -l
30 1 * * 1-5 tar -Jcvf /backup/etcbak-$(date -d '1 days ago' +%F-%H).tar.xz /etc
示例2:工作日时间,每10分钟执行一次磁盘空间检查,一旦发现任何分区利用率高 于80%,就发送邮件报警.
crontab -e
*/10 * * 1-5 /root/while_read_check.sh
检查结果:
crontab -l
*/10 * * * 1-5 /root/while_read_check.sh
cat /root/while_read_check.sh
#!/bin/bash
warn=10
df|sed -rn '/^\/dev\/sd/s#^([^[:space:]]+).* ([[:digit:]]+)%.*$#\1 \2#p'|while read part use;do
if [ $use -gt $warn ];then
echo "$part will be full.use:$use" |mail -s 'Disk usage monitor.' root &> /dev/null
fi
done