查看Linux进程启动时间的命令方法
在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学习网公众号!
持久化存储实现自动登录教程
- 上一篇
- 持久化存储实现自动登录教程
- 下一篇
- 百度地图充电桩准吗?实时数据解析
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- ljg-skills
- ljg-skills 是李继刚开源的 AI 技能与提示词集合,面向大模型使用者整理了一批可复用的 prompt、角色设定和任务技能模板,适合用于学习提示词设计、搭建个人 AI 工作流和沉淀团队常用智能体能力。
- 2739次使用
-
- MELO音乐
- MELO音乐是一站式AI视频与音乐制作助手,对标suno, udio的高品质体验。提供伴奏生成、原创写词、无损导出、哼唱识曲、混音变声等全套音频与短视频编辑工具。无论是流行Kpop、电音说唱、民谣古风、摇滚儿歌还是商用轻音乐,MELO为你免费谱曲,轻松做同款!
- 2537次使用
-
- UniScribe
- UniScribe 是一款 AI 音视频转文字与内容整理工具,支持上传音频、视频文件或粘贴 YouTube 链接,自动生成转写文本、摘要、思维导图和关键问题,并支持多格式导出,适合会议记录、课程学习、访谈整理和内容创作复盘。
- 2479次使用
-
- 剧云
- 剧云是专业中文剧本创作平台,安全稳定运行十余年,集成AI编剧、剧本医生审核、人物小传、剧情关系图、大纲编写、多人协作、Word导入导出、版权管控功能,数据安全防护,轻松高效创作剧本。
- 2709次使用
-
- 万象有声
- 万象有声,一个专为有声创作者打造的新一代智能有声内容创作平台。平台提供专业的智能拆章、智能画本编辑、AI配音、AI生成音效、后期制作、智能对轨、智能审听等有声创作全流程工具,可以帮助创作者高效、低成本创作出引人入胜的有声作品。立即体验,让有声书制作更简单!
- 2655次使用
-
- Linux搭建vsftpdFTP服务器教程
- 2026-04-30 501浏览
-
- Shell脚本安装教程:.sh一键安装指南
- 2026-03-16 501浏览
-
- Linux清空文件内容的几种方法
- 2025-12-01 501浏览
-
- Linux命令行下载文件技巧
- 2025-11-23 501浏览
-
- Linuxapt与yum配置技巧全解析
- 2025-09-23 501浏览

