如何检查 Linux 中进程运行了多长时间?

简介: 【5月更文挑战第4天】

进程的运行时间是指进程自启动以来所经过的时间。通过检查进程运行时间,我们可以了解到底有哪些进程在系统中运行了很长时间,这对于定位系统资源占用高、导致系统响应变慢的问题至关重要。及时发现并处理这些长时间运行的进程,可以提高系统的稳定性和性能。

使用 ps 命令

ps 命令是一个用于报告当前系统进程状态的强大工具。通过结合不同的选项,我们可以获取有关进程的各种信息,包括进程运行时间。

使用以下命令可以查看进程的基本信息,包括进程 ID(PID)、运行时间等:

ps -eo pid,cmd,etime
  • -e: 显示所有进程
  • -o: 指定输出的格式

上述命令输出的列中,etime 表示进程的运行时间。例如:

  PID CMD                          ELAPSED
 1234 /usr/bin/example-process    02:30:45

这表示 PID 为 1234 的进程 example-process 已经运行了2小时30分钟45秒。

使用 top 命令

top 是一个实时监控系统进程的命令行工具,提供了一个动态更新的进程列表。

运行以下命令启动 top

top

top 界面,你可以按 Shift+E 键来切换显示进程的运行时间。这将使得进程列表中包含 TIME+ 列,显示进程已运行的总时间。

PID USER      PR  NI    VIRT    RES    SHR S  %CPU  %MEM     TIME+ COMMAND
1234 user     20   0  200012  10560   8204 R   5.0   0.3  02:30:45 example-process

这个例子中,example-process 的运行时间为2小时30分钟45秒。

使用 pstree 命令

pstree 命令以树状图的形式显示进程的层次结构。通过查看进程树,我们可以更清晰地了解进程之间的关系,并查看它们的运行时间。

运行以下命令使用 pstree 查看进程树:

pstree -p

其中,-p 选项显示进程的 PID。输出可能如下:

init(1)─┬─systemd─┬─(sd-pam)
        │         ├─...
        │         └─(process-1)
        ├─(process-2)
        ├─(process-3)
        └─...

通过查看这个树状结构,你可以识别每个进程及其子进程,并在需要时了解它们的运行时间。

使用 /proc 文件系统

Linux 中的 /proc 目录是一个虚拟文件系统,提供了有关系统和进程的信息。我们可以通过读取 /proc 下的文件获取进程的详细信息,包括运行时间。

通过读取 /proc/[PID]/stat 文件,我们可以获取有关特定进程的详细信息,包括运行时间。以下是一个示例:

cat /proc/1234/stat

输出可能如下:

1234 (example-process) S 0 1234 1234 0 -1 4194560 385 0 0 0 0 0 0 0 20 0 1 0 12345678 1024 18446744073709551615 134512640 134513319 4294956704 18446744073709551615 135481464 0 0 0 0 17 1 0 0 0 0 0 0 0 0 0

在输出中,第 22 列(从左数)表示进程的运行时间,以时钟滴答为单位。

使用 htop

htop 是一个交互式的、更友好的进程查看工具,相对于传统的 top 命令更为强大和直观。

运行以下命令启动 htop

htop

htop 界面,你可以使用箭头键和功能键来导航和执行各种操作。按下 F6 键,选择并启用 TIME+ 以显示进程的运行时间。

PID USER      PRI  NI    VIRT    RES    SHR S  %CPU  %MEM     TIME+ COMMAND
1234 user      20   0  200012  10560   8204 R   5.0   0.3  02:30.45 example-process

这里,TIME+ 列显示进程的运行时间,以小时、分钟和秒的格式呈现。

使用 Systemd 工具

Systemd 是一套系统和服务管理器,提供了多种工具来监控和控制系统上运行的进程。

通过运行以下命令,你可以使用 systemctl 查看特定服务的详细信息,包括运行时间:

systemctl status example-service

输出中包含了服务的详细信息,其中也包括了运行时间:

● example-service.service - Example Service
   Loaded: loaded (/etc/systemd/system/example-service.service; enabled; vendor preset: enabled)
   Active: active (running) since Mon 2024-03-01 12:00:00 UTC; 2h 30min ago
 Main PID: 1234 (example-process)
    Tasks: 1 (limit: 4915)
   Memory: 10.5M
   CGroup: /system.slice/example-service.service
           └─1234 /usr/bin/example-process

在输出中,Active 部分显示了服务的活动状态以及自启动以来的时间。

编写脚本自动化检查

使用 Shell 脚本

创建一个 Shell 脚本文件,比如 check_process_time.sh,并添加以下内容:

#!/bin/bash

# 设置要检查的进程名称
process_name="example-process"

# 获取进程运行时间
process_time=$(ps -eo cmd,etime | grep "$process_name" | awk '{print $NF}')

echo "Process $process_name has been running for: $process_time"

保存脚本文件后,赋予执行权限并运行:

chmod +x check_process_time.sh
./check_process_time.sh

脚本将输出指定进程的运行时间,方便用户定期执行以监控进程状态。

定时执行脚本

使用 cronsystemd 的定时任务功能,你可以定期执行上述脚本,以便及时了解进程的运行时间。下面是使用 cron 的例子:

# 打开定时任务编辑器
crontab -e

添加以下行来每小时执行一次脚本:

0 * * * * /path/to/check_process_time.sh

保存并退出编辑器。

目录
相关文章
|
22天前
|
监控 数据可视化 Ubuntu
|
11天前
|
缓存 监控 Linux
linux进程管理万字详解!!!
本文档介绍了Linux系统中进程管理、系统负载监控、内存监控和磁盘监控的基本概念和常用命令。主要内容包括: 1. **进程管理**: - **进程介绍**:程序与进程的关系、进程的生命周期、查看进程号和父进程号的方法。 - **进程监控命令**:`ps`、`pstree`、`pidof`、`top`、`htop`、`lsof`等命令的使用方法和案例。 - **进程管理命令**:控制信号、`kill`、`pkill`、`killall`、前台和后台运行、`screen`、`nohup`等命令的使用方法和案例。
39 4
linux进程管理万字详解!!!
|
2天前
|
存储 运维 监控
深入Linux基础:文件系统与进程管理详解
深入Linux基础:文件系统与进程管理详解
33 8
|
5天前
|
安全 算法 Linux
Linux 服务器还有漏洞?建议使用 OpenVAS 日常检查!
在数字化时代,Linux 服务器的安全至关重要。OpenVAS 是一款优秀的开源漏洞扫描工具,可以帮助及时发现并修复服务器中的安全隐患。本文将介绍 OpenVAS 的主要功能、使用方法及应对漏洞的措施,帮助用户加强服务器安全管理,确保企业数字化安全。
18 7
|
26天前
|
存储 监控 固态存储
|
29天前
|
机器学习/深度学习 人工智能 Ubuntu
|
11天前
|
算法 Linux 定位技术
Linux内核中的进程调度算法解析####
【10月更文挑战第29天】 本文深入剖析了Linux操作系统的心脏——内核中至关重要的组成部分之一,即进程调度机制。不同于传统的摘要概述,我们将通过一段引人入胜的故事线来揭开进程调度算法的神秘面纱,展现其背后的精妙设计与复杂逻辑,让读者仿佛跟随一位虚拟的“进程侦探”,一步步探索Linux如何高效、公平地管理众多进程,确保系统资源的最优分配与利用。 ####
38 4
|
11天前
|
缓存 负载均衡 算法
Linux内核中的进程调度算法解析####
本文深入探讨了Linux操作系统核心组件之一——进程调度器,着重分析了其采用的CFS(完全公平调度器)算法。不同于传统摘要对研究背景、方法、结果和结论的概述,本文摘要将直接揭示CFS算法的核心优势及其在现代多核处理器环境下如何实现高效、公平的资源分配,同时简要提及该算法如何优化系统响应时间和吞吐量,为读者快速构建对Linux进程调度机制的认知框架。 ####
|
13天前
|
消息中间件 存储 Linux
|
19天前
|
运维 Linux
Linux查找占用的端口,并杀死进程的简单方法
通过上述步骤和命令,您能够迅速识别并根据实际情况管理Linux系统中占用特定端口的进程。为了获得更全面的服务器管理技巧和解决方案,提供了丰富的资源和专业服务,是您提升运维技能的理想选择。
19 1