云计算【第一阶段(22)】进程和计划任务管理

news2024/7/6 18:57:58

一、查看进程

1.1、程序和进程的关系

程序

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

进程

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

1.2、查看进程

1.2.1、静态查看进程信息ps

ps    参数

常用的参数

  • -a:显示当前终端下的所有进程信息,包括其他用户的进程。与“x”选项结合时将显示系统中所有的进程信息。
  • -u:使用以用户为主的格式输出进程信息。
  • -x:显示当前用户在所有终端下的进程信息。
  • -e:显示系统内的所有进程信息。
  • -1:使用长格式显示进程信息。
  • -f:使用完整的格式显示进程信息。

常用的选项组合
ps    -aux        #将以简单列表的形式显示出进程信

ps     -elf        #将以长格式显示系统中的进程信息
 

字段描述
USER启动该进程的用户账号的名称
PID该进程在系统中的唯一数字ID号
%CPUCPU占用的百分比
%MEM内存占用的百分比
VSZ虚拟内存使用量(KB)
RSS物理内存使用量(KB)
TTY进程运行的终端。非终端启动的进程显示为pts: 远程登录终端,tty1-tty6: 本地终端(可能包括图像界面和字符界面),?: 系统自身执行的进程
STAT

进程状态:D: 不可中断的休眠状态R: 运行状态S: 休眠状态T: 停止状态Z: 僵尸进程

其他状态如<NLsl+ 也有各自的含义

START启动该进程的时间
TIME该进程占用的CPU时间
COMMAND启动该进程的命令的名称

 STAT补充

状态代码描述
D不可中断的休眠状态。通常用于等待I/O操作完成。这并不意味着它是系统守护进程,但守护进程可能会处于此状态。
R运行状态。进程正在运行或准备运行。
S休眠状态。进程在等待某个条件成立以便继续执行。
T停止状态。进程收到SIGSTOP、SIGTSTP、SIGTTIN或SIGTTOU信号后停止执行。
Z僵尸状态。进程已经终止,但父进程尚未回收其资源。
<进程运行在高优先级上(这个符号通常不直接出现在STAT列中,而是可能作为其他信息的一部分)。
N进程运行在正常优先级上(这个符号通常不直接出现在STAT列中,而是可能作为其他信息的一部分)。
L进程有页面锁定在内存中(这个状态代码可能不直接出现在STAT列中,而是作为进程属性的一部分)。
s进程是控制终端的会话领导(session leader)。
l进程是多线程的(这个状态代码可能不直接出现在STAT列中,而是作为进程属性的一部分)。
+进程在前台运行(这个状态代码可能不直接出现在STAT列中,而是作为进程状态的一部分)。

 

列名解释
F内核分配给进程的系统标记
S进程的状态
UID启动这些进程的用户
PID进程的进程ID
PPID父进程的进程号(如果该进程是由另一个进程启动的)
C进程生命周期中的CPU利用率
PRI进程的优先级(越大的数字代表越低的优先级)
NI谦让度值用来参与决定优先级
ADDR进程的内存地址
SZ假如进程被换出,所需交换空间的大致大小
WCHAN若该进程在睡眠,则显示睡眠中的系统函数名
STIME进程启动时的系统时间
TTY进程启动时的终端设备(pts/0-255代表虚拟终端,tty1-tty7代表本地控制台终端)
TIME运行进程需要的累计CPU时间
CMD进程的启动命令
状态描述
D不可被唤醒的睡眠状态,通常用于 I/O 情况
R该进程正在运行
S该进程处于睡眠状态,可被唤醒
T停止状态,可能是在后台暂停或进程处于除错状态
W内存交互状态(从 2.6 内核开始无效)
X死掉的进程(应该不会出现)
Z僵尸进程。进程已经中止,但是部分程序还在内存当中
<高优先级(以下状态在 BSD 格式中出现)
N低优先级
L被锁入内存
s包含子进程
l多线程(小写 L)
+位于后台
C进程占用CPU的百分比

1.2.1.1、实验

在终端A执行 编写vim  a.txt

打开另一个终端B

ps -aux |grep a.txt

S 表示睡眠状态, + 表示前台

这个终端A上 按下: ctrl+z 停止

再次查看状态

查看状态 T 表示停止状态

扩展:
ctrl  -   c 是发送 SIGINT 信号,终止一个进程
ctrl  -   z 是发送 SIGSTOP 信号,挂起一个进程。将作业放置到后台(暂停)
ctrl  -   d 不是发送信号,而是表示一个特殊的二进制值,表示 EOF。代表输入完成或者注销
 

 1.2.2、动态查看进程信息top

top   命令

类别描述
系统任务(Tasks)
total总进程数
running正在运行的进程数
sleeping休眠的进程数
stopped中止的进程数
zombie僵死无响应的进程数
CPU 占用
us用户占用
sy内核占用
ni优先级调度占用
id空闲CPU(百分比)
waI/O 等待占用
hi硬件中断占用
si软件中断占用
st虚拟化占用
内存占用(Mem)
total总内存空间
free空闲内存
used已用内存
buff/cache物理内存和交换内存的缓冲区总和
avail Mem考虑buff/cache后可用的物理内存
交换空间(Swap)
total总交换空间
free空闲交换空间
used已用交换空间
avail Mem注意:这里的avail Mem与内存占用中的avail Mem意义不同,如果表示Swap的可用空间,则无需此列

下面白色那排扩展

USER进程所有者的用户名
PR优先级(由内核动态调整)
NInice 值(进程优先级)。负值表示高优先级,正值表示低优先级
VIRT虚拟内存使用量(VSZ)
RES常驻内存使用量(RSS)
SHR共享内存大小(kb)
S进程状态(D=不可中断的睡眠,R=运行/可运行,S=睡眠,T=已跟踪/已停止,Z=僵停)
%CPUCPU 时间占用百分比
%MEM使用的物理内存百分比
TIME+使用的 CPU 时间总计(单位:1/100 秒)
COMMAND命令名/命令行
1.2.2.1、实验

当我运行I/O的时候,wa占用

dd if=/dev/zero of=/mnt/a.txt count=19 bs=100M

又恢复成

 1.2.2.2、top 命令全屏操作界面快捷键

默认 3s 刷新一次,按 s 修改刷新时间按空格 :立即刷新。
P:按 CPU 排序
M:按内存排序
T:按时间排序
p: 进程 IP,查看某个进程状态
N 键根据启动时间进行排序
数字键 1:显示每个内核的 CPU 使用率

u/U:指定显示的用户
h:可以获得 top 程序的在线帮助信息
q:键可以正常地退出 top 程序

注:若通过 top 排名工具发现某个进程 CPU 占用率非常高,需要终止该进程的运行,可以在 top 操作界面中按 k 键,然后在列表上方将会出现“PID to signal/kill [default pid = 3180]:” 的提示信息,根据需要输入指定进程的 PID 号并按 Enter 键, 出现“Send pid 输入的能够ID  signal [15/sigterm]”的二次确认的提示信息,然后按Enter 键确认即可终止对应的进程。

 1.2.3、pgrep根据特定条件查询进程pid信息

pgrep  -参数

常用的参数

  • -l:选项可同时输出对应的进程名以及PID
  • -U:选项查询特定用户的进程
  • -t:选项查询在特定终端运行的进程 

1.2.4、pstree命令以树形结构列出进程信息

结合以下常用的参数使用:

  • -p:选项使用时可以同时列出对应的PID号
  • -u:选项可以列出对应的用户名
  • -a:选项可以列出完整的命令信息

执行如下的“pstree -aup”命令可以查看当前系统的进程树,包括各进程对应的PID 号、用户名、完整命令等信息。从输出结果中可以看出,systemd 进程确实是 Linux 操作系统中所有进程的“始祖”。

二、控制进程

2.1、进程的启动方式

手工启动

  • 前台启动:用户输入命令,直接执行程序
  • 后台启动:在命令行尾加入"&"符号

例如,当使   用 cp 命令从光盘中制作镜像文件时,由于需要复制的数据较多,耗时较长,因此可结合“&” 符号将复制操作放到后台运行,以便用户可以继续执行其他命令操作。

输出信息中包括后:台任务序号【1】,pid号 35489

调度启动

在服务器维护工作中,经常需要执行一些比较费时而且较占用资源的任务(如数据备份),这些任务更适合在相对空闲的时候(如夜间)进行。这时就需要用户事先进行调度安排,指定任务运行的时间,当系统到达设定时间时会自动启动并完成指定的任务。调度启动的计划 任务进程均在后台运行,不会占用用户的命令终端。
进程的调度启动可以通过 at、crontab 命令进行设置,其中 at 命令用于设置一次性(如12:15 时重启网络服务)计划任务,crontab 命令用于设置周期性运行(如每周五 17:30 备份数据库)的计划任务。

2.2、进程的前后台调度

2.2.1、挂起当前的进程

当Linux操作系统中的命令正在前台执行时(运行尚未结束),按Ctrl+Z组合键可以将当前进程挂起(调入后台并停止执行),这种操作在需要暂停当前进程并进行其他操作时特别有用。例如,打包usr并且调入后台 ,可以按 Ctrl+Z 组合键将该下载任务调入后台并暂停执行

tar czvf  usr.tar.gz /usr

2.2.2、jobs命令查看处于后台的任务列表

常用的参数

-l:选项可以同时显示该进程对应的PID号

job -l  

查看处于后台的任务列表

2.2.3、fg、bg命令将后台的进程恢复运行

使用 bg(BackGround,后台)命令,可以将后台中暂停执行(如按 Ctrl+Z 组合键挂起)的任务恢复运行,继续在后台执行操作;(注意就不能再停止了)
使用 fg 命令(ForeGround,前台),可以将后台任务重新恢复到前台运行。
除非后台中的任务只有一个,否则 bg 和 fg 命令都需要指定后台进程的任务编号作为参数。

2.3、终止进程执行

当用户在前台执行某个进程时,可以按Ctrl+C组合键强制进行中断(如命令长时间没有响应的情况下)。
中断前台进程的运行后,系统将返回命令行提示符状态等待用户输入新的命令。

当按 Ctrl+C 组合键无法终止程序或者需要结束在其他终端或后台运行的进程时, 可以使用专用的进程终止工具 kill、killall 和 pkill。

2.3.1、使用 kill 命令终止进程

通过 kill 命令终止进程时,需要使用进程的 PID 号作为参数。无特定选项时,kill 命令将给该进程发送终止信号并正常退出运行,若该进程已经无法响应终止信号,则可以结合“-9”    选项强行终止进程。强制终止进程时可能会导致程序运行的部分数据丢失,因此不到不得已时不要轻易使用“-9”选项。(但是一般还是会用
例如,若 SSH 服务的 sshd 进程的 PID 号为 93333,则执行“kill 93333”命令后可以将进程 sshd 终止

2.3.2、使用 pkill 命令终止进程

三、at一次性任务设置

一次性计划任务
在 Linux 操作系统中,除了用户即时执行的命令操作以外,还可以配置在指定的时间、指定的日期执行预先计划的系统管理任务(如定期备份、定期采集监测数据)。CentOS 系统中默认已安装了 at、cronie 软件包,通过 atd 和 crond 这两个系统服务实现一次性、周期性计划任务的功能,并分别通过 at、crontab 命令进行计划任务设置


使用at命令设置的计划任务只在指定的时间点执行一次,前提是对应的系统服务atd必须已经运行。需要注意的是,计划执行任务的时间、日期必须安排在当前系统的时刻之后,   否则将无法正确设置计划任务。
设置一次性计划任务时,在 at 命令行中依次指定计划执行任务的时间、日期作为参数(若只指定时间则表示当天的该时间,若只指定日期则表示该日期的当前时间),确认后将进入带“at>”提示符的任务编辑界面,每行设置一条执行命令,可以依次设置多条语句,最后按 Ctrl+D 组合键提交任务。所设置的命令操作将在计划的时间点被依次执行。

格式

at  [HH:MM]  [yyyy-mm-dd]
任务设置完毕后按Ctrl+D 组合键提交

如果错误,修改用ctrl+删除修改内容

 3.1、实验

以下操作将设置一条计划任务,在当天的 21:30 自动关闭当前系统。


 

3.2、查询计划和删除计划

可以通过 atq 命令进行查询

 用atrm +任务号  删除

四、crontab周期性任务设置

crontab命令
按照预先设置的时间周期 (分钟,小时,天。.....)重复执行用户指定的命令操作,属于周期性计划任务。
/etc/crontab 文件中设置的是维护 Linux 操作系统所需的任务,Linux 操作系统及相关程序在安装时可自动设置,不建议用户手动修改此文件。

该文件中包括设置 Shell 环境、可执行路径等变量的操作,以及每小时、每天、每周、每月需要执行的任务目录。执行如下的“cat /etc/crontab”命令可以查看/etc/crontab 文件的具体内容。


 

4.1、管理crontab计划任务

编辑计划任务
crontab -e【-u用户名】
查看计划任务
crontab -i【u用户名】
删除计划任务
crontab -r【-u用户名】

crontab -u 用户名 #指定XX用户的cron服务
crontab -l #列出当前用户下的cron的详细内容
crontab -u zx -l #列出zx用户下的cron的详细内容
crontab -r #删除所有用户的cron内容,普通用户执行,只删除自己的cron内容
crontab -r -u zx #删除zx用户的cron内容
crontab -e #编辑cron服务 

4.1.1、-e编辑内容格式

50      3       2    1        *       run command
分钟 小时 日期 月份 星期    命令

分时日月周

4.2、时间数值的特殊表示方法

  • *表示该范围内的任意时间
  • 减号“-”:可以表示一个连续的时间范围,如“1-4”表示整数 1、2、3、4。
  • 逗号“,”:可以表示一个间隔的不连续范围,如“3, 4, 6, 8”。
  • 斜杠符号“/”:可以用来指定间隔频率,如在日期字段中的“*/3”表示每隔 3 天。

示例

4.3、实验

普通用户执行“crontab -e”命令时,可以设置自己的计划任务(需要注意命令的执行权限)。
例如,用户 yc666设置一条计划任务:

在每晚上的 18:36 将/etc/passwd 文件的内容复制到宿主目录中,保存为 pwd.txt 文件

因各条计划任务在执行时并不需要用户登录,所以任务配置记录中的命令建议使用绝对路径,以避免因缺少执行路径而无法执行命令的情况。另外,在设置非每分都执行的任务时,    “分钟”字段也应该填写一个具体的时间数值,而不要保留为默认的“*”,否则将会在每分钟执行一次计划任务。

 

在root下可以-u查看其他人计划

 补充

crontab -e:编辑的是当前系统用户作为执行者的的定时任务

conrtab -l:查看当前用户的定时任务

/etc/cronatab:是系统级别,可以包含所有用户的定时任务

其他的一些例子

例如,若要按固定的周期重复完成一些系统管理任务,任务内容如下:

①每天早上 7:50自动开启 sshd 服务,22:50 关闭 sshd 服务;

②每隔五天清空一cron        次 FTP 服务器公共目录/var/ftp/pub 中的数据;

③每周六的 7:30 重新启动系统中的 httpd 服务;

④每周一、周三、周五的下午 17:30,使用 tar 命令自动备份/etc/httpd 目录,则可由 root 用户通过 crontab 设置以下计划任务。

例如,若要按固定的周期重复完成一些系统管理任务,任务内容如下:①每天早上 7:50
自动开启 sshd 服务,22:50 关闭 sshd 服务;②每隔五天清空一cron		次 FTP 服务器公共目录
/var/ftp/pub 中的数据;③每周六的 7:30 重新启动系统中的 httpd 服务;④每周一、周三、周五的下午 17:30,使用 tar 命令自动备份/etc/httpd 目录,则可由 root 用户通过 crontab 设置以下计划任务。


[root@localhost ~]# crontab -e
50 7 * * * /usr/bin/systemctl start sshd.service 
50 22 * * * /usr/bin/systemctl stop sshd.servic 
0 0 */5 * * /usr/bin/rm -rf /var/ftp/pub/*
30 7 * * 6 /usr/bin/systemctl httpd restart
30 17 * * 1,3,5 /usr/bin/tar jcf httpdconf.tar.bz2 /etc/httpd/
*/2 * * * * ls -lh /home/*

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1869776.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Geotools系列说明之入门介绍与坐标系转换说明

Geotools介绍 借用官网的介绍 GeoTools is an open source Java library that provides tools for geospatial data 就是提供java处理地理空间的工具详细内容请参考官网 Geotools环境搭建 我们这里只讨论Geotools在Maven中和Idea的项目实战&#xff0c;至于Geotools的服务端…

Altium Designer软件下载安装「PCB设计软件」安装包资源获取

Altium Designer作为一款集成化的电子产品开发系统&#xff0c;它主要适用于Windows操作系统&#xff0c;为电子设计工程师们提供了一个高效、便捷的工作平台。 在Altium Designer中&#xff0c;原理图设计、电路仿真、PCB绘制编辑、拓扑逻辑自动布线、信号完整性分析和设计输出…

DVWA 靶场 File Inclusion 通关解析

前言 DVWA代表Damn Vulnerable Web Application&#xff0c;是一个用于学习和练习Web应用程序漏洞的开源漏洞应用程序。它被设计成一个易于安装和配置的漏洞应用程序&#xff0c;旨在帮助安全专业人员和爱好者了解和熟悉不同类型的Web应用程序漏洞。 DVWA提供了一系列的漏洞场…

KVB App:集运价格飙升:地缘风险下的投资新机遇

摘要 随着全球地缘政治局势的反复和海运需求的持续高企&#xff0c;集装箱运价在近期不断攀升&#xff0c;吸引了越来越多的投资者。摩根大通的最新报告指出&#xff0c;地缘风险加剧和航运市场需求旺盛使得即期运费可能继续走高。本文将深入分析当前集运市场的情况及其对投资者…

备份和还原

stai和dnta snat&#xff1a;源地址转换 内网---外网 内网ip转换成可以访问外网的ip 内网的多个主机可以使用一个有效的公网ip地址访问外部网络 DNAT&#xff1a;目的地址转发 外部用户&#xff0c;可以通过一个公网地址访问服务内部的私网服务。 私网的ip和公网ip做一个…

SQLite、MySQL、PostgreSQL 3个关系数据库之间优缺点对比

引言 关系数据模型以行和列的表格形式组织数据&#xff0c;在数据库管理工具中占主导地位。今天还有其他数据模型&#xff0c;包括NoSQL和NewSQL&#xff0c;但是关系数据库管理系统&#xff08;RDBMS&#xff09;仍然占主导地位用于存储和管理全球数据。 本文比较了三种实现最…

40岁学习java是否需要报班学习?

在开始前刚好我有一些资料&#xff0c;是我根据网友给的问题精心整理了一份「java的资料从专业入门到高级教程」&#xff0c; 点个关注在评论区回复“666”之后私信回复“666”&#xff0c;全部无偿共享给大家&#xff01;&#xff01;&#xff01;应该不需要。各种公开免费的…

新能源行业必会基础知识-----电力市场概论笔记-----绪论

新能源行业知识体系-------主目录-----持续更新(进不去说明我没写完)&#xff1a;https://blog.csdn.net/grd_java/article/details/139946830 目录 1. 电力市场的定义2. 对传统电力系统理论的挑战 1. 电力市场的定义 1. 我国电力市场的进程 我国新一轮电力体制改革的5大亮点&…

摒弃反模式:使用Kotlin委托优化Android BaseActivity

摒弃反模式&#xff1a;使用Kotlin委托优化Android BaseActivity 在Android开发中&#xff0c;许多开发者习惯于创建名为“BaseActivity”或“BaseFragment”的基类&#xff0c;以便在所有Activity或Fragment中共享一些通用行为。这种方法乍一看似乎是个好主意&#xff0c;但实…

C语言实现KMP算法

#include<stdio.h> #include<string.h> #include<stdlib.h>void getNextArray(char * sub_str, int sub_str_length, int * next_array); int kmpSearch(char * sub_str, char * main_str);int main(void) {// 1 声明用于算法处理的字符串char origin_str[] …

整数智能与上海数据交易所携手,共筑数据要素市场新篇章

近期&#xff0c;整数智能荣获上海数据交易所“数据治理服务商”证书&#xff0c;正式加入上海数据交易所数商生态&#xff0c;成为上海数据交易所官方认证的数据治理服务商。 在数字经济的浪潮中&#xff0c;上海数据交易所一直扮演着引领者和推动者的角色。紧扣建设国家级…

CID引流电商:传统电商破局的新动力

摘要&#xff1a;CID引流电商为传统电商带来破局新机遇&#xff0c;通过跨平台引流、精准定位和高效转化&#xff0c;解决了流量获取难、成本高的问题&#xff0c;提升了销售业绩和市场竞争力。CID引流电商助力传统电商在激烈竞争中保持领先&#xff0c;推动行业持续发展。 随…

气象相关图表制作-字体图标、图片、折线的堆叠

开发工作中有个需要展示气温&#xff08;折线&#xff09;、天气&#xff08;图片&#xff09;、风羽&#xff08;字体图标&#xff09;的图表展示需求&#xff0c;之前用过highcharts的关于类似的chart&#xff0c;里面的风雨用的是自带的图片&#xff0c;但是现在要求风羽需要…

2024年Apache DolphinScheduler 社区开源之夏活动中选公示

各位社区伙伴们&#xff0c;经过严格的评审和筛选&#xff0c;我们非常高兴地向大家公布Apache DolphinScheduler 社区在本年度的开源之夏活动中&#xff0c;中选的学生和导师名单&#xff01; 序号项目名称中选学生导师1增加Raft注册插件胡世豪朱学通2k8s任务功能扩展戴明辰伏…

【原创工具】孔夫子旧书网店铺图书采集工具1.0

目录 1 概述2 演示效果2.1 图文2.2视频3 核心逻辑3.1 导出数据4 附件下载5 使用方式1 概述 爬取孔夫子旧书网的店铺图书信息(条码、书名、售价、定价),支持导出和调速(默认速度5条/s)、支持识别该店铺最新上架图书和总计图书数量,采集结果和官网排序一致,可以对比测试 2…

启动台出现agent app的解决方法~

启动台出现agent app的解决方法&#xff5e; 如果用了战网&#xff0c;Battle.net&#xff0c;在卸载后有一个agent app&#xff0c;启动台删除不掉&#xff0c;应用程序里面没有&#xff0c;怎么办呢&#xff1f; 解决方法&#xff1a;找到这个app所在位置&#xff0c;可以通…

STM32将外部SDRAM空间作为系统堆(Heap)空间

概述 stm32可以外扩很大的sram&#xff0c;常见外部sram的初始化函数一般是c语言写的&#xff0c;默认写在main函数里面。stm32初始化首先进入汇编代码startup_stm32f429xx.s&#xff0c;在汇编代码中Reset_Handler&#xff08;复位中断服务程序&#xff09;里面先调用了Syste…

ABAP开发:动态Open SQL编程案例介绍

动态Open SQL是Open SQL的扩展。它不是要求整个SQL语句都是动态指定的。通过熟悉的静态ABAP编码表达静态已知的部分&#xff0c;动态元素的部分通过动态标记指定。动态片段不明确包含在ABAP源代码中&#xff0c;而是源代码包含一个ABAP变量&#xff0c;用括号括起来作为占位符。…

Linux—进程与计划管理

目录 一、程序 二、进程 1、什么是进程 2、进程的特点 3、进程、线程、携程 3.1、进程 3.2、线程 3.3、携程 三、查看进程信息 1、ps -aux 2、ps -elf 3、top ​3.2、输出内容详解 3.2.1、输出第一部分解释 3.2.2、输出第二部分解释 4、pgrep 5、pstree 四、进…

从CVPR 2024看域适应、域泛化最新研究进展

域适应和域泛化一直以来都是各大顶会的热门研究方向。 域适应指&#xff1a;当我们在源域上训练的模型需要在目标域应用时&#xff0c;如果两域数据分布差异太大&#xff0c;模型性能就有可能降低。这时可以利用目标域的无标签数据&#xff0c;通过设计特定方法减小域间差异&a…