在linux中进行进程分组
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在linux中进行进程分组相关的知识,希望对你有一定的参考价值。
我最近看到一些关于systemd
和cgroups
进程管理的截屏视频,我对以下方面的区别感到有些困惑:
a)服务:在典型的Linux术语中,服务可以包含多个进程;属于同一服务的进程如何分组?根据什么惯例?
b)过程组:根据POSIX标准的典型过程分组
c)切片:systemd
用于对资源分配/限制(以及其他)的服务(和范围)进行分组的概念
您可以将切片视为“cgroups systemd方式”。默认情况下,每个服务都有自己的切片(使用systemd-cgls
将其打印出来),在单元文件中,您可以自定义允许此特定单元的资源,例如,如果我打印nginx实例的状态:
● nginx.service - A high performance web server and a reverse proxy server
Loaded: loaded (/usr/lib/systemd/system/nginx.service; enabled; vendor preset: disabled)
Active: active (running) since Tue 2015-01-27 19:41:23 EST; 22h ago
Main PID: 495 (nginx)
CGroup: /system.slice/nginx.service
├─495 nginx: master process /usr/bin/nginx -g pid /run/nginx.pid; error_log stderr;
└─496 nginx: worker process
您可以看到此服务使用的相关Cgroup或“切片”。
为了自定义资源管理,你必须添加类似的东西
[Slice]
CPUShares=512
MemoryLimit=2G
内部单位失败,然后systemctl daemon-reload && systemctl restart nginx
您还可以组合切片以创建“服务数组”(询问您是否想要了解更多信息),这些服务将共享已定义的资源限制。这是一个.slice单位https://www.freedesktop.org/software/systemd/man/systemd.slice.html。基本上你创建一个.slice单元然后启动它并启用它并告诉其他服务在服务单元的“slice”部分内使用这个slice。
此外,有关控制资源调整的更多信息:qazxsw poi
编辑:
添加这些资源约束将限制nginx服务使用的资源,并且如果nginx由于DDOS或其他原因而变得疯狂,则可以保证其他服务的安全。
让我试着澄清,因为你似乎在混合不同的术语。
进程组此术语未在cgroup中使用,您可能指的是“控制组”,它基本上是cgroup的缩写。我注意到有几个网站在实际上意味着控制组时错误地使用了进程组。
Cgroups使用以下术语:切片,范围,服务
切片这些是用于为资源管理创建cgroup层次结构的单元类型。默认情况下有三个切片:
- system(默认包含启动过程)
- 用户(默认情况下包含用户会话)
- 机器(默认已创建但未使用并留给虚拟环境使用)
范围组织守护程序工作进程的组织单位。您可以将其视为“切片内的切片”。
服务由systemd控制的进程或进程组。基本上是您通过systemctl控制(停止/启动/状态)的过程。
以上是关于在linux中进行进程分组的主要内容,如果未能解决你的问题,请参考以下文章
Linux中进程控制块PCB-------task_struct结构体结构