管理后台进程
1.什么是后台进程:通常进程会在终端前台运行,一旦关闭终端,进程也会随着结束,那么此时我们就希望进程能在后台进行,就是将在前台运行的进程放入后台运行,这样即使我们关闭了终端也不影响进程的正常运行
2.我们为什么要将进程放入后台运行
比如:我们此前在国内服务器往国外服务器传输大文件时,由于网络的问题需要传输很久,如果在传输的过程中出现网络抖动或者不小心关闭了终端则会导致传输失败,如果能将传输的进程放入后台,是不是就能解决此类问题了。
3.使用什么工具将进程放入后台
早期的时候大家都选择使用&符号将进程放入后台,然后在使用jobs、bg、fg等方式查看进程状态,但太麻烦了。也不直观,所以我们推荐使用screen。
安装screen
[root@oldboy ~]# yum install screen -y
#2.开启一个screen窗口,指定名称[root@oldboy ~]# screen -S wget_mysql
#3.在creen 窗口中执行任务即可
#4.平滑的退出screen 但不会终止这个任务
ctrl+a+d 是挂起在后台执行,
要想真正的退出程序 ctrl+c 终止程序 然后 exit 退出 后台就没有进程了
5.查看当前正在运行的screen有哪些
[root@oldboy ~]# screen -listThere is a screen on:22058.wget_mysql (Detached)1 Socket in /var/run/screen/S-root.
6.进入正在运行的screen 可以是进程编号 也可以是名字
[root@oldboy ~]# screen -r wget_mysql[root@oldboy ~]# screen -r 22058
5.进程的优先级
1.什么优先级
优先级指的是优先享受资源,比如排队买票时,军人优先、老人优先。等等
2.为什么要与系统优先级
举个例子: 海底捞火锅正常情况下响应就特别快,那么当节假日来临时人员突增则会导致处理请求特别慢,那么假设我是海底捞VIP客户(最高优先级),无论门店多么繁忙,我都不用排队,海底捞人员会直接服务于我,满足我的需求。至于没有VIP的人员(较低优先级)则进入排队等待状态。(PS: 至于等多久,那.....)
3.系统中如何有系统优先级
在启动进程时,为不同的进程使用不同的调度策略。nice 值越高: 表示优先级越低,例如+19,该进程容易将CPU 使用量让给其他进程。nice 值越低: 表示优先级越高,例如-20,该进程更不倾向于让出CPU。
1)使用top或ps命令查看进程的有限级
#1.使用top可以查看nice优先级。 NI: 实际nice级别,默认是0。 PR: 显示nice值,-20映射到0,+19映射到39PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND1083 root 20 0 298628 2808 1544 S 0.3 0.1 2:49.28 vmtoolsd5 root 0 -20 0 0 0 S 0.0 0.0 0:00.00 kworker/0:+
#2.使用ps查看进程优先级[root@m01 ~]# ps axo command,nice |grep sshd|grep -v grep/usr/sbin/sshd -D 0sshd: root@pts/2 0
2.nice指定程序的优先级 语法格式nice -n 优先级数字 进程名称
1.开启vim并且指定程序优先级为-5[root@m01 ~]# nice -n -5 vim & &后台执行[1] 98417
#2.查看该进程的优先级情况[root@m01 ~]# ps axo pid,command,nice |grep 98417 98417 vim -5
#3.renice命令修改一个正在运行的进程优先级。语法格式 renice -n 优先级数字 进程pid
#1.查看sshd进程当前的优先级状态[root@m01 ~]# ps axo pid,command,nice |grep 折叠shd 70840 sshd: root@pts/2 0 98002 /usr/sbin/sshd -D 0
#2.调整sshd主进程的优先级[root@m01 ~]# renice -n -20 9800298002 (process ID) old priority 0, new priority -20
#3.调整之后记得退出终端[root@m01 ~]# ps axo pid,command,nice |grep 折叠shd 70840 sshd: root@pts/2 0 98002 /usr/sbin/sshd -D -20[root@m01 ~]# exit
#4.当再次登陆sshd服务,会由主进程fork子进程(那么子进程会继承主进程的优先级)[root@m01 ~]# ps axo pid,command,nice |grep 折叠shd 98002 /usr/sbin/sshd -D -20 98122 sshd: root@pts/0 -20
6.系统平均负载[进阶]
每次发现系统变慢时,我们通常做的第一件事,就是执行 top 或者 uptime 命令,来了解系统的负载情况。比如像下面这样,我在命令行里输入了 uptime 命令,系统也随即给出了结果。
[root@m01 ~]# uptime04:49:26 up 2 days, 2:33, 2 users, load average: 0.70, 0.04, 0.05#我们已经比较熟悉前面几列,它们分别是当前时间、系统运行时间以及正在登录用户数。
而最后三个数字呢,依次则是过去 1 分钟、5 分钟、15 分钟的平均负载(Load Average)。
1.什么是平均负载平均负载不就是单位时间内的 CPU 使用率吗?上面的 0.70,就代表 CPU 使用率是 70%。其实上并.....那到底如何理解平均负载: 平均负载是指单位时间内,系统处于可运行状态和不可中断状态的平均进程数,也就是平均活跃进程数,PS: 平均负载与 CPU 使用率并没有直接关系。
3.那平均负载为多少时合理最理想的状态是每个 CPU 上都刚好运行着一个进程,这样每个 CPU 都得到了充分利用。所以在评判平均负载时,首先你要知道系统有几个 CPU,这可以通过 top 命令获取,或grep 'model name' /proc/cpuinfo
例1、假设现在在 4、2、1核的CPU上,如果平均负载为 2 时,意味着什么呢? Q1.在4 个 CPU 的系统上,意味着 CPU 有 50% 的空闲。Q2.在2 个 CPU 的系统上,意味着所有的 CPU 都刚好被完全占用。Q3.而1 个 CPU 的系统上,则意味着有一半的进程竞争不到 CPU。
.平均负载与 CPU 使用率有什么关系在实际工作中,我们经常容易把平均负载和 CPU 使用率混淆,所以在这里,我也做一个区分。可能你会疑惑,既然平均负载代表的是活跃进程数,那平均负载高了,不就意味着 CPU 使用率高吗?我们还是要回到平均负载的含义上来,平均负载是指单位时间内,处于可运行状态和不可中断状态的进程数。所以,它不仅包括了正在使用 CPU 的进程,还包括等待 CPU 和等待 I/O 的进程。*
而 CPU 使用率,是单位时间内 CPU 繁忙情况的统计,跟平均负载并不一定完全对应。比如:CPU 密集型进程,使用大量 CPU 会导致平均负载升高,此时这两者是一致的;I/O 密集型进程,等待 I/O 也会导致平均负载升高,但 CPU 使用率不一定很高;大量等待 CPU 的进程调度也会导致平均负载升高,此时的 CPU 使用率也会比较高。