Linux系统:进程和计划任务管理

目录

一、程序

二、进程

1、什么是进程

1.1 进程的概念

1.2 进程的特征

1.3 进程、线程和协程

2、进程状态

3、进程的类型

4、进程使用内存出现的问题

三、进程管理相关命令

1、ps(process state)

1.1 用法

1.2 分析ps命令输出的内容

2、top

2.1 用法

2.2 分析top命令输出的内容

2.2.1 top 命令输出的第一部分

2.2.2 top 命令输出的第二部分

3、pgrep

4、pidof

5、pstree

6、lsof(list opened files )

7、vmstat

8、free

9、iostat

10、iotop

11、uptime

12、mpstat

13、pmap

14、webmin

​编辑

15、dstat 

 四、进程管理

1、前台运行和后台运行

2、前台运行和后台运行相互切换的命令

2.1 &

2.2 jobs

2.3 fg

2.4 ctrl+z

2.5 bg

3、结束进程

3.1 kill

3.2 killall

3.3 pkill

五、计划任务

1、at

2、crontab

六、总结


一、程序

  • 程序是一系列指令的集合,用于在计算机或其他设备上执行特定的任务或操作
  • 它是以特定的编程语言编写的,可以告诉计算机如何进行计算、处理数据、执行操作或解决问题
  • 通过编写程序,人们可以利用计算机的处理能力来完成各种任务,例如编写应用程序、设计网站、进行数据分析等
  • 程序是计算机软件的基本组成部分,它们被编译或解释后可以在计算机上运行

二、进程

1、什么是进程

1.1 进程的概念

进程(Process)是计算机中正在运行的程序的实例,是被载入内存的一个指令集合,是资源分配和管理的基本单位。每个进程都有自己的内存空间、代码和数据,并且可以独立地执行

  • 进程ID(Process ID,PID)号码被用来标记各个进程

  • UID、GID语境决定对文件系统的存取和访问权限

  • 通常从执行进程的用户来继承

  • 存在生命周期

  • 都由其父进程创建

1.2 进程的特征
特征说明
动态性进程是程序的一次执行过程,是临时的,有生命期的,是动态产生,动态消亡的
并发性任何进程都可以同其他进程一起并发执行
独立性进程是系统进行资源分配和调度的一个独立单位
结构性进程由程序、数据和进程控制块三部分组成
1.3 进程、线程和协程

①进程(Process)

  • 进程是操作系统中的一个独立执行单位,它拥有自己的内存空间、代码和数据
  • 每个进程都是独立运行的,它们之间相互隔离,无法直接访问对方的内存空间
  • 进程之间通过进程间通信(IPC)来进行数据交换和协调
  • 进程具有较高的安全性和稳定性,但创建和切换进程的开销较大

②线程(Thread):

  • 线程是进程内的一个独立执行单元,它共享进程的内存空间和资源
  • 多个线程可以同时执行不同的任务,它们可以访问相同的变量和数据
  • 线程之间的切换开销较小,适合处理需要并发执行的任务
  • 线程之间的通信相对容易,但需要考虑线程安全的问题

③协程(Coroutine):

  • 协程是一种轻量级的线程,它由程序控制自行调度,而不是由操作系统调度。
  • 协程可以在同一个线程内实现并发执行,通过协程的切换来实现任务的切换。
  • 协程之间的切换开销很小,因此可以实现高效的并发编程。
  • 协程通常采用非抢占式的调度方式,需要显式的让出执行权给其他协程
区别
进程线程协程
操作系统分配资源的基本单位操作系统调度任务的基本单位程序控制自行调度的基本单位
进程之间相互隔离线程共享进程的资源协程在同一个线程内实现并发执行
进程和线程的切换开销较大,适用于需要较高安全性和稳定性的任务协程的切换开销较小,适用于高效的并发编程

 拓展:

如何确定一个程序是多线程还是单线程?
1. pstree  -p |  grep  程序名              //查看当前该程序的pid号

2. grep  -i  threads  /proc/进程的PID/status       //查看当前该程序的线程

或者   prtstat    进程pid号                         //查看当前程序的进程信息

2、进程状态

  • 进程状态图总览:

  • 新建(New):当一个程序被创建时,它处于新建状态。在这个阶段,操作系统为该程序分配必要的资源,并为其创建一个进程控制块(PCB)。
  • 就绪(Ready):在就绪状态下,进程已经准备好执行,但由于CPU资源有限,操作系统尚未选择该进程来执行。在多任务环境中,可能有多个进程处于就绪状态。
  • 运行(Running):当操作系统选择一个就绪进程并将其分配给CPU时,该进程进入运行状态。在运行状态下,进程的指令被执行。
  • 阻塞(Blocked):在某些情况下,进程需要等待某些事件的发生,例如等待用户输入、等待I/O操作完成等。这时,进程会进入阻塞状态,并暂时释放CPU资源。
  • 终止(Terminated):进程在完成其任务后或由于某种原因被终止时,进程进入终止状态。在这个状态下,进程的资源被释放,进程控制块被销毁。

3、进程的类型

  • 前台进程:前台进程是用户当前正在与之交互的进程。它们通常在屏幕上显示输出,并等待用户输入。例如,运行一个应用程序或编辑文档时,相关的进程将被认为是前台进程
  • 后台进程:后台进程是在后台运行的进程,不会直接与用户交互。它们通常在后台执行任务,而不会干扰用户的当前工作。例如,下载文件或执行系统维护任务的进程可以被认为是后台进程
  • 守护进程:守护进程是在操作系统启动时就开始运行的进程,它们在后台运行,并且没有与之直接交互的用户界面。它们通常用于执行系统级任务,如服务监控、日志记录等。守护进程通常会在后台持续运行,直到系统关闭或显式地被停止
  • 父进程和子进程:父进程是创建其他进程的进程,而子进程是由父进程创建的新进程。子进程可以继承父进程的一些属性和资源,并可以独立地执行自己的任务。这种进程之间的关系形成了进程树
  • 前置进程和非前置进程:前置进程是可以被操作系统中断并停止执行的进程,而非前置进程则不会被中断。前置进程通常用于多任务操作系统中,以便操作系统可以在需要时立即切换到其他进程。
  • 交互式进程和批处理进程:交互式进程是需要与用户交互的进程,而批处理进程是按照预定的命令序列自动执行的进程。交互式进程通常需要在用户输入时做出响应,而批处理进程则按照预定义的规则进行处理。
  • 并发进程和并行进程:并发进程是指多个进程在一段时间内同时存在,但不一定同时执行。并行进程是指多个进程在同一时间内同时执行。并发进程可以通过时间片轮转等方式交替执行,而并行进程则需要多个处理器或多核处理器来同时执行

4、进程使用内存出现的问题

①内存泄漏:Memory Leak

指程序中用malloc或new申请了一块内存,但是没有用free或delete将内存释放,导致这块内存一直处于占用状态

②内存溢出:Memory Overflow

指程序申请了10M的空间,但是在这个空间写入10M以上字节的数据,就是溢出

③内存不足:OOM(Out Of Memory )

这种情况在java程序中比较常见。系统会选一个进程将之杀死,在日志messages中看到类似下面的提示

Jul 10 10:20:30 kernel: Out of memory: Kill process 9527 (java) score 88 or sacrifice child

//当JVM因为没有足够的内存来为对象分配空间并且垃圾回收器也已经没有空间可回收时,就会抛出这个error,因为这个问题已经严重到不足以被应用处理

出现以上问题的原因:

  • 给应用分配内存太少:比如虚拟机本身可使用的内存(一般通过启动时的VM参数指定)太少
  • 应用用的太多,并且用完没释放,浪费了,此时就会造成内存泄露或者内存溢出

使用的解决办法:

  • 限制java进程的max heap,并且降低java程序的worker数量,从而降低内存使用
  • 给系统增加swap空间

三、进程管理相关命令

1、ps(process state)

1.1 用法

显示当前运行进程的信息

选项说明

BSD选项
a显示当前终端下的所有进程信息,包括其他用户的进程。与“x”选项结合时将示系统中所有的进程信息
u使用以用户为主的格式输出进程信息
x显示当前用户在所有终端下的进程信息
k倒序显示进程信息
UNIX选项-e显示系统内的所有进程信息
-l使用长(Long)格式显示进程信息
-f使用完整的(Full)格式显示进程信息
GNU选项--help帮助信息
查看静态的进程统计信息:
ps aux          //查看系统中所有的进程
ps -le         //查看系统中所有的进程,而且还能看到进程的父进程的PID和进程优先级
ps -l           //只能查看当前Shell产生的进程
ps axo pid,cmd,%mem,%cpu          //查看进程的特定属性
ps aux k -%cpu                    //按CPU利用率倒序排序
ps aux k -%mem                    //按占用内存最多倒序排序
1.2 分析ps命令输出的内容

 ps aux 命令的输出属性详解:

表头说明
USER该进程是由哪个用户产生的
PID进程的pid号
%CPU该进程占用CPU资源的百分比,占用的百分比越高,进程越耗费资源
%MEM该进程占用物理内存的百分比,占用的百分比越高,进程越耗费资源
VSZ该进程占用虚拟内存的大小,单位为 KB
RSS该进程占用实际物理内存的大小,单位为 KB
TTY该进程是在哪个终端运行的。?代表和终端无关,系统进程;tty1 ~ tty7 代表本地控制台终端;tty7 是图形终端;tty1~tty6 是本地的字符界面终端;pts/0 ~ 255 代表虚拟终端,一般是远程连接的终端,第一个远程连接占用 pts/0,第二个远程连接占用 pts/1,依次増长
STAT

进程状态。常见的状态有以下几种:

-D:不可被唤醒的睡眠状态,通常用于 I/O 情况

-R:该进程正在运行

-S:该进程处于睡眠状态,可被唤醒

-T:停止状态,可能是在后台暂停或进程处于除错状态

-W:内存交互状态

-X:死掉的进程

-Z:僵尸进程。进程已经中止,但是还是占用硬件资源

-<:高优先级

-N:低优先级

-L:被锁入内存

-s:包含子进程

-l:多线程

-+:前台进程

START该进程的启动时间
TIME该进程占用 CPU 的运算时间,注意不是系统时间
COMMAND产生此进程的命令名

 ps -ef 命令的输出属性详解:

表头说明
F

进程标志,说明进程的权限。

常见的标志有两个      1:进程可以被复制,但是不能被执行      4:进程使用超级用户权限

S进程状态,具体的状态和"psaux"命令中的 STAT 状态一致
UID运行此进程的用户的 ID
PID进程的ID
PPID父进程的ID
C该进程的 CPU 使用率,单位是百分比
PRI

进程的优先级,数值越小,该进程的优先级越高,越早被 CPU 执行

系统定义不可以人为修改

NI

进程的优先级,数值越小,该进程越早被执行

可以人为修改(-20~19)

ADDR该进程在内存的哪个位置
SZ该进程占用多大内存
WCHAN

该进程是否运行

"-"代表正在运行

TTY该进程由哪个终端产生
TIME该进程占用 CPU 的运算时间,注意不是系统时间
CMD产生此进程的命令名

2、top

2.1 用法

用于实时监视系统运行状态的常用工具,提供了对系统各种资源利用情况的实时动态展示,包括 CPU 使用率、内存占用、进程信息等

选项说明
-d 秒数指定 top 命令每隔几秒更新。默认是 3 秒

-b

使用批处理模式输出。一般和"-n"选项合用,用于把 top 命令重定向到文件中
-n 次数指定 top 命令执行的次数
-p 进程pid仅查看指定pid的进程
-s使 top 命令在安全模式中运行,避免在交互模式中出现错误
-u 用户名只监听某个用户的进程

在 top 命令的显示窗口中,还可以使用如下按键,进行一下交互操作:

操作键说明
? 或 h显示交互模式的帮助
c按照 CPU 的使用率排序,默认就是此选项
M按照内存的使用率排序
N按照 PID 排序
T按照 CPU 的累积运算时间排序,也就是按照 TIME+ 项排序
k按照 PID 给予某个进程一个信号。一般用于中止某个进程,信号 9 是强制中止的信号
r按照 PID 给某个进程重设优先级(Nice)值
q退出 top 命令
2.2 分析top命令输出的内容

top 命令的输出内容是动态的,默认每隔 3 秒刷新一次。命令的输出主要分为两部分:

  • 第一部分是前五行,显示的是整个系统的资源使用状况,我们就是通过这些输出来判断服务器的资源使用状态的
  • 第二部分从第六行开始,显示的是系统中进程的信息

2.2.1 top 命令输出的第一部分

第一行为任务队列信息,具体内容如表所示:

内 容说 明
19:24:57系统当前时间
up 12 min系统的运行时间,本机已运行了12min
1 users当前登录了一个用户
load average: 0.00, 0.01,0.04系统在之前 1 分钟、5 分钟、15 分钟的平均负载。如果 CPU 是单核的,则这个数值超过 1 就是高负载:如果 CPU 是四核的,则这个数值超过 4 就是高负载 (这个平均负载完全是依据个人经验来进行判断的,一般认为不应该超过服务器 CPU 的核数)

第二行为进程信息,具体内容如表所示:

内 容说 明
Tasks: 161 total系统中的进程总数
1 running正在运行的进程数
160 sleeping睡眠的进程数
0 stopped正在停止的进程数
0 zombie僵尸进程数。如果不是 0,则需要手工检查僵尸进程

第三行为 CPU 信息,具体内容如表所示:

内 容说 明
Cpu(s): 0.0 %us用户模式占用的 CPU 百分比 个人用户开启的进程占用的 cpu 率
0.1%sy系统模式占用的 CPU 百分比
0.0%ni改变过优先级的用户进程占用的 CPU 百分比
99.9%id空闲 CPU 占用的 CPU 百分比
0.0%wa等待输入/输出的进程占用的 CPU 百分比 
0.0%hi硬中断请求服务占用的 CPU 百分比
0.0%si软中断请求服务占用的 CPU 百分比
0.0%stst(steal time)意为虚拟程序占用 cpu 时间百分比,就是当有虚拟机时,虚拟CPU等待实际CPU的时间百分比

第四行为物理内存信息,具体内容如表所示:

内 容说 明
Mem: 1867048k total物理内存的总量,单位为KB
1216592 free空闲的物理内存数量
281812k used己经使用的物理内存数量
368644k buffer作为缓冲的内存数量

第五行为交换分区(swap)信息,具体内容如表所示:

内 容说 明
Swap: 4194300k total交换分区(虚拟内存)的总大小
0k used已经使用的交换分区的大小
419300k free空闲交换分区的大小
1392216k cache作为缓存的交换分区的大小

注:

通过 top 命令的第一部分就可以判断服务器的健康状态。如果 1 分钟、5 分钟、15 分钟的平均负载高于 1,则证明系统压力较大。如果 CPU 的使用率过高或空闲率过低,则证明系统压力较大。如果物理内存的空闲内存过小,则也证明系统压力较大

2.2.2 top 命令输出的第二部分

主要是系统进程信息

表头说明
PID进程的 ID
USER该进程所属的用户
PR优先级,数值越小优先级越高
NI优先级,数值越小、优先级越高
VIRT该进程使用的虚拟内存的大小,单位为 KB
RES该进程使用的物理内存的大小,单位为 KB
SHR共享内存大小,单位为 KB
S进程状态
%CPU该进程占用 CPU 的百分比
%MEM该进程占用内存的百分比
TIME+该进程共占用的 CPU 时间
COMMAND进程的命令名

3、pgrep

根据进程名或者其他属性来查找进程的 PID

选项说明

-U

指定用户
-l显示进程名
-a显示完整格式的进程名
-P pid

显示指定进程的子进程

pgrep -l "log"         //显示以“log”为名的进程pid
pgrep -l -U dh         //查看指定用户为dh的进程pid

4、pidof

用于查找指定进程的进程pid,它可以接受一个或多个进程名作为参数,并返回匹配进程名的所有进程的 pid

通式:   pidof   进程名1   进程名2

5、pstree

 用于以树状图的形式显示进程之间的父子关系。它将按照进程的层次结构展示进程及其子进程,使得用户可以清晰地了解进程之间的关系

选项说明
-a 显示启动每个进程对应的完整指令,包括启动进程的路径、参数等
-p显示PID
-T不显示线程thread,默认显示线程
-u显示用户切换
-H pid高亮显示指定进程及其前辈进程
pstree -p |grep nginx          //过滤nginx进程的pid号
pstree dh                      //查看用户dh的进程
pstree 2382                    //查看pid号为2382的进程

  6、lsof(list opened files )

用于显示系统中已经打开的文件,以及这些文件被哪些进程所使用。它可以帮助用户查看文件被哪些进程打开、网络连接情况等

选项说明
-c  字符串只列出以字符串开头的进程打开的文件
+d  目录名列出某个目录中所有被进程调用的文件
-u  用户名只列出某个用户的进程打开的文件
-p  pid列出某个 PID 进程打开的文件
-t仅显示进程ID
-i如lsof  -i   :80  查看哪些程序占用80端口

 7、vmstat

用于显示系统的虚拟内存统计信息,包括进程、内存、交换分区、I/O 等方面的性能数据。它可以帮助用户实时监视系统的负载情况,以及发现潜在的性能问题

选项说明
-n指定输出间隔和次数,如 vmstat 2 5 表示每隔 2 秒输出一次,共输出 5 次
-a显示活跃和非活跃内存的状态
-s显示内存的统计摘要信息
-p  分区设备文件名查看硬盘分区的读写情况
-d列出硬盘有关读写总量的统计表

分析vmstat命令输出的内容:

字段说明
procs进程信息字段: -r:等待运行的进程数,数量越大,系统越繁忙。 -b:不可被唤醒的进程数量,数量越大,系统越繁忙。
memory内存信息字段: -swpd:虚拟内存的使用情况,单位为 KB。 -free:空闲的内存容量,单位为 KB。-buff:缓冲的内存容量,单位为 KB。-cache:缓存的内存容量,单位为 KB。
swap交换分区信息字段: -si:从磁盘中交换到内存中数据的数量,单位为 KB。 -so:从内存中交换到磁盘中数据的数量,单位为 KB。这两个数越大,表明数据需要经常在磁盘和内存之间进行交换,系统性能越差。
io磁盘读/写信息字段: -bi:从块设备中读入的数据的总量,单位是块。 -bo:写到块设备的数据的总量,单位是块。这两个数越大,代表系统的 I/O 越繁忙。
system系统信息字段: -in:每秒被中断的进程次数。 -cs:每秒进行的事件切换次数。这两个数越大,代表系统与接口设备的通信越繁忙。
cpuCPU信息字段: -us:非内核进程消耗 CPU 运算时间的百分比。 -sy:内核进程消耗 CPU 运算时间的百分比。 -id:空闲 CPU 的百分比。 -wa:等待 I/O 所消耗的 CPU 百分比。 -st:被虚拟机所盗用的 CPU 百分比

注:

vmstat 命令的输出结果中,我们应该重点注意 procs 项中 r 列的值,以及 CPU 项中 us 列、sy 列和 id 列的值 

8、free

用于显示系统内存的使用情况,包括物理内存、交换空间和操作系统内核缓冲区的信息

选项说明
-h以更易读的单位(如 KB、MB、GB)显示内存使用情况
-s 时间指定 free 命令的刷新间隔
-b以字节为单位显示内存使用情况
-k以千字节为单位显示内存使用情况
-m以兆字节为单位显示内存使用情况
-g 以吉字节为单位显示内存使用情况

拓展:

一台服务器正常使用但使用一周后开机非常卡顿

答:内存缓存太多,需要及时清理缓存,或者内存不足,需要添加内存条

echo 3 > /proc/sys/vm/drop_caches         //清除缓存

9、iostat

用于显示 CPU 使用情况和设备(磁盘、终端、网络文件系统等)的输入/输出统计数据。它能够帮助用户监视系统的磁盘活动和 CPU 使用情况,以便及时发现系统性能问题

选项说明
-c只显示CPU行
-d显示设备〈磁盘)使用状态
-k以千字节为为单位显示输出
-t在输出中包括时间戳
-x在输出中包括扩展的磁盘指标

10、iotop

用于显示系统中磁盘 I/O 活动情况,并能够实时监视各个进程的磁盘 I/O 使用情况,类似于 top 命令对 CPU 使用情况的监视。这使得用户可以快速了解哪些进程正在对磁盘进行读取和写入操作

选项说明

-o

只显示有磁盘 I/O 活动的进程
-b以批处理模式运,适合脚本使用
-n指定刷新间隔和次数,如 iotop -n 5 表示刷新 5 次后退出

iftop  -ni  ens33      //监控网络流量

11、uptime

用于显示系统的运行时间以及平均负载情况。它能够帮助用户了解系统的活跃时间,以及在最近 1、5 和 15 分钟内的平均负载情况

 12、mpstat

用于显示每个 CPU 的性能统计信息,包括平均负载、用户空间和系统空间的 CPU 时间比例等。这对于分析系统的 CPU 性能以及发现可能存在的性能瓶颈非常有帮助

选项说明

-P

后面可以跟一个 CPU 编号,表示只显示指定 CPU 的统计信息
-u显示 CPU 使用率的详细信息
-I显示中断的统计信息

13、pmap

用于显示进程的内存映射信息。它可以显示进程使用的内存区域的详细信息,包括内存映射的起始地址、权限、偏移量、设备、inode

pmap  选项  进程的pid
选项说明
-x以十六进制的形式显示内存地址
-d显示调试信息,包括共享库、符号表等
-q简化模式,只显示每个内存区域的起始地址和大小
-p显示内存区域所属的共享库或文件路径
-X以十六进制的形式显示内存权限标志
-h以更易读的单位(如 KB、MB、GB)显示内存大小
-L显示线程的内存映射信息

14、webmin

webmin是一个基于Web界面的系统管理工具,提供了一个直观的图形用户界面,使系统管理员能够通过浏览器远程管理系统。

Webmin可以用来配置和管理各种系统组件和服务,例如用户帐户、磁盘配额、文件共享、防火墙、网络设置等等。

wget https://prdownloads.sourceforge.net/webadmin/webmin-1.955-1.noarch.rpm
//从官网上下载安装包
yum -y install webmin-1.955-1.noarch.rpm       //下载webmin工具
service webmin start           //开启webmin程序服务
systemctl stop firewalld       //关闭防火墙
setenforce 0                   //临时关闭防护https://IP地址:10000/         //从浏览器远程管理Linux

 输入Linux账户和密码后可登录到webmin,可远程管理系统

15、dstat 

dstat是一个开源的系统性能监控工具,用于收集和报告有关系统资源使用情况的数据。它可以提供即时的系统性能统计,涵盖各个方面,如CPU利用率、内存使用情况、磁盘活动、网络吞吐量等。dstat以文本形式输出数据,可以通过在终端中运行命令或将输出保存到文件中进行查看和分析

 四、进程管理

1、前台运行和后台运行

前台运行(Foreground)指的是进程在用户界面中可见并与用户进行交互的执行方式。当进程在前台运行时,它会占据屏幕,并且用户的命令输入和程序输出都会在用户界面中显示。前台运行的进程通常需要用户的输入或响应,因此它们会阻塞用户界面,直到特定操作完成或用户交互完成

后台运行(Background)指的是进程在后台执行而不占据用户界面或阻塞用户输入的方式。后台运行的进程不会直接与用户进行交互,它们在后台默默地执行任务。用户可以继续在用户界面中进行其他操作,而后台进程会在后台继续执行

2、前台运行和后台运行相互切换的命令

2.1 &

特殊字符“&”,表示把前台运行的命令放入后台执行

2.2 jobs

查看后台任务列表

2.3 fg

调出后台任务到前台执行

2.4 ctrl+z

把任务再调回后台,但该任务会停止运行

2.5 bg

可以从新开始后台停止的服务

2.6 并行执行任务

案例:

执行ping命令,需要ping 172.16.12网段的所有ip地址,并将其转入后台执行

编写test.sh脚本:#!/bin/bash
for i in {1..254}
do
{
ping  -c1  -w2 172.16.12.${i} &>/dev/null && echo "$i is online" >> /opt/online || echo "$i is offline" >> /opt/offline
}&
done

3、结束进程

3.1 kill

kill命令用于终止正在运行的进程。它发送一个信号给指定的进程,告诉进程如何处理这个信号

kill  信号  进程PID号
信号编号信号名说明
0EXIT程序退出时收到该信息
1HUP挂掉电话线或终端连接的挂起信号,这个信号也会造成某些进程在没有终止的情况下重新初始化
2INT表示结束进程,但并不是强制性的,常用的 "Ctrl+C" 组合键发出就是一个 kill -2 的信号
3QUIT退出
9KILL杀死进程,即强制结束进程
11SEGV段错误
15TERM正常结束进程,是 kill 命令的默认信号

注:

  • 对于非特权用户,只能终止自己拥有的进程
  • kill命令只能识别进程pid号,不能识别进程名
  • 使用kill命令时需要小心,因为误操作可能导致数据丢失或系统不稳定
3.2 killall

用于终止指定名称的进程。它会发送一个信号给所有与指定名称匹配的进程,从而终止这些进程

killall  选项   信号   进程名
选项说明

-i

在终止每个进程之前进行交互式确认
-e 只终止完全匹配的进程名
-g向进程组发送信号
-I忽略进程名的大小写;

注:

  • 使用killall命令时需要谨慎,因为它会终止所有匹配的进程,可能导致意外的结果
  • 在使用killall命令时最好明确指定进程名,以避免意外终止错误的进程
3.3 pkill

用于根据进程名称终止进程。它会发送一个信号给与指定名称匹配的进程,从而终止这些进程

pkill   信号  进程名
选项说明

-signal 或 -s signal

指定要发送的信号
-u username 或 --euid username根据用户名终止进程
-f 或 --full根据完整命令行终止进程

 注:

  • 使用pkill命令时需要小心,因为它会终止所有匹配的进程,可能导致意外的结果
  • 在使用pkill命令时最好明确指定进程名或其他选项,以避免意外终止错误的进程

五、计划任务

1、at

at命令用于在将来的某个时间执行一次性的任务。用户可以使用at命令指定一个时间来执行某个命令或脚本,该任务将在指定的时间执行一次,然后退出

at  选项  时间
格式用法
HH:MM比如 04:00 AM。如果时间已过,则它会在第二天的同一时间执行
Midnight(midnight)代表 12:00 AM(也就是 00:00)
Noon(noon)代表 12:00 PM(相当于 12:00)
Teatime(teatime)下午茶代表 4:00 PM(相当于 16:00)
英文月名 日期 年份比如 January 15 2018 表示 2018 年 1 月 15 号,年份可有可无
MMDDYY、MM/DD/YY、MM.DD.YY比如 011518 表示 2018 年 1 月 15 号
now+时间以 minutes、hours、days 或 weeks 为单位,例如 now+5 days 表示命令在 5 天之后的此时此刻执行
atq           //查看任务列表

atrm 任务序列号             //删除任务

注:

  • 如果系统中有 /etc/at.allow 文件,那么只有写入 /etc/at.allow 文件(白名单)中的用户可以使用 at 命令,其他用户不能使用 at 命令
  • 如果系统中没有 /etc/at.allow 文件,只有 /etc/at.deny 文件,那么写入 /etc/at.deny 文件(黑名单)中的用户不能使用 at 命令,其他用户可以使用 at 命令。不过这个文件对 root 用户不生效
  • 如果系统中这两个文件都不存在,那么只有 root 用户可以使用 at 命令

 2、crontab

用于在预定时间执行任务的命令。它允许用户创建、编辑、显示和删除定期运行的任务(也称为 cron 作业)

基本语法:  crontab  选项
选项功能
-e编辑某个用户的 crontab 文件内容。如果不指定用户,则表示编辑当前用户的 crontab 文件
-l显示某用户的 crontab 文件内容,如果不指定用户,则表示显示当前用户的 crontab 文件内容
-r从 /var/spool/cron 删除某用户的 crontab 文件,如果不指定用户,则默认删除当前用户的 crontab 文件
-u user用来设定某个用户的 crontab 服务,例如 "-u demo" 表示设备 demo 用户的 crontab 服务,此选项一般有 root 用户来运行。
-i在删除用户的 crontab 文件时,给确认提示
crontab文件格式:  *   *   *   *   *   command
说明
第一个 *指定分钟(0 ~ 59)
第二个 *指定小时(0 ~ 23)
第三个 *指定月份中的某一天(1 ~ 31)
第四个 *指定月份(1 ~ 12)
第五个 *指定星期中的某一天(0 ~ 6,0 代表星期日)
command指定要执行的命令或脚本
特殊符号说明
*(星号)表示该范围内的任意时间
,(逗号)表示间隔的多个不连续时间点
-(中杠)表示一个连续的时间范围
/(正斜线)指定间隔的时间频率,代表每隔多久执行一次

如:

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

实例:

要求:每两分钟执行将/etc/passwd文件复制到/opt下

crontab  -e             //编辑cron任务计划文件内容:
*/2 * * * * /usr/bin/cp  /etc/passwd  /opt         
或者
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin    
//当cp命令不写绝对路径时需要添加这一行
*/2 * * * * cp  /etc/passwd  /optcrontab -l              //列出当前用户的cron表
crontab  -r             //删除当前用户的cron表

 

注:

  • 6 个选项都不能为空,必须填写。如果不确定,则使用“*”代表任意时间

  • crontab 定时任务的最小有效时间是分钟,最大有效时间是月

  • 在定义时间时,日期和星期最好不要在一条定时任务中出现,因为它们都以天为单位,非常容易让管理员混淆

  • 在定时任务中,不管是直接写命令,还是在脚本中写命令,最好都使用绝对路径。有时使用相对路径的命令会报错

拓展:

*/2 * * * * /usr/bin/touch /data/`date +\%F`
*/2 * * * * /usr/bin/touch /data/`date +%F`

//上下两行文件格式中,上面那行可以被执行,但下面那行不能被执行

原因:上下两行的区别是上面那行在“%”前添加了转义符“\”

cron任务中不建议使用%,它有特殊用途,它表示换行的特殊意义,且第一个%后的所有字符串会被将成当作命令的标准输入,如果在命令中要使用%,则需要用 \ 转义
注意:将%放置于单引号中是不支持的

六、总结

五大性能:

  • CPU:top、w、vmstat
  • 内存:free、top、vmstat
  • 磁盘剩余:df
  • 硬盘读写性能:iostat
  • 网络带宽:iftop

如何优化系统:

  • 关闭不必要的开机自启动程序
  • 禁止使用超级管理员用户
  • 使用国内的yum源
  • 内核调优:开启路由转发功能、增加tcp链接数
  • 关闭核心防护selinux

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

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

相关文章

LLM 中的长文本问题

近期,随着大模型技术的发展,长文本问题逐渐成为热门且关键的问题,不妨简单梳理一下近期出现的典型的长文本模型: 10 月上旬,Moonshot AI 的 Kimi Chat 问世,这是首个支持 20 万汉字输入的智能助手产品; 10 月下旬,百川智能发布 Baichuan2-192K 长窗口大模型,相当于一次…

江苏事业单位计算机岗复习备考经验(2023年)

一、考情分析&#xff1a;根据历年考试分析统计&#xff0c;我们江苏事业单位计算机岗考试题型为前百分之四十的行测和时政加上后百分之六十的计算机专业知识&#xff1b;其中前百分之四十为单项选择题&#xff0c;后面的计算机专业知识为单选题、多选题、简答题和实务题。由于…

ssrf之gopher协议的使用和配置,以及需要注意的细节

gopher协议 目录 gopher协议 &#xff08;1&#xff09;安装一个cn &#xff08;2&#xff09;使用Gopher协议发送一个请求&#xff0c;环境为&#xff1a;nc起一个监听&#xff0c;curl发送gopher请求 &#xff08;3&#xff09;使用curl发送http请求&#xff0c;命令为 …

黑马程序员Java项目实战《瑞吉外卖》,轻松掌握springboot + mybatis plus开发核心技术的真java实战项目——第二部分

黑马程序员Java项目实战《瑞吉外卖》&#xff0c;轻松掌握springboot mybatis plus开发核心技术的真java实战项目——第二部分 1.员工管理模块1.1 完善登陆功能1.2 新增员工1.2.1 全局异常捕获 1.3 员工信息分页查询1.4 启用/禁用员工账号1.4.1 使用自定义消息转换器 1.5 编辑…

springboot整合gateway网关

一、网关基本概念 1、API网关介绍 API 网关出现的原因是微服务架构的出现&#xff0c;不同的微服务一般会有不同的网络地址&#xff0c;而外部客户端可能需要调用多个服务的接口才能完成一个业务需求&#xff0c;如果让客户端直接与各个微服务通信&#xff0c;会有以下的问题…

React Admin 前端脚手架之ant-design-pro

文章目录 一、React Admin 前端脚手架选型二、React Admin 前端脚手架之ant-design-pro三、ant-design-pro使用步骤四、常用总结&#xff08;持续更新&#xff09;EditableProTable组件 常用组件EditableProTable组件 编辑某行后&#xff0c;保存时候触发发送请求EditableProTa…

linux 系统 kill 指令笔记

kill 名称 kill - send a signal to a process 向指定的线程或进程发送信号 描述 The default signal for kill is TERM. Use -l or -L to list availablesignals. Particularly useful signals include HUP, INT, KILL, STOP,CONT, and 0. Alternate signals …

k8s笔记1- 初步认识k8s

k8s简介&#xff1a; kubernetes&#xff0c;俗称k8是&#xff0c;用于自动部署&#xff0c;扩缩和管理容器化应用程序的开源系统&#xff0c;它将组成应用程序的容器&#xff0c;组合成逻辑单元&#xff0c;便于管理和服务发现。 k8s的作用 自动化上线和回滚、存储编排…

Spring中的工厂类、bean的作用范围和生命周期

1.Spring中的工厂类 1.1ApplicationContext ClassPathXmlApplicationContext&#xff1a;加载类路径下 Spring 的配置文件 FileSystemXmlApplicationContext&#xff1a;加载本地磁盘下 Spring 的配置文件 1.1.1service ApplicationContext&#xff1a;只要一读取配置文件…

PyTorch|PyTorch张量解释

神经网络中的输入、输出和转换都使用张量表示&#xff0c;因此&#xff0c;神经网络编程大量使用张量&#xff0c;张量是我们在 PyTorch 中编程神经网络时将使用的数据结构。 关于张量及其维数的简要说明&#xff0c;以及术语&#xff1a; 你有时会看到一个称为向量的一维张量…

[论文分享]TimesURL:通用时间序列表示学习的自监督对比学习

论文题目&#xff1a;TimesURL: Self-supervised Contrastive Learning for Universal Time Series Representation Learning 论文地址&#xff1a;https://arxiv.org/abs/2312.15709 代码地址&#xff1a;暂无 摘要 学习适用于各种下游任务的通用时间序列表示具有挑战性&…

Springboot整合RocketMQ 基本消息处理

目录 1. 同步消息 2. 异步消息 3. 单向消息 4. 延迟消息 5. 批量消息 6. 顺序消息 7. Tag过滤 导入依赖 <dependency><groupId>org.apache.rocketmq</groupId><artifactId>rocketmq-spring-boot-starter</artifactId></dependency> …

14:00面试,14:08就出来了,问的问题过于变态了。。。

从小厂出来&#xff0c;没想到在另一家公司又寄了。 到这家公司开始上班&#xff0c;加班是每天必不可少的&#xff0c;看在钱给的比较多的份上&#xff0c;就不太计较了。没想到10月一纸通知&#xff0c;所有人不准加班&#xff0c;加班费不仅没有了&#xff0c;薪资还要降40…

机器学习原理到Python代码实现之LinearRegression

Linear Regression 线性回归模型 该文章作为机器学习的第一篇文章&#xff0c;主要介绍线性回归模型的原理和实现方法。 更多相关工作请参考&#xff1a;Github 算法介绍 线性回归模型是一种常见的机器学习模型&#xff0c;用于预测一个连续的目标变量&#xff08;也称为响应变…

Spring的bean的生命周期!!!

一.单例模式 单例&#xff1a;[启动容器]--->通过构造方法&#xff08;创建对象&#xff09;---->调用set方法&#xff08;注入&#xff09;--->调用init方法&#xff08;初始化&#xff09;----[容器关闭]----->调用destroy方法&#xff08;销毁&#xff09; app…

死锁的处理策略“检测和解除”-第三十九天

目录 前言 死锁的检测 数据结构资源分配图 基于“图”检测死锁 可以消除所有边 不能消除所有边 结论 死锁定理 死锁的解除 本节思维导图 前言 如果系统中既不采取预防死锁的措施&#xff0c;也不采取避免死锁的措施&#xff0c;系统就很可能发生死锁&#xff0c;在这种…

西电期末1019.校验和计算

一.题目 二.分析与思路 难点在于逐个取出数据的每一位&#xff0c;我们编写f函数&#xff0c;使用了一个while函数&#xff0c;每次循环中用取余的运算符找到数据的个位累加&#xff0c;再将n/10&#xff0c;如此n便被去除了个位&#xff0c;十位就成了新的个位&#xff0c;最…

案例精选|淄博绿能燃气工程有限公司日志审计系统建设方案

淄博绿能燃气工程有限公司&#xff0c;成立于1994年&#xff0c;前身为淄博市煤气公司管道液化气分公司。公司业务主要涉及天然气、液化气等市政工程施工及城镇燃气供应等领域&#xff0c;具有市政公用工程施工总承包二级资质&#xff0c;《压力管道安装许可证》压力管道安装GB…

利用Embedding优化搜索功能

我们继续用Gemini学习LLM编程之旅。 Embedding是一种自然语言处理 (NLP) 技术&#xff0c;可将文本转换为数值向量。Embedding捕获语义含义和上下文&#xff0c;从而导致具有相似含义的文本具有更接近的Embedding。例如&#xff0c;句子“我带我的狗去看兽医”和“我带我的猫去…

LeetCode---378周赛

题目列表 2980. 检查按位或是否存在尾随零 2981. 找出出现至少三次的最长特殊子字符串 I 2982. 找出出现至少三次的最长特殊子字符串 II 2983. 回文串重新排列查询 一、检查按位或是否存在尾随零 这题和位运算有关&#xff0c;不是很难&#xff0c;题目要求至少有两个数的…