首页 > 系统服务 > 详细

Linux操作系统中进程和计划管理

时间:2021-06-24 22:53:39      阅读:31      评论:0      收藏:0      [点我收藏+]

1. 程序与进程的关系

2. 查看进程信息-ps

3. 查看进程信息-top

4. 查看进程信息-pgrep

5. 查看进程树-pstree

6. 进程的启动方式与后台调度

7. 终止进程的运行

8. 计划任务管理

 

 

 

 

 

 

 

 

1. 程序与进程的关系

 程序

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

 进程

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

 进程与线程的关系

  • 一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程
  • 资源分配给进程,同一进程内的所有线程共享该进程的所有资源
  • 线程在执行过程中需要协作同步。不同进程中的线程之间要利用消息通信的方法实现同步;
  • 处理机分配给线程,即真正在处理机上运行的是线程
  • 线程是进程的一个执行单元,也是进程内的可调用实体。

  (资源分配的最小单位-进程程序执行的最小单位-线程

2. 查看进程信息-ps

 方法一

1 ps aux
2 查看静态的进程统计信息

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

 字段解释

  USER:进程的用户
  PID:进程的ID
  %CPU:进程占用的CPU百分比
  %MEM:占用内存的百分比
  VSZ:该进程使用的虚拟内存量(KB)
  RSS:该进程占用的物理内存量(KB)
  TTY:启动进程的终端名不是从终端启动的进程则显示为”?“
  STAT:进程的状态D:不可中断的休眠状态R:正在运行状态;S:处于休眠状态可被唤醒T:停止状态,可能是在后台暂停进程处于跟踪调试状态Z:僵尸进程进程已经中止但是部分程序还在内存当中
  START:该进程被触发启动时间
  TIME:该进程实际使用CPU运行的时间
  COMMAND:进程的启动命令

技术分享图片

 方法二

1 ps -elf
2 查看静态的进程统计信息
3 ps -aT
4 显示所有线程

  -e:显示系统内的所有进程信息
  -l:使用长格式显示进程信息
  -f:使用完整的格式显示进程信息
  -a:显示所有进程PID
  -T:查看线程信息

 字段解释

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

技术分享图片

3. 查看进程信息-top

1 top
2 查看动态的进程排名信息

 第一行任务队列信息

1 14:09:16       系统时间
2 up 2:55        系统已运行时长
3 1 user          当前登录用户数
4 load average: 0.00, 0.01, 0.05  系统负载,即单位时间内系统处理的任务数,后面三个数值分别为1分钟5分钟15分钟前到现在的平均值

 第二行为进程信息

 1 Tasks       总进程数
 2 running      正在运行的进程数
 3 sleeping     休眠的进程数
 4 stopped      中止的进程数
 5 zombie       僵死的进程数

僵尸进程:

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

 第三行为CPU信息

1 us   用户占用
2 sy   内核占用
3 ni   优先级调度占用
4 id   空闲CPU,要了解空闲的CPU百分比,主要看%id 部分(=总-us-sy-ni5 wa   I/O等待占用
6 hi   硬件中断占用
7 si   软件中断占用
8 st   虚拟化占用

 第四行为内存信息

1 total            总内存空间
3 free             空闲内存
5 used             已用内存
7 buff/cache       物理内存和交换内存的缓冲区总和

 第五行为交换空间信息

1 total             总交换空间
2 free              空闲交换空间
3 used              已用交换空间
4 avail Mem         可用物理空间

 技术分享图片

常用命令

1 P键根据CPU使用百分比大小进行排序
2 M键:根据驻留内存大小进行排序
3 N键:根据启动时间进行排序
4 c键:切换显示命令名称和完整命令行
5 h键:可以获得top程序的在线帮助信息
6 k键:根据提示输入指定进程的PID号并按Enter键终止对应的进程
7 q键退出top程序
8 数字1键显示CPU个数和状态
1 top -H            显示所有线程
2 top -H -P <pid>   显示特定进程中的线程

技术分享图片

技术分享图片

技术分享图片

 tty 终端

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

4. 查看进程信息-pgrep

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

1 pgrep -l "ce"
2 -l:显示进程名,缺省时只输出PID号
3 -U:指定特定用户
4 -t:指定终端

技术分享图片

5. 查看进程树-pstree

 以树形结构列出进程信息

1 pstree -aup
2 -a                    显示完整信息
3 -u                    列出对应用户名
4 -p                    列出对应PID号
5 pstree -ap 指定用户    查看指定用户进程树

技术分享图片

技术分享图片

6. 进程的启动方式与后台调度

 手工启动

  • 前台启动:用户输入命令直接执行程序
  • 后台启动:在命令行尾加入“&”符号
1 cp -R /data /opt &   
2 复制过程中可以后台运行(输出信息中包括后台任务序号和PID号

 进程的前后台调度

1 Ctrl + Z组合键
2 将当前进程挂起,即调入后台并停止执行
3  
4 jobs 命令
5 jobs [-l]        查看处于后台的任务列表
6 
7 fg 命令
8后台进程恢复到前台运行,可指定任务序号

技术分享图片

7. 终止进程的运行

1 Ctrl + C 组合键
2 中断正在执行的命令
3 
4 Kill、Killall命令
5 kill               用于终止指定PID号的进程
6 killall            用于终止指定名称相关的所有进程
7 -9 选项             用于强制终止

技术分享图片

技术分享图片

 pkill 命令

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

常用命令

  -∪:根据进程所属的用户名终止相应进程
  -t:根据进程所在的终端终止相应进程

1 pgrep -l -U "指定用户”
2 #查看
3 pkill -9 -U "指定用户”
4 #强行终止

8. 计划任务管理

 at 命令

  一次性计划任务

1 at [HH:MM] [yyyy-mm-dd]
2 
3 atq         #查看未执行的任务列表
4 
5 atrm 1      #删除第一条任务

技术分享图片

 crontab 命令

  • 按照预先设置的时间周期 分钟、小时、天、月、周重复执行用户指定的命令操作
  • 属于周期性计划任务
  • 主要设置文件

  全局配置文件,位于文件: /etc/crontab
  系统默认的设置,位于目录: /etc/cron.*/
  用户定义的设置,位于文件: /var/spool/cron/用户名

 管理crontab计划任务

1 编辑计划任务
2 crontab -e [-u 用户名]
3 #-u缺省默认是针对当前用户
1 查看计划任务
2 crontab -l [-u 用户名]
1 删除计划任务
2 crontab -r [-u 用户名]

 crontab任务配置格式

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

 时间数值的特殊表示方法

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

 应用示例

1 0 17 * * 1-5          周一到周五每天17:00
2 30 8 * * 1,3,5        每周一、三、五的8点30分
3 0 8-18/2 * * *        8点到18点之间每2小时
4 0 * */3 * *           每3天

  crontab -e [-u root]  (最好用绝对路径)

 每分钟定时执行一次规则

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

 

 每小时定时执行一次规则

1 每小时执行:0 * * * * 或者 0 * /1 * * *
2 每天上午7点执行:0 7 * * *
3 每天上午7点10分执行:10 7 * * *

 

 每天定时执行一次规则

1 每天执行:0 0 * * *

 

 每周定时执行一次规则

1 每周执行:0 0 * *1

 

 每月定时执行一次规则

1 每月执行:0 0 1 * *

 

 每年定时执行–次规则

1 1 每年执行:0 0 1 1 *

 

 1 10 * * * * ls       指定每小时的第10分钟执行一次ls命令
 2 30 10 * * * ls      指定每天的10:30执行ls命令
 3 30 10 10 * * ls     指定每月10号的10: 30分执行ls命令
 4 30 10 10 10 * ls    指定每年的10月10日10: 30执行ls命令
 5 30 10 * * 0 ls      指定每星期日的10:30执行ls命令
 6 30 10 10,20 * * ls  每月10号及20号的3: 30执行ls命令  [“,”用来连接多个不连续的时段]
 7 30 8-11 * * * ls    每天8-11点的第30分钟执行ls命令   [“-”用来连接连续的时段]
 8 */15 * * * * ls     每15分钟执行一次ls命令[即每个小时的第 0 15 30 45 60分钟执行ls命令]
 9 30 10 */10 * * ls   每个月中,每隔10天10:30执行一 次ls命令[即每月的1、11、21、31日是的10: 30执行一次ls命令]
10 */10 10-16 * 1,6 6 /usr/bin/ls -l    1,6月的每个周六从上午10点到下午的4点的每10分钟执行ls -l
1 echo ‘30 7 * * 7 /usr/bin/systemctl httpd restart‘ >> /var/spool/cron/root

 

Linux操作系统中进程和计划管理

原文:https://www.cnblogs.com/xyc11/p/14924164.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!