查看Linux进程启动时间的命令方法
时间:2026-04-21 10:45:58 379浏览 收藏
在Linux系统中精准获取进程启动时间需根据场景选择合适方法:`ps -eo pid,lstart,cmd`以可读格式直观展示所有进程的完整启动时刻,适合日常排查;`/proc/PID/stat`第22字段提供内核级高精度启动滴答数,虽需换算但最权威,尤其适用于调试fork时间偏差;systemd服务则应优先使用`systemctl show -p ActiveEnterTimestamp`或`systemctl status`查看服务就绪时间,反映实际业务可用性;而top和htop因仅显示运行时长而非绝对时间,完全不适用于启动时间审计。理解不同命令背后的时间语义——进程创建、内核记账起点还是服务状态变更——才是准确回答“它到底什么时候开始的”这一关键问题的核心。

ps 命令怎么看进程启动时间
Linux 下最直接的方式是用 ps 查看进程的启动时间,但默认输出不带时间字段,必须显式指定格式。关键在于使用 lstart(完整启动时间)或 stime(启动时间戳,单位为秒)字段。
常用命令示例:
ps -eo pid,lstart,cmd --sort=-lstart | head -5
说明:-e 选所有进程,-o 自定义输出列,lstart 格式为 YYYY-MM-DD HH:MM:SS,--sort=-lstart 表示倒序(最新启动在前)。
lstart可读性强,适合人工排查;stime是从系统启动开始的秒数,需配合uptime -s手动换算- 普通用户只能看到自己启动的进程;要查全部进程,需加
sudo - 注意:部分精简版 busybox 或容器环境中的
ps不支持lstart,会报错unknown sort key: lstart
/proc/PID/stat 文件里怎么提取启动时间
每个进程在 /proc/[PID]/stat 的第 22 个字段(从 1 开始计数)是该进程启动时距系统启动以来的时钟滴答数(starttime),单位是 sysconf(_SC_CLK_TCK),通常是 100 Hz(即每 tick = 0.01 秒)。
手动计算步骤:
- 执行
getconf CLK_TCK确认 tick 频率(多数系统为 100) - 读取
cat /proc/1234/stat | awk '{print $22}'得到starttime - 执行
awk 'BEGIN{print '"$(cat /proc/uptime | awk '{print $1}')" - '"$(cat /proc/1234/stat | awk '{print $22}')"' / 100}'得到进程已运行秒数 - 再用
date -d "@$(($(date -d "$(uptime -s)" +%s) + 运行秒数))"换算出绝对启动时间
这个方法底层可靠,但写成一行命令易出错,建议封装为小脚本;另外,/proc/PID/stat 中的 starttime 是内核态记录值,比 ps 更权威,尤其适用于调试进程被 fork 后时间漂移的问题。
systemd 服务怎么查启动时间
如果进程由 systemd 管理(如 nginx、dockerd),优先用 systemctl 查,它记录的是服务单元的激活时间,而非进程创建时间,但对运维更实用。
常用命令:
systemctl show nginx.service -p ActiveEnterTimestamp --value
或者更直观地:
systemctl status nginx.service | grep "Active:"
说明:ActiveEnterTimestamp 是服务进入 active 状态的时间,精度到微秒;systemctl status 输出中 “Active:” 行右侧的时间就是这个值的可读形式。
- 注意区分
ActiveEnterTimestamp(服务就绪)和InactiveEnterTimestamp(上次退出) - 非 systemd 启动的进程(比如手动
./app)不会出现在systemctl结果中 - 某些服务设了
Restart=always,ActiveEnterTimestamp是最近一次重启时间,不是首次启动时间
top 和 htop 不能直接看启动时间
top 默认不显示进程启动时间,htop 虽然支持自定义列,但其 STARTED 列实际显示的是进程运行时长(如 12:34:56),不是具体日期时间,容易误解。
如果你在 htop 里按 F2 → Columns → Available columns 找到 STARTED 并添加,它只显示“已运行多久”,无法还原到某年某月某日几点几分。
- 想确认是否真有启动时间列?在
htop中按F1看帮助,搜索STARTED字段说明 - 不要依赖
top的TIME+列——那是 CPU 占用总时间,和启动无关 - 这类交互式工具的设计目标是实时监控,不是审计溯源,查启动时间请切回
ps或/proc
真正要注意的是:不同命令反映的时间语义不同——ps lstart 是进程创建时刻,/proc/PID/stat 的 starttime 是内核记账起点,systemctl 的时间是服务单元状态变更点。选哪个,取决于你到底想回答什么问题:是“这个进程啥时候被 fork 出来的”,还是“这个服务啥时候对外提供能力了”。
今天关于《查看Linux进程启动时间的命令方法》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
374 收藏
-
379 收藏
-
150 收藏
-
239 收藏
-
411 收藏
-
107 收藏
-
216 收藏
-
304 收藏
-
376 收藏
-
445 收藏
-
453 收藏
-
247 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习