首页 > 系统相关 >进程及计划任务管理

进程及计划任务管理

时间:2022-10-09 15:58:54浏览次数:51  
标签:占用 crontab 任务 计划 线程 内存 进程 CPU

1.程序和进程的关系

1.1 程序

  • 保存在硬盘、光盘等介质中的可执行代码和数据
  • 文件中静态保存的代码

1.2 进程

  • 在CPU及内存中运行的程序代码
  • 动态执行的代码
  • 父、子进程
  • 每个程序可以创建一个或多个进程

1.3 线程和进程的关系

线程:程序执行的最小单位

  • 线程 是CPU调度的最小单位(程序执行流的最小单元),它被包含在进程之中,是进程中的实际运作单元。
  • 一条线程是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务
  • (一个线程挂掉会影响其他线程,而进程之间是互相隔离的,互不影响)

进程:资源分配的最小单位

  • 进程 是程序执行时的一个实例,即它是程序已经执行到课中程度的数据结构的汇集。
  • 从内核的观点看,进程的目的就是担当分配系统资源(CPU时间、内存等)的基本单位

总的来说:进程有独立的地址空间,线程没有单独的地址空间(同一进程内的线程共享进程的地址空间)

2.查看进程信息

2.1 ps -aux

  • a: 显示终端上的所有进程,包括其它用户的进程。
  • u: 表示列出进程的用户。
  • x: 显示所有终端的进程。 
  • k:倒序

 

 

 

查看cpu使用率

 

 

 

 

 

各列名称涵义
USER 进程的用户
PID 进程的ID
%CPU 进程占用的CPU百分比
%MEM 占用内存的百分比
VSZ 该进程使用的虚拟内存量(KB)
RSS 该进程占用的物理内存量(KB)
TTY 启动进程的终端名。不是从终端启动的进程则显示为? (本地终端是用tty1,tty2表示,pts是远程终端)
STAT: 该进程的状态
D:不可中断的休眠状态;
R:正在运行状态;
S:处于休眠状态,可被唤醒;
T:停止状态,可能是在后台暂停或进程处于跟踪调试状态;
Z: 僵尸进程,进程已经中止,但是部分程序还在内存当中 (查看僵尸进程,及时将其kill);
w 进入内存交换(从内核2.6开始无效);
X,死掉的进程;< 高优先级;
N 低优先级;
L 有些页被锁进内存;
s 包含子进程;
+ 位于后台的进程组;
l 多线程,克隆线程)
START 该进程被触发启动时间
TIME 该进程实际使用CPU运行的时间
COMMAND 进程的启动命令

补充知识:

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

2.2 ps -elf

常用选项

  • -e: 显示系统内的所有进程信息
  • -l: 使用长格式显示进程信息
  • -f: 使用完整的格式显示进程信息

 

 

 

各列解释:

名称涵义
F 内核分配给进程的系统标记
S 进程的状态
UID 启动这些进程的用户
PID 进程的进程ID
PPID 父进程的进程号(如果该进程是由另一个进程启动的)
C 进程生命周期中的CPU利用率
PRI 进程的优先级(越大的数字代表越低的优先级,不可人为修改)
NI 优先级(可人为修改)
ADDR 进程的内存地址
SZ 假如进程被换出,所需交换空间的大致大小
WCHAN 若该进程在睡眠,则显示睡眠中的系统函数名
STIME 进程启动时的系统时间
TTY 进程启动时的终端设备
TIME 运行进程需要的累计CPU时间
CMD 进程的启动命令

2.3 top

 

 

 五行信息解释

行列名称各字段涵义
第一行任务队列信息 14 : 09 : 16(系统时间)up 5:31(系统已运行时长)2user(当前登录用户数)oad average: 0.00, 0.01, 0.05(系统负载,即单位时间内系统处理的任务数,后面三个数值分别为1分钟、5分钟、15分钟前到现在的平均值)(Load Average的值应该小于CPU个数核数0.7)
第二行为进程信息 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(总交换空间)free(空闲交换空间)used(已用交换空间)avail Mem(可用物理空间)

各列解释

各列名称涵义
PID 进程id
USER 进程所有者的用户名
PR 优先级
NI 谦让度值。负值表示高优先级,正值表示低优先级
VIRT 进程使用的虚拟内存总量,单位kb
RES 进程使用的物理内存大小,单位kb
SHR 共享内存大小,单位kb
S 进程状态
%CPU 上次更新到现在的CPU时间占用百分比
%MEM 进程使用的物理内存百分比
TIME+ 进程使用的CPU时间总计,单位1/100秒
COMMAND 命令名/命令行

top常用命令

快捷键作用
P键 根据CPU使用百分比大小进行拥序
M键 根据驻留内存大小进行排序
N键 根据启动时间进行排序
c键 切换显示命令名称和完整命令行
h键 可以获得top程序的在线帮助信息
k键 根据提示输入指定进程的PID号并按Enter 键终止对应的进程
q键 退出top程序
数字1键 显示CPU个数和状态

tty终端
Centos7系统,tty1表示图形界面,tty2-tty6表示文字界面,可以用Ctrl+Alt+F1-F6切换
pts说明是用远程工具连接的,比如xshell,后面的数字代表登录的时间顺序,越小证明登录的越早

查看线程 top -H;ps -T
top -H -p :显示特定进程中的线程

2.4 pstree

-p 显示端口号

 

 

2.5 vmstat 和 iostat

 

 

 

 

3.进程后台执行

命令+&

补充:ctrl + z是把进程放在后台并停止

4.停止进程

4.1 kill

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

-9选项用于强制终止(可能会导致数据的丢失,能不用就不用)

-19暂停

-18开始

-1停止

4.2 killall

killall+指定名称可以停止相关的所有进程

5.crontab

5.1 crontab的概念

周期性计划任务

• 按照预先设置的时间周期 分钟、小时、天、月、周重复执行用户指定的命令操作

• 属于周期性计划任务

5.2 管理crontab计划任务

crontab -e [-u 用户名]         #编辑计划任务,-u缺省时表示当前用户
crontab -l [-u 用户名]         #查看计划任务
crontab -r [-u 用户名]         #删除计划任务

5.3 crontab的格式

项目含义范围
第一个"*" 一小时当中的第几分钟(minute) 0~59
第二个"*" 一天当中的第几小时(hour) 0~23
第三个"*" 一个月当中的第几天(day) 1~31
第四个"*" 一年当中的第几个月(month) 1~12
第五个"*" 一周当中的星期几(week) 0~7(0和7都代表星期日)
特殊符号含义
*(星号) 代表任何时间。比如第一个"*"就代表一小时种每分钟都执行一次的意思。
,(逗号) 代表不连续的时间。比如"0 8,12,16***命令"就代表在每天的 8 点 0 分、12 点 0 分、16 点 0 分都执行一次命令。
-(中杠) 代表连续的时间范围。比如"0 5 ** 1-6命令",代表在周一到周六的凌晨 5 点 0 分执行命令。
/(正斜线) 代表每隔多久执行一次。比如"/10***命令",代表每隔 10 分钟就执行一次命令。

5.4 编辑crontab计划任务

 

标签:占用,crontab,任务,计划,线程,内存,进程,CPU
From: https://www.cnblogs.com/yuqiao9/p/16772134.html

相关文章

  • python 默认主进程结束前,不会主动结束子进程
    1#coding=utf82importmultiprocessing3importtime456defprocess(name):7whileTrue:8print('进程名:{}正在运行...'.format(name)......
  • 定时任务参数配置
    QuartZCron表达式解析:Cron表达式由7个部分组成,每个部分使用空格隔开。表达式中的七个部分从左到右代表的含义如下:秒分时日(每月中的一天)月日(每周中的一天)年 具体参......
  • supervisor 部署及管理进程
    部署yum-yinstallepel-releaseyum-yinstallsupervisor查看配置systemctlcatsupervisord   修改配置   #主要是内存 文件打开数[root@bogon......
  • linux 定时任务 加锁
    ​​*/3****flock-xn/home/work/fupeng/oem_apk_new.lock-c'sh/home/work/fupeng/oem_apk_new.sh>/dev/null2>&1'>/dev/null2>&1......
  • Linux进程冻结
    主要参考:Documentation\power\freezing-of-tasks.rstFreezingoftasks—TheLinuxKerneldocumentation【原创】LinuxSuspend流程分析-LoyenWang-博客园(cnb......
  • 说说 Spring 定时任务如何大规模企业级运用
    作者:姚辉(千习)Spring定时任务简介定时任务是业务应用开发中非常普遍存在的场景(如:每分钟扫描超时支付的订单,每小时清理一次数据库历史数据,每天统计前一天的数据并生成报......
  • leetcode-621. 任务调度器
    621.任务调度器假设有任务["A","A","A","B","B","B"],n=2,可以画图表示CPU的时间分配MT表示maxTime,这个任务列表中出现次数最大的任务数量,这里就是MT=3MC表示maxCou......
  • 狐漠漠养成日记 Cp.00001 开始养成计划
    开始养成计划今天是我开始这个“狐漠漠养成计划”的第一天(划掉)。看来是昨天出门前忘记保存了,昨天写的几百字内容全都没有了,今天其实已经是计划开始的第二天了。因为昨天......
  • 大疆 L1 任务文件格式说明(CLC/CLI/CMI/IMU/LDR/MNF/RTB/RTK/RTL/RTS/JPG/MOV)
    大疆L1任务文件格式说明(CLC/CLI/CMI/IMU/LDR/MNF/RTB/RTK/RTL/RTS/JPG/MOV)​​大疆L1官网简介​​​​CLC​​​​CLI​​​​CMI​​​​IMU​​​​LDR​​​​MNF​......
  • 定时任务
    目录定时任务-crond定时任务的作用定时任务语法定时任务相关命令定时任务实战备份定时任务拒绝某个用户使用定时任务定时任务调试规则linux发邮件使用定时任务发情书思维导......