进程和计划任务管理

简介: 1、查看进程2、控制进程 3、at一次性任务设置4、crontab周期性任务设置

1、程序和进程的关系:


image.png


查看静态的进程信息:ps aux   (不要加-否则显示的信息不够全)

选项有【a】显示终端上的所有进程,包括其它用户进程

        【u】表示列出进程的用户

          【x】显示所有终端的进程


b9.png

各列的解释:


USER:进程的用户。

PID:进程的ID。

CPU:进程占用的CPU百分比。

各MEM:占用内存的百分比。

VSZ:该进程使用的虚拟内存量(KB)

RSS:该进程占用的物理内存量(KB)

TTY:启动进程的终端名。不是从终端启动的进程则显示为?

STAT:该进程的状态(D:不可中断的休眠状态 R:正在运行状态 S:处于休眠状态,可被唤醒 T:停止状态,

可能是在后台暂停或进程处于跟踪调试状态  Z:僵尸进程,进程已经中止,但是部分程序还在内存当中)

START:该进程被触发启动时间。

TIME:该进程实际使用CPU运行的时间

COMMAND:进程的启动命令。


查看静态的进程信息:ps -elf                

选项有:


【e】显示系统内的所有进程信息。

【l】使用长格式显示进程信息。

【f】使用完整的格式显示进程信息。

【a】显示所有进程pid。

【T】查看线程信息。


b10.png


F:内核分配给进程的系统标记。

S:进程的状态。

UID:启动这些进程的用户。

PID:进程的进程ID。

PPID:父进程的进程号(如果该进程是由另一个进程启动的)

C:进程生命周期中的CPU利用率。

PRI:进程的优先级(越大的数字代表越低的优先级)

NI:谦让度值用来参与决定优先级。

ADDR:进程的内存地址。

SZ:假如进程被换出,所需交换空间的大致大小。

WCHAN:若该进程在睡眠,则显示睡眠中的系统函数名。

STIME:进程启动时的系统时间。

TTY:进程启动时的终端设备。

TIME:运行进程需要的累计CPU时间

CMD:进程的启动命令。


补充:


显示所有线程 :ps -aT                 

一个进程结束了,但是如果该进程的父进程已经先结束了,那么该进程就不会变成僵尸进程,因为每个进程结束的时候,系统都会扫描当前系统中所运行的所有进程,看有没有哪个进程是刚刚结束的这个进程的子进程,如果是的话,就由Init来接管它,成为它的父进程,进程退出后init会回收其占用的相关资源。

但是当子进程比父进程先结束,而父进程又没有回收子进程,释放子进程占用的资源,此时子进程将成为一个僵尸进程。


查看动态进程排名信息:top         

b11.png

第一行是                                   任务队列信息

18:45:18                                系统时间

up 58min                               系统已运行时长

3 user                               当前登录用户数

load average:0.00,0.01,0.05          系统负载,即单位时间内系统处理的任务数,后面三个数值分别为       1分钟、5分钟、15分钟前到现在的平均值


第二行                                     进程信息

Tasks                                     总进程数

running                                   正在运行的进程数

sleeping                                  休眠的进程数

stopped                                   中止的进程数

zombie                                    僵死的进程数


第三行                                     CPU的信息

us                                        用户占用

sy                                        内核占用

ni                                        优先级调度占用

id                                        空闲CPU,要了解空闲的CPU百分比,主要看id部分

wa                                        I/O等待占用

hi                                        硬件中断占用

si                                        软件中断占用

st                                        虚拟化占用


第四行                                      内存的信息

total                                      总内存空间

free                                       空闲内存

used                                       已用内存

buff/cache                                 物理内存和交换内存的缓冲区总和


第五行                                       交换空间的信息

total                                       总交换空间

total                                       空闲交换空间

used                                        已用交换空间

avail Mem                                  可用物理空间


进程信息区各列解释:


进程id       PID

USER        进程所有者的用户名

PR             优先级

NI             谦让度值。负值表示高优先级,正值表示低优先级

VIRT           进程使用的虚拟内存总量,单位kb

RES            进程使用的物理内存大小,单位kb

SHR            共享内存大小,单位kb

S              进程状态

%CPU           上次更新到现在的CPU时间占用百分比

%MEM           进程使用的物理内存百分比

TIME+          进程使用的CPU时间总计,单位1/100秒

COMMAND        命令名/命令行


top常用命令:


1

2

3

4

5

6

7

8

9

10

P键:根据CPU使用百分比大小进行排序

M键:根据驻留内存大小进行排序

N键:根据启动时间进行排序

c键:切换显示命令名称和完整命令行

h键:可以获得top程序的在线帮助信息

k键:根据提示输入指定进程的PID号并按Enter键终止对应的进程

q键:退出top程序

数字1键:显示CPU个数和状态

top-H:显示所有线程

top-H-p<pid>:显示特定进程中的线程


补充:centos7 系统,tty1表示图形界面,tty2-tty6表示文字界面,可以用ctrl+alt+f1-f6  切换。

pts说明表示是用远程工具连接的,比如xshell,后面数字表示登录的时间,越小登录的越早

 

 

根据特定条件查询进程PID信息:pgrep


b12.png


以树形结构列出进程信息:pstree          


b13.png


b14.png


2、进程的启动方式:      


手工启动

后台启动:在命令行尾加入“&”符号

前台启动:用户输入命令,直接执行程序


进程的前后台调度:Ctrl+z组合键 ,将当前程序挂起,即调入后台并停止执行 


b15.png


jobs 【-l】          查看处于后台的任务列表


b16.png


fg命令    将后台进程恢复到前台运行,可指定任务序号


b17.png


ctrl+c组合键       :          中断正在执行的命令

kill、killall命令 :

kill用于终止指定PID号的进程

killall用于终止指定名称相关的所有进程

-9选项用于强制终止

 

pkill                  :         根据特定条件终止相应的进程

常用命令选项

-U:根据进程所属的用户名终止相应进程

-t: 根据进程所在的终端终止相应程


b18.pngb19.pngb20.png

3、一次性计划任务  :at    


at 【HH:MM】【yyyy-mm-dd】

H:时

M:分

yyy:年

mm:月

dd:日

[root@localhost~]#at 18:18           不跟年月日,表示使用当前日期

at> shutdown -h now

at> <EOT>                             按  ctrl d   提交一次性计划任务

job 2 at Sun May 7 18:18:00 2017

[root@localhost~]# atq                查看未执行的任务列表

[root@localhost~]# atrm 1             删除第一条任务

  

4、周期性管理: crontab  

            

  • 按照预先设置的时间周期(分钟、小时、天、月、周)重复执行用户指定的命令操作
  • 属于周期性计划任务
  • 主要设置文件
  • 全局配置文件,位于文件:/etc/crontab
  • 系统默认的设置,位于目录:/etc/cron.*/
  • 用户定义的设置,位于文件:/var/spool/cron/用户名

管理crontab计划任务

  • 编辑计划任务  crontab -e 【-u 用户名】         -u缺省时默认是针对当前用户
  • 查看计划任务  crontab -l  【-u 用户名】
  • 删除计划任务  crontab -r  【-u 用户名】

 

crontab 任务配置格式:

b21.png

  • 字段                                                        说明
  • 分钟                                                        取值为从0到59之间的任意整数
  • 小时                                                        取值为从0到23之间的任意整数
  • 日期                                                        取值为从1到31之间的任意整数
  • 月份                                                        取值为从1到12之间的任意整数
  • 星期                                                        取值为从0到7之间的任意整数,0或7代表星期日
  • 命令                                                        要执行的命令或程序脚本

 

 

时间数值的特殊表示方法

  • * 表示该范围内的任意时间
  • , 表示间隔的多个不连续时间点
  • -   表示一个连续的时间范围
  • /   指定间隔的时间频率

 

 

例子:


0 17 * * 1-5         周一到周五每天17点

30 8 * * 1,3,5       周一,周三,周五8.30

0 8-18/2 * * *       8点到18点每两小时

0 * */3 * *          每三天


crontab -e 【-u root】 编辑计划任务


每分钟定时执行一次规则:

每1分钟执行:*/1 * * * 或者 * * * * *  

每5分钟执行:*/5 * * * *

 

每小时定时执行一次规则:

每小时执行:  0 * * * * 或者 0 */1 * * *

每天上午7点执行:0 7 * * *

每天上午7点10分执行:10 7 * * *

 

每天定时执行一次规则:

每天执行 0 0 * * *

 

每周定时执行一次规则:

每周执行 0 0 * * 1

 

每月定时执行一次规则:

每月执行 0 0 1 * *

 

每年定时执行一次规则:

每年执行 0 0 1 1 *


其它类型例子:


5 * * * * ls         指定每小时的第5分钟执行一次ls命令

30 5 * * * ls        指定每天的 5:30 执行ls命令

30 7 8 * * ls        指定每月8号的7:30分执行ls命令

30 5 8 6 * ls        指定每年的6月8日5:30执行ls命令

30 6 * * 0 ls        指定每星期日的6:30执行ls命令【注:0表示星期天,1表示星期1,以此类推,也可以用英文来表示,sun表示星期天,mon表示星期一等。】

30 3 10,20 * * ls    每月10号及20号的3:30执行ls命令[注:“,”用来连接多个不连续的时段]

25 8-11 * * * ls     每天8-11点的第25分钟执行ls命令[注:“-”用来连接连续的时段]

*/15 * * * * ls      每15分钟执行一次ls命令 [即每个小时的第0 15 30 45 60分钟执行ls命令 ]

30 6 */10 * * ls     每个月中,每隔10天6:30执行一次ls命令[即每月的1、11、21、31日是的6:30执行一次ls命


还有一个方法就是:  echo ‘30 7 * * 6 /usr/bin/systemctl httpd restart’ >> /var/spool/cron/root

 

 

 

总结 :


• 查看进程的命令(ps、 top、pgrep、 pstree)

• 进程控制                  

 启动进程、调度进程、终止进程        

• at命令 设置计划任务 (一次性任务)    

• crontab计划任务的配置字段 (周期性任务)

相关文章
|
4月前
|
调度 Windows Perl
进程和计划任务管理
进程和计划任务管理
36 0
|
10月前
|
分布式计算 Hadoop
hadoop进程启停管理
hadoop进程启停管理
59 0
|
2月前
|
SQL 自然语言处理 网络协议
【Linux开发实战指南】基于TCP、进程数据结构与SQL数据库:构建在线云词典系统(含注册、登录、查询、历史记录管理功能及源码分享)
TCP(Transmission Control Protocol)连接是互联网上最常用的一种面向连接、可靠的、基于字节流的传输层通信协议。建立TCP连接需要经过著名的“三次握手”过程: 1. SYN(同步序列编号):客户端发送一个SYN包给服务器,并进入SYN_SEND状态,等待服务器确认。 2. SYN-ACK:服务器收到SYN包后,回应一个SYN-ACK(SYN+ACKnowledgment)包,告诉客户端其接收到了请求,并同意建立连接,此时服务器进入SYN_RECV状态。 3. ACK(确认字符):客户端收到服务器的SYN-ACK包后,发送一个ACK包给服务器,确认收到了服务器的确
167 1
|
2月前
|
Ubuntu Unix Linux
如何使用 Supervisor 管理你的进程
**Supervisor** 是一款Python编写的进程管理工具,用于类Unix系统,确保应用服务持续运行。常用命令包括:`reload`(重新加载配置)、`status`(查看进程状态)、`shutdown`(关闭所有进程)、`start`和`stop`(控制单个进程)。在CentOS上安装Supervisor用`yum install -y supervisor`,配置文件通常在`/etc/supervisord.conf`。
45 0
|
4月前
|
存储 Java 调度
Java多线程基础-1:通俗简介操作系统之进程的管理与调度
操作系统是一个复杂的软件,具备许多功能。其中,进程的管理与调度是与我们密切相关的。本文将对操作系统功能中进程管理与调度作出介绍。
43 0
|
4月前
|
消息中间件 监控 Linux
Linux进程和计划任务管理
通过这些命令和工具,你可以有效地管理Linux系统中的进程和计划任务,监控系统的运行状态并保持系统的稳定和可靠性。 买CN2云服务器,免备案服务器,高防服务器,就选蓝易云。百度搜索:蓝易云
129 2
|
4月前
|
存储 调度
进程的奥德赛:并发世界中的核心概念与动态管理
进程的奥德赛:并发世界中的核心概念与动态管理
59 2
|
4月前
|
存储 Linux 程序员
【Linux C/C++ 堆内存分布】深入理解Linux进程的堆空间管理
【Linux C/C++ 堆内存分布】深入理解Linux进程的堆空间管理
275 0
|
2月前
|
运维 关系型数据库 MySQL
掌握taskset:优化你的Linux进程,提升系统性能
在多核处理器成为现代计算标准的今天,运维人员和性能调优人员面临着如何有效利用这些处理能力的挑战。优化进程运行的位置不仅可以提高性能,还能更好地管理和分配系统资源。 其中,taskset命令是一个强大的工具,它允许管理员将进程绑定到特定的CPU核心,减少上下文切换的开销,从而提升整体效率。
掌握taskset:优化你的Linux进程,提升系统性能

相关实验场景

更多