Linux 下如何查看进程的资源限制信息?

news2025/6/4 5:58:07

简介

Linux 上的 cat /proc/$pid/limits 命令提供有关特定进程的资源限制的信息,其中 $pid 是相关进程的进程 ID (pid)。该文件是 `/proc 文件系统的一部分,该文件系统是一个虚拟文件系统,提供有关进程和系统资源的信息。

基本用法

cat /proc/1234/limits

# 其中 1234 是目标进程的 PID。
  • $pid:目标进程的进程 ID(PID)。可以通过 ps 命令查找,例如 ps aux | grep <进程名>

  • 输出:显示指定进程的软限制(soft limit)、硬限制(hard limit)以及限制单位。

输出示例:

Limit                     Soft Limit           Hard Limit           Units
Max cpu time               unlimited            unlimited             seconds
Max file size              unlimited            unlimited             bytes
Max data size              unlimited            unlimited             bytes
Max stack size             8388608              8388608               bytes
Max core file size        0                    unlimited             bytes
Max resident set          unlimited            unlimited             bytes
Max processes             6348                 6348                  processes
Max open files            1024                 1024                  files
Max locked memory         65536                65536                 bytes
Max address space         unlimited            unlimited             bytes
Max file locks            unlimited            unlimited             locks
Max pending signals       6348                 6348                  signals
Max msgqueue size         819200               819200                bytes
Max nice priority         20                   20                    priority
Max realtime priority     99                   99                    priority
Max realtime timeout      unlimited            unlimited             us

关键字段解释

  • Max cpu time:该进程可以消耗无限量的 CPU 时间(没有上限)

  • Max file size:该进程可以创建任意大小的文件

  • Max data size:数据段(存储变量和数组)不受限制

  • Max stack size:堆栈大小限制为 8MB(8388608 字节),堆栈存储函数调用数据

  • Max open files:该进程最多可以同时打开 1024 个文件

  • Max processes:该进程最多可以产生 6348 个子进程

修改限制

  • ulimit:用于调整当前 shell 会话的限制

  • prlimit:用于对已经运行的进程设置限制

  • /etc/security/limits.conf:用于设置用户和组的默认资源限制

资源限制

这些是应用于进程的各种限制和约束,以控制其可以使用的资源,例如内存、CPU 和文件描述符。

此文件中列出的常见资源包括:

  • Limit:资源的实际限制

  • Current:该进程当前对该资源的使用情况

  • Soft Limit:当前应用于进程的限制,可以由进程进行调整(在硬限制范围内)

  • Hard Limit:不可超过的最大限制,它由系统管理员设置或采用默认设置

  • Units:衡量限制的单位(例如字节、KB 等)

常见的限制类型

  • Max process limit:用户可以创建的最大进程数。它限制了用户可以生成的进程数量

  • Max open files:进程可以拥有的最大文件描述符数量。这会影响进程可以同时打开的文件、套接字等的数量

  • Max locked memory:可以锁定到 RAM 中的最大内存量,防止其被换出

  • Max address space:进程可以分配的最大虚拟地址空间量,其中包括内存、堆和堆栈

  • Max CPU time:进程可使用的最大 CPU 时间。以秒为单位

  • Max file locks:进程可以拥有的文件锁的最大数量

  • Max number of threads:进程可以创建的最大线程数

  • Max user time:进程在用户空间中花费的最长时间(以秒为单位)(即不包括内核时间)

  • Max virtual memory:进程可以分配的虚拟内存总量,通常控制进程内存使用的上限

  • Max file size:进程创建文件的最大大小

  • Max data size:进程数据段的最大大小(包括堆和数据)

  • Max stack size:进程堆栈的最大大小

  • Max core file size:核心转储文件(core dump)的最大大小

  • Max resident set:驻留内存(RSS,物理内存)的最大大小

  • Max pending signals:进程可排队的最大信号数

  • Max msgqueue sizePOSIX 消息队列的最大大小

  • Max realtime priority:实时调度优先级的最大值

  • Max realtime timeout:实时任务的最大超时时间(微秒)

软限制与硬限制

  • 软限制:这是当前为进程设置的限制,进程可以更改它,管理员也可以使用 ulimit(用于 shell)或 prlimit(用于正在运行的进程)等命令更改它

  • 硬限制:这是除非超级用户 (root) 更改,否则无法超过的最大限制,硬限制由内核强制执行,它是软限制的上限

常见用法

检查进程资源限制

用于诊断进程是否因资源限制(如文件描述符不足)而失败:

cat /proc/$(pidof bash)/limits

查看当前 bash 进程的限制

查找文件描述符限制

检查进程的最大文件描述符数:

cat /proc/1234/limits | grep "Max open files"

输出示例:

Max open files            1024                 1048576              files
结合 ulimit 调整限制

ulimit 命令可修改当前 shell 的软限制(需要硬限制允许)。例如,增加文件描述符限制

ulimit -n 2048
cat /proc/$$/limits | grep "Max open files"
监控系统限制

检查所有进程的限制模式

for pid in /proc/[0-9]*; do echo "PID: $(basename $pid)"; cat $pid/limits; done
诊断文件描述符不足

假设某个服务(PID 1234)报错 Too many open files

cat /proc/1234/limits | grep "Max open files"
lsof -p 1234 | wc -l

如果打开的文件数接近软限制,临时增加限制:

prlimit --pid 1234 --nofile=2048:1048576

或修改服务配置文件(如 systemdLimitNOFILE

检查核心转储

确保进程可以生成核心转储:

cat /proc/1234/limits | grep "Max core file size"

如果软限制为 0,启用核心转储:

ulimit -c unlimited

相关配置文件

/proc/$pid/limits 的值通常来自以下来源:

  • /etc/security/limits.conf:定义用户或组的默认资源限制
# 格式:<domain> <type> <item> <value>
* soft nofile 1024
* hard nofile 1048576

* 表示所有用户,nofile 对应 Max open files

  • /etc/security/limits.d/:包含额外的限制配置文件

  • 系统默认值:由内核参数或系统配置(如 /proc/sys/) 决定

  • ulimit 命令:动态修改当前 shell 或进程的软限制

  • systemd 配置:服务进程的限制可在 systemd 单元文件中的[Service] 快设置(例如 LimitNOFILE=2048

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

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

相关文章

【备忘】php命令行异步执行超长时间任务

环境说明&#xff1a; 操作系统&#xff1a;windows10 IDE&#xff1a;phpstorm 开发语言&#xff1a;php7.4 框架&#xff1a;thinkphp5.1 测试环境&#xff1a;linuxwindows均测试通过。 初级方法&#xff1a; function longRunningTask() {$root_path Tools::get_ro…

在 RK3588 上通过 VSCode 远程开发配置指南

在 RK3588 上通过 VSCode 远程开发配置指南 RK3588 设备本身不具备可视化编程环境&#xff0c;但可以通过 VSCode 的 Remote - SSH 插件 实现远程代码编写与调试。以下是完整的配置流程。 一、连接 RK3588 1. 安装 Debian 系统 先在 RK3588 上安装 Debian 操作系统。 2. 安…

OpenHarmony标准系统-HDF框架之音频驱动开发

文章目录 引言OpenHarmony音频概述OpenHarmony音频框图HDF音频驱动框架概述HDF音频驱动框图HDF音频驱动框架分析之音频设备驱动HDF音频驱动框架分析之supportlibs实现HDF音频驱动框架分析之hdi-passthrough实现HDF音频驱动框架分析之hdi-bindev实现HDF音频驱动加载过程HDF音频驱…

HTML Day03

Day03 0. 引言1. CSS1.1 CSS的3种使用方法1.2 内联样式1.3 内部样式表1.4 外部CSS文件 2. 图像3. 表格3.1单元格间距和单元格边框 4. 列表4.1 有序表格的不同类型4.2 不同类型的无序表格4.3 嵌套列表 5. 区块6. 布局6.1 div布局6.2 表格布局 0. 引言 HELLO ^ _ ^大家好&#xf…

篇章六 数据结构——链表(二)

目录 1. LinkedList的模拟实现 1.1 双向链表结构图​编辑 1.2 三个简单方法的实现 1.3 头插法 1.4 尾插法 1.5 中间插入 1.6 删除 key 1.7 删除所有key 1.8 clear 2.LinkedList的使用 2.1 什么是LinkedList 5.2 LinkedList的使用 1.LinkedList的构造 2. LinkedList的…

吴恩达MCP课程(3):mcp_chatbot

原课程代码是用Anthropic写的&#xff0c;下面代码是用OpenAI改写的&#xff0c;模型则用阿里巴巴的模型做测试 .env 文件为&#xff1a; OPENAI_API_KEYsk-xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx OPENAI_API_BASEhttps://dashscope.aliyuncs.com/compatible-mode…

【清晰教程】查看和修改Git配置情况

目录 查看安装版本 查看特定配置 查看全局配置 查看本地仓库配置 设置或修改配置 查看安装版本 打开命令行工具&#xff0c;通过version命令检查Git版本号。 git --version 如果显示出 Git 的版本号&#xff0c;说明 Git 已经成功安装。 查看特定配置 如果想要查看特定…

JAVA 常用 API 正则表达式

1 正则表达式作用 作用一&#xff1a;校验字符串是否满足规则作用二&#xff1a;在一段文本中查找满足要求的内容 2 正则表达式规则 2.1 字符类 package com.bjpowernode.test14;public class RegexDemo1 {public static void main(String[] args) {//public boolean matche…

光电设计大赛智能车激光对抗方案分享:低成本高效备赛攻略

一、赛题核心难点与备赛痛点解析 全国大学生光电设计竞赛的 “智能车激光对抗” 赛题&#xff0c;要求参赛队伍设计具备激光对抗功能的智能小车&#xff0c;需实现光电避障、目标识别、轨迹规划及激光精准打击等核心功能。从历年参赛情况看&#xff0c;选手普遍面临三大挑战&a…

Python实现P-PSO优化算法优化BP神经网络回归模型项目实战

说明&#xff1a;这是一个机器学习实战项目&#xff08;附带数据代码文档&#xff09;&#xff0c;如需数据代码文档可以直接到文章最后关注获取。 1.项目背景 在当今数据驱动的时代&#xff0c;回归分析作为预测和建模的重要工具&#xff0c;在科学研究和工业应用中占据着重要…

Microsoft的在word中选择文档中的所有表格进行字体和格式的调整时的解决方案

找到宏 创建 并粘贴 使用 Sub 全选所有表格() Dim t As Table an MsgBox("即将选择选区内所有表格&#xff0c;若无选区&#xff0c;则选择全文表格。", vbYesNo, "reboot提醒您!") If an - 6 Then Exit Sub Set rg IIf(Selection.Type wdSelectionIP, …

C++23:关键特性与最新进展深度解析

文章目录 范围的新功能与增强元组的优化与新特性字符与字符串的转义表示优化std::thread::id的改进与扩展栈踪迹的格式化支持结论 C23作为C标准的最新版本&#xff0c;带来了许多令人瞩目的改进和新特性。从新的范围和元组功能到对字符和字符串转义表示的优化&#xff0c;再到 …

鲲鹏Arm+麒麟V10 K8s 离线部署教程

针对鲲鹏 CPU 麒麟 V10 的离线环境&#xff0c;手把手教你从环境准备到应用上线&#xff0c;所有依赖包提前打包好&#xff0c;步骤写成傻瓜式操作指南。 一、环境规划# 准备至少两台机器。 架构OS作用Arm64任意&#xff0c;Mac 也可以下载离线包Arm64麒麟 V10单机部署 K8s…

PGSQL结合linux cron定期执行vacuum_full_analyze命令

‌VACUUM FULL ANALYZE 详解‌ 一、核心功能 ‌空间回收与重组‌ 完全重写表数据文件&#xff0c;将碎片化的存储空间合并并返还操作系统&#xff08;普通 VACUUM 仅标记空间可重用&#xff09;。彻底清理死元组&#xff08;已删除或更新的旧数据行&#xff09;&#xff0c;解…

C#定时器深度对比:System.Timers.Timer vs System.Threading.Timer性能实测与选型指南

本文通过真实基准测试揭秘两种常用定时器的性能差异&#xff0c;助你做出最佳选择 一、C#定时器全景概览 在C#生态中&#xff0c;不同定时器适用于不同场景。以下是主流定时器的核心特性对比&#xff1a; 定时器类型命名空间适用场景触发线程精度内存开销依赖框架System.Wind…

解决8080端口被占问题

文章目录 1. 提出问题2. 解决问题2.1 查看占用8080端口的进程2.2 杀死占用8080端口的进程2.3 测试问题是否已解决3. 实战小结1. 提出问题 运行Spring Boot项目,报错8080端口被占 2. 解决问题 2.1 查看占用8080端口的进程 执行命令:netstat -ano | findstr :8080 2.2 杀死占用…

介绍一种LDPC码译码器

介绍比特翻转译码原理以及LDPC码译码器的设计。 1 译码理论 比特翻转&#xff08;BF&#xff09;译码算法是硬判决算法的一种。 主要译码思想是&#xff1a;当有一个校验矩阵出错时&#xff0c;BF 算法认为在这个校验矩阵中一定至少存在一个位置的码字信息是错误的&#xff1…

3DMAX+Photoshop教程:将树木和人物添加到户外建筑场景中的方法

在本教程中&#xff0c;我将向您展示如何制作室外场景。我不会详细解释每一个细节&#xff0c;而是想快速概述一下我的方法。 在本教程中&#xff0c;我使用了一个相对简单的3D模型&#xff0c;并向您展示了在一些高质量纹理的帮助下可以做什么。此外&#xff0c;我将向您展示…

随记 配置服务器的ssl整个过程

第一步 先了解到这个公钥私钥服务器自己可以生成&#xff0c;但是没什么用&#xff0c;浏览器不会信任的&#xff0c;其他人访问不了。所以要一些中间机构颁布的证书才有用。 一般的服务器直接 安装 Certbot 和插件 //CentOS Nginx 用户&#xff1a; sudo yum install epe…

数据库高可用架构设计:集群、负载均衡与故障转移实践

关键词:数据库高可用,HA架构,数据库集群,负载均衡,故障转移,SQL Server Always On,MySQL InnoDB Cluster,高可用性组,读写分离,灾难恢复 在当今瞬息万变的数字化时代,数据的价值日益凸显,数据库作为承载核心业务数据的基石,其可用性直接决定了业务的连续性与用户…