1.管理进程状态
(1)kill -l列出当前系统所支持的信号
[root@peachcat1 ~]# 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
16) SIGSTKFLT 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 34) SIGRTMIN 35) SIGRTMIN+1 36) SIGRTMIN+2 37) SIGRTMIN+3
38) SIGRTMIN+4 39) SIGRTMIN+5 40) SIGRTMIN+6 41) SIGRTMIN+7 42) SIGRTMIN+8
43) SIGRTMIN+9 44) SIGRTMIN+10 45) SIGRTMIN+11 46) SIGRTMIN+12 47) SIGRTMIN+13
48) SIGRTMIN+14 49) SIGRTMIN+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) SIGRTMAX
(2)常用信号
数字编号 | 信号含义 | 信号翻译 |
---|---|---|
1 | SIGHUP | 通常用来重新加载配置文件 |
9 | SIGKILL | 强制杀死进程 |
15 | SIGTERM | 终止进程,默认kill使用该信号 |
①kill
#给vsftpd发送信号
[root@peachcat1 ~]# yum install -y vsftpd
[root@peachcat1 ~]# systemctl start vsftpd
[root@peachcat1 ~]# ps aux | grep vsftpd
root 7866 0.0 0.1 53276 576 ? Ss 14:49 0:00 /usr/sbin/vsftpd /etc/vsftpd/vsftpd.conf
root 7869 0.0 0.2 112708 988 pts/0 R+ 14:49 0:00 grep --color=auto vsftpd
#发送重载信号
[root@peachcat1 ~]# kill -1 7866
#发送停止信号
[root@peachcat1 ~]# kill 7866
#发送强制停止信号
[root@peachcat1 ~]# kill -9 7866
②killall、pkill
用于杀死指定名字的进程
#通过服务名称杀掉进程
[root@peachcat1 ~]# pkill nginx
[root@peachcat1 ~]# killall nginx
#使用pkill踢出从远程登录到本机的用户,终止pts/0上所有进程,并且bash也结束(用户被强制退出)
[root@peachcat1 ~]# pkill -9 -t pts/0
2.管理后台进程
(1)什么是后台进程
通常进程都会在终端前台运行,一旦关闭终端,进程也会随着结束,那么此时我们就希望进程能在后台运行,就是将在前台运行的进程放入后台运行,这样即使我们关闭了终端也不影响进程的正常运行;
(2)为什么要将进程放入后台运行
比如:我们此前在国内服务器网国外服务器传输大文件时,由于网络的问题需要传输很久,如果在传输的过程中出现网络抖动或者不下心关闭了终端则会导致传输失败,如果能将传输的进程放入后台,就能解决这类问题了;
(3)将进程放入后台的工具
①jobs、bg、fg的使用(不推荐)
[root@peachcat1 ~]# sleep 3000 &
[1] 7888
[root@peachcat1 ~]# sleep 4000
^Z
[2]+ Stopped sleep 4000
[root@peachcat1 ~]# ps aux | grep "sleep"
root 7888 0.0 0.1 107952 616 pts/0 S 15:07 0:00 sleep 3000
root 7889 0.0 0.1 107952 616 pts/0 T 15:07 0:00 sleep 4000
root 7891 0.0 0.2 112708 988 pts/0 R+ 15:08 0:00 grep --color=auto sleep
[root@peachcat1 ~]# jobs
[1]- Running sleep 3000 &
[2]+ Stopped sleep 4000
②screen的使用(推荐)
#安装
[root@peachcat1 ~]# yum install -y screen
#开启一个screen窗口,指定名称
[root@peachcat1 ~]# screen -r wget_mysql
#在screen窗口中执行任务
#Ctrl+a+d平滑退出screen,不会终止screen中的任务;终止当前窗口可以用exit命令或者Ctrl+d
#查看当前运行的screen窗口有哪些
[root@peachcat1 ~]# screen -list
There is a screen on:
7895.wget_mysql (Detached)
1 Socket in /var/run/screen/S-root.
#进入正在运行的screen
[root@peachcat1 ~]# screen -r wget_mysql
[root@peachcat1 ~]# screen -r 7777
3.进程的优先级
(1)什么是优先级
优先级指的是优先享受资源
(2)为什么要有系统优先级
可以优先执行
(3)系统中如何给进程配置优先级
在启动进程时,为不同的进程使用不同的调度策略
nice值越高:表示优先级约越低,+19,该进程容易将CPU使用量让给其他进程;
nice值越低:表示优先级越低,-20,该进程更不倾向于让出CPU;
①使用top或ps命令查看进程的优先级
NI:实际nice级别,默认为0;PR:显示nice值,-20映射到0,+19映射到39(PR-NI=20)
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
802 root 20 0 300824 6284 4932 S 0.7 1.3 1:00.93 vmtoolsd
7913 root 20 0 161880 2188 1572 R 0.7 0.5 0:00.37 top
[root@peachcat1 ~]# ps axo command,nice | grep sshd |grep -v grep
/usr/sbin/sshd -D 0
sshd: root@pts/1 0
sshd: root@pts/0 0
②nice指定程序的优先级,nice -n 优先级数字 进程名称
#开启vim并且指定程序优先级为-5
[root@peachcat1 ~]# nice -n -5 vim &
[3] 7920
#查看该进程的优先级情况
[root@peachcat1 ~]# ps axo pid,command,nice | grep 7920
7920 vim -5
7922 grep --color=auto 7920 0
[3]+ Stopped nice -n -5 vim
4.系统平均负载
(1)什么是平均负载
平均负载就是单位时间内的活跃进程数,处于运行状态+处于等待运行+不可中断的进程(R+S+D)
(2)平均负载为多少时合适
最理想的状态是每个CPU上都刚好运行着一个进程,这样每个CPU都得到了充分利用,所以在评判平均负载时,首先要知道服务器有几个CPU,可以通过top命令获取,或者grep 'model name' /proc/cpuinfo
(3)平均负载的三个数值
①如果1分钟、5分钟、15分钟的三个值基本相同,或者相差不大,就说明系统负载很平稳;
②如果1分钟的值远小于15分钟的值,就说明系统最近1分钟的负载在减少,而过去15分钟内却又很大的负载
③如果1分钟的值远大于15分钟的值,就说明最近1分钟的负载在增加,这种增加可能是临时的,也可能会持续上升,需要持续观察;
一旦1分钟的平均负载接近或者超过了CPU的个数,就意味着系统正在发生过载的问题,这是就要分析问题,并想办法优化
(4)实际生产环境中,平均负载多高,需要重点关注
当平均负载高于CPU数量70%的时候,就应该排查负载高的问题了,一旦负载过高,就可能导致进程相应变慢,进而影响服务的正常功能;
但70%这个数字不是绝对的,最推荐的方法是把系统的平均负载监控起来,根据历史数据判断负载的变化趋势,当发现负载有明显升高趋势时,再分析调查;
(5)平均负载与CPU使用率有什么关系
平均负载是指单位时间内,处于可运行和等待运行和不可中断状态的进程数,所以,它不仅包括了正在使用CPU的进程,还包括等待CPU和等待I/O的进程;
CPU使用率是指单位时间内,CPU繁忙情况的统计,跟平均负载并不一定完全对应;
比如:
CPU密集型进程,使用大量CPU会导致平均负载升高,此时两者是一致的;
I/O密集型进程,等待I/O也会导致平均负载升高,但CPU使用率不一定很高;
大量等待CPU的进程调度也会导致平均负载升高,此时CPU的使用率也会比较高。