运维人员必须知道的十个系统进程

系统 其他OS
kswapd0系统定时唤醒kswapd,检查内存是否紧张,如果不紧张,则睡眠,在kswapd中,有2个阀值:pages_hige,pages_low,空闲内存页数量低于pages_low的时,kswapd进程会扫描内存并且每次释放出32个free pages,直到free page的数量到达pages_high标准。

前言

在日常运维工作中,经常会看到一些奇怪的系统进程占用资源比较高,但是又不敢随意的Kill这些进程

而这些系统级的内核进程都是会用中括号括起来的,它们会执行一些系统的辅助功能(如将缓存写入磁盘);

无括号的进程都是用户们执行的进程(如java、nginx等)

如下图所示:

图片图片

  • kswapd0系统定时唤醒kswapd,检查内存是否紧张,如果不紧张,则睡眠,在kswapd中,有2个阀值:pages_hige,pages_low,空闲内存页数量低于pages_low的时,kswapd进程会扫描内存并且每次释放出32个free pages,直到free page的数量到达pages_high标准
  • kjournaldkjournald有三种模式,分别是journal,ordered,和writebackjournal:最慢的一种模式,主要记录所有文件系统上的元数据改变ordered:默认使用的模式,只记录文件系统改变的元数据,并且是在改变前记录日志writeback :最快的一种模式,同样只记录修改过的元数据,依赖标准文件系统写进程将数据写到硬盘
  • pdflush主要用于将内存中的内容和文件系统进行同步。比如说:当一个文件在内存中进行修改,pdflush负责将它写回硬盘。每当内存中的垃圾页(dirty page)超过10%的时候,pdflush就会将这些页面备份回硬盘。此比率通过通过/etc/sysctl.conf中的 vm.dirty_background_ratio项默认值为10

  • kthreadd内核初始化的时候被创建的一个内核线程,其作用是管理调度其它内核线程。它会循环运行一个叫做kthreadd的函数,该函数的作用是运行kthread_create_list全局链表中维护的kthread,然后可以调用kthread_create创建一个kthread,它会被加入到kthread_create_list链表中,同时kthread_create会weak up kthreadd_task

注意:这个线程不能关闭!!!

  • migrationmigration/0-migration/31共有32个内核现场,每个处理器核对应一个migration内核线程,主要作为相应CPU核的迁移进程,用来执行进程迁移操作,内核中的函数是migration_thread();该进程在系统启动时自动加载(每个 cpu 一个),并将自己设为 SCHED_FIFO 的实时进程,然后检查 runqueue::migration_queue 中是否有请求等待处理,如果没有,就在 TASK_INTERRUPTIBLE 中休眠,直到被唤醒后再次检查。migration_thread() 仅仅是一个 CPU 绑定以及 CPU 电源管理等功能的一个接口。这个线程是调度系统的重要组成部分。
  • watchdogwatchdog/0-watchdog/31总共32个内核线程, 每个处理器核心对应一个watchdog 内核线程,主要用于监视系统的运行,在系统出现故障时自动重新启动系统,包括一个内核 watchdog module 和一个用户空间的 watchdog 程序。其基本工作原理是:当watchdog启动后(即/dev/watchdog设备被打开后),如果在某个时间间隔(1分钟)内/dev/watchdog没有被执行写操作, 硬件watchdog电路或软件定时器就会重新启动系统,每次写操作会导致重新设定定时器。
  • eventsevents/0-events/31, 总共32个内核线程,每个处理器核对应一个 events内核线程。主要用作处理内核事件很多软硬件事件(比如断电,文件变更)被转换为events,并分发给对相应事件感兴趣的线程进行响应。
  • kblockdkblockd/0-kblockd/31, 总共32个内核线程 ,每个处理器核对应一个 kblockd 内核线程,用于管理系统的块设备,它会周期性的激活系统内的块设备驱动
  • aioaio/0-aio/31, , 总共32个内核线程,每个处理器核对应一个 aio 内核线程, 代替用户进程管理I/O,用以支持用户态的AIO(异步I/O)注意:此线程不应该被关闭。
  • rpciodrpciod/0-rpciod/31, 总共32个内核线程, 每个处理器核对应一个rpciod内核线程,主要作为远程调用服务(如NFS)的守护进程,用于从客户端启动I/O服务
责任编辑:武晓燕 来源: 步步运维步步坑
相关推荐

2023-05-11 16:29:39

Javascript开发前端

2021-09-15 09:20:37

Python函数代码

2022-06-08 10:42:34

ReduceJavaScript技巧

2022-10-17 15:33:46

前端开发数组

2023-11-28 14:04:15

Kubernetes运维

2018-01-31 10:58:27

2011-05-11 15:28:05

2011-01-28 15:11:15

PowerShell

2023-11-13 08:18:56

2024-12-16 08:11:45

Python系统调用

2021-05-26 08:00:00

微服务开发求职

2022-06-20 22:37:25

Linux操作系统命令

2018-04-08 10:08:43

开发人员工具

2022-07-26 09:09:23

Python编程语言代码

2020-05-29 11:48:01

安全运维信息安全网络安全

2023-02-06 16:46:59

JavaScript程序员技巧

2020-09-23 09:55:15

算法TensorFlowGithub

2009-06-25 09:04:22

.NET开发人员

2021-11-05 11:56:34

运维规则书籍

2014-03-14 09:13:35

Linux终端进程管理终端命令
点赞
收藏

51CTO技术栈公众号