百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程文章 > 正文

如何检查 Linux 中所有正在运行的服务?

qiyuwang 2025-04-05 22:08 7 浏览 0 评论

在 Linux 系统中,服务是系统的命脉。它们可能是网络服务器(像 Nginx 或 Apache)、数据库(比如 MySQL 或 PostgreSQL)、日志管理器,甚至是负责硬件检测的小型后台程序。了解哪些服务正在运行,有以下几个关键原因:

  • 性能优化
  • :某些服务可能占用大量 CPU 或内存资源,影响系统效率。
  • 故障排查
  • :当系统出现问题时,检查服务状态往往是定位根源的第一步。
  • 安全防护
  • :未经授权或未知的服务可能是潜在的安全漏洞。
  • 资源管理
  • :确保只有必要服务运行,避免浪费系统资源。

本文将介绍一系列命令和工具,帮助你从不同角度检查 Linux 中的服务。我们会涵盖现代 systemd 系统下的方法,也会回顾一些适用于老系统的经典工具,确保你无论面对哪种 Linux 环境都能游刃有余。

方法一:使用 systemctl命令

现代 Linux 的服务管理利器

在如今的 Linux 发行版(如 Ubuntu、Debian、CentOS 8+ 等)中,systemd 已经成为默认的初始化系统,而 systemctl 是它的核心管理工具。想快速了解系统中正在运行的服务?systemctl 是你的首选。

列出所有正在运行的服务

要查看所有正在运行的服务,输入以下命令:

systemctl list-units --type=service --state=running 

这行命令会列出所有处于“运行”状态的服务单元。输出看起来可能是这样的:

UNIT                        LOAD   ACTIVE SUB     DESCRIPTION apache2.service             loaded active running The Apache HTTP Server cron.service                loaded active running Regular background program processing daemon ssh.service                 loaded active running OpenBSD Secure Shell server ... 
  • UNIT
  • :服务单元的名称,通常以 .service 结尾。
  • LOAD
  • :表示服务是否已加载到内存。
  • ACTIVE
  • :服务是否处于活动状态(active 表示正在运行)。
  • SUB
  • :子状态(running 表示正在执行)。
  • DESCRIPTION
  • :服务的简要描述。

如果你想看到更详细的列表,包括已停止的服务,可以去掉 --state=running

systemctl list-units --type=service 

检查特定服务的状态

想深入了解某个服务的运行情况?用 systemctl status

systemctl status apache2 

输出会显示服务的详细信息,比如:

● apache2.service - The Apache HTTP Server    Loaded: loaded (/lib/systemd/system/apache2.service; enabled; vendor preset: enabled)    Active: active (running) since Mon 2023-10-01 09:00:00 UTC; 2h ago      Docs: https://httpd.apache.org/docs/2.4/  Main PID: 1234 (apache2)     Tasks: 55 (limit: 4915)    Memory: 15.2M    CGroup: /system.slice/apache2.service            ├─1234 /usr/sbin/apache2 -k start            ├─1235 /usr/sbin/apache2 -k start            └─1236 /usr/sbin/apache2 -k start 

这里你可以看到服务的启动时间、主进程 ID(PID)、内存占用,甚至是子进程的详细信息。非常适合排查服务是否正常运行。

小贴士

  • 检查服务是否开机自启:systemctl is-enabled apache2
  • 启动或停止服务:systemctl start apache2systemctl stop apache2

方法二:使用 service命令

老派但依然实用

在一些老的 Linux 系统(如 CentOS 6)中,SysVinit 是主流的初始化系统,而 service 命令是管理服务的标配工具。即使在 systemd 系统中,service 也能用(实际上它是 systemctl 的一个封装)。

查看所有服务的状态

运行以下命令,快速查看所有服务的状态:

service --status-all 

输出会是这样的:

 [ + ]  apache2  [ - ]  mysql  [ ? ]  dbus  ... 
  • [ + ]
  • :服务正在运行。
  • [ - ]
  • :服务已停止。
  • [ ? ]
  • :服务状态未知(通常是因为没有状态检查脚本)。

检查特定服务

想知道某个服务的情况?试试:

service apache2 status 

这会返回类似 systemctl status 的信息,但格式更简洁。

局限性

service 的功能不如 systemctl 强大,尤其是在 systemd 系统中,它只是一个过渡工具。如果你在现代系统中,建议优先使用 systemctl


方法三:使用 ps命令

进程视角看服务

ps 是一个万能的进程查看工具,虽然它不直接针对“服务”,但很多服务是以进程形式运行的。通过 ps,你可以从底层了解系统中正在发生什么。

列出所有进程

最常用的命令是:

ps -ef 

输出会显示所有进程的详细信息:

  • UID
  • :运行进程的用户。
  • PID
  • :进程 ID。
  • PPID
  • :父进程 ID。
  • CMD
  • :启动进程的命令。

筛选服务进程

想找特定服务的进程?结合 grep

ps -ef | grep apache 

这会过滤出所有与 Apache 相关的进程。

更灵活的用法

如果只想看进程树,可以用:

ps auxf 

这会显示进程的层级关系,帮助你理解服务和子进程之间的联系。


方法四:使用 top和 htop

实时监控服务

当你需要实时观察服务占用的资源时,tophtop 是绝佳选择。

top命令

输入 top,你会看到一个动态更新的界面:

q 退出,按 P 按 CPU 排序,按 M 按内存排序。

htop命令

htoptop 的升级版,界面更友好,支持鼠标操作。先安装它:

sudo apt-get install htop  # Ubuntu/Debian sudo yum install htop      # CentOS/RHEL 

运行 htop,你会看到彩色界面,可以用箭头键导航,用 F3 搜索服务进程。

场景应用

假设你怀疑某个服务(如 Apache)占用了过多资源,用 tophtop 可以立刻看到它的 CPU 和内存使用情况。


方法五:使用 netstat和 ss

网络服务的窗口

很多服务(如 Web 服务器、SSH)会监听网络端口。通过 netstatss,你可以发现这些服务的踪迹。

netstat命令

列出所有监听端口:

netstat -tuln 

输出:

  • 80
  • 端口通常是 HTTP 服务。
  • 22
  • 端口是 SSH。

想知道是哪个进程在监听?加上 -p

netstat -tulnp 

需要 root 权限,输出会显示 PID 和程序名。

ss命令

ssnetstat 的现代替代品,速度更快:

ss -tuln 

输出类似 netstat,但更简洁。加上 -p 查看进程:

ss -tulnp 

实际案例

假设你发现端口 3306 被占用,用 ss -tulnp | grep 3306,很可能发现是 MySQL 在运行。


方法六:使用 chkconfig

老系统的服务管理

在 SysVinit 系统中,chkconfig 是管理服务启动状态的工具。虽然在 systemd 系统中已不常用,但在老系统(如 CentOS 6)中仍有价值。

列出服务状态

chkconfig --list 

输出:

apache2         0:off   1:off   2:on    3:on    4:on    5:on    6:off cron            0:off   1:off   2:on    3:on    4:on    5:on    6:off 

数字 0-6 表示运行级别,on 表示该级别下服务会启动。

修改服务状态

开启服务自启:

chkconfig apache2 on 

方法七:使用 journalctl

从日志看服务

journalctl 是 systemd 的日志工具,可以帮你查看服务的运行历史和状态。

查看所有日志

journalctl 

查看特定服务日志

journalctl -u apache2 

输出:

实时监控

想看服务的实时日志?加上 -f

journalctl -u apache2 -f 

综合应用:如何选择合适的方法?

面对这么多工具,哪一个最适合你?答案取决于你的需求和系统环境:

  • 快速概览
  • :用 systemctl list-units --type=service --state=running
  • 详细状态
  • :用 systemctl statusjournalctl
  • 进程视角
  • :用 pstop/htop
  • 网络服务
  • :用 netstatss
  • 老系统
  • :用 servicechkconfig

实战场景

假设你的网站响应变慢:

  1. top 检查是否有服务占用过多资源。
  2. systemctl status 查看 Web 服务状态。
  3. ss -tulnp 确认端口是否正常监听。
  4. journalctl -u 查看日志,寻找错误线索。

相关推荐

基于Docker方式安装与部署Camunda流程引擎

1Camunda简介官网:https://docs.camunda.org/manual/7.19/installation/docker/Camunda是一个轻量级、开源且高度灵活的工作流和决策自...

宝塔Linux面板如何部署Java项目?(宝塔面板 linux)

通过宝塔面板部署Java还是很方便的,至少不需要自己输入tomcat之类的安装命令了。在部署java项目前,我还是先说下目前的系统环境,如果和我的系统环境不一样,导致部署不成功,那你可能需要去找其他资...

浪潮服务器如何用IPMI安装Linux系统

【注意事项】此处以浪潮服务器为例进行演示所需使用的软件:Chrome浏览器个人PC中需要预先安装java,推荐使用jdk-8u181-windows-x64.exe【操作步骤】1、在服务器的BIOS中...

Centos7环境Hadoop3集群搭建(hadoop集群环境搭建实验报告)

由于项目需要存储历史业务数据,经过评估数据量会达到100亿以上,在原有mongodb集群和ES集群基础上,需要搭建Hbase集群进行调研,所以首先总结一下Hadoop集群的搭建过程。一、三个节点的集群...

Hadoop高可用集群搭建及API调用(hadoop高可用原理)

NameNodeHA背景在Hadoop1中NameNode存在一个单点故障问题,如果NameNode所在的机器发生故障,整个集群就将不可用(Hadoop1中虽然有个SecorndaryNameNo...

使用Wordpress搭建一个属于自己的网站

现在开源的博客很多,但是考虑到wordpress对网站的seo做的很好,插件也多。并且全世界流量排名前1000万的网站有33.4%是用Wordpress搭建的!所以尝试用Wordpress搭建一个网站...

Centos 安装 Jenkins(centos 安装ssh)

1、Java安装查看系统是否已安装Javayumlistinstalled|grepjava...

Java教程:gitlab-使用入门(java中的git)

1导读本教程主要讲解了GitLab在项目的环境搭建和基本的使用,可以帮助大家在企业中能够自主搭建GitLab服务,并且可以GitLab中的组、权限、项目自主操作...

Dockerfile部署Java项目(docker部署java应用)

1、概述本文主要会简单介绍什么是Docker,什么是Dockerfile,如何安装Docker,Dockerfile如何编写,如何通过Dockerfile安装jar包并外置yaml文件以及如何通过do...

如何在Eclipse中搭建Zabbix源码的调试和开发环境

Zabbix是一款非常优秀的企业级软件,被设计用于对数万台服务器、虚拟机和网络设备的数百万个监控项进行实时监控。Zabbix是开放源码和免费的,这就意味着当出现bug时,我们可以很方便地通过调试源码来...

Java路径-02-Java环境配置(java环境搭建及配置教程)

1Window环境配置1.1下载...

35.Centos中安装python和web.py框架

文章目录前言1.Centos7python:2.Centos8python:3.进行下载web.py框架然后应用:4.安装好之后进行验证:5.总结:前言...

《我的世界》服务器搭建(我的世界服务器如何搭建)

1.CentOS7环境1.1更改YUM源#下载YUM源文件curl-o/etc/yum.repos.d/CentOS-Base.repohttps://mirrors.aliyun.com...

CentOS 7 升级 GCC 版本(centos7.4升级7.5)

1.GCC工具介绍GCC编译器:...

Linux安装Nginx详细教程(linux安装配置nginx)

环境准备1.因为Nginx依赖于gcc的编译环境,所以,需要安装编译环境来使Nginx能够编译起来。命令:yuminstallgcc-c++显示完毕,表示安装完成:2.Nginx的http模块需要...

取消回复欢迎 发表评论: