如何检查 Linux 中所有正在运行的服务?
nanshan 2025-04-11 02:55 11 浏览 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 apache2 或 systemctl 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
实时监控服务
当你需要实时观察服务占用的资源时,top 和 htop 是绝佳选择。
top命令
输入 top,你会看到一个动态更新的界面:
按 q 退出,按 P 按 CPU 排序,按 M 按内存排序。
htop命令
htop 是 top 的升级版,界面更友好,支持鼠标操作。先安装它:
sudo apt-get install htop # Ubuntu/Debian sudo yum install htop # CentOS/RHEL
运行 htop,你会看到彩色界面,可以用箭头键导航,用 F3 搜索服务进程。
场景应用
假设你怀疑某个服务(如 Apache)占用了过多资源,用 top 或 htop 可以立刻看到它的 CPU 和内存使用情况。
方法五:使用netstat和ss
网络服务的窗口
很多服务(如 Web 服务器、SSH)会监听网络端口。通过 netstat 或 ss,你可以发现这些服务的踪迹。
netstat命令
列出所有监听端口:
netstat -tuln
输出:
- 80 端口通常是 HTTP 服务。
- 22 端口是 SSH。
想知道是哪个进程在监听?加上 -p:
netstat -tulnp
需要 root 权限,输出会显示 PID 和程序名。
ss命令
ss 是 netstat 的现代替代品,速度更快:
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 status 或 journalctl。
- 进程视角:用 ps 或 top/htop。
- 网络服务:用 netstat 或 ss。
- 老系统:用 service 或 chkconfig。
实战场景
假设你的网站响应变慢:
- 用 top 检查是否有服务占用过多资源。
- 用 systemctl status 查看 Web 服务状态。
- 用 ss -tulnp 确认端口是否正常监听。
- 用 journalctl -u 查看日志,寻找错误线索。
相关推荐
- ssh终端xshell日志查看命令(xshell怎么看日志)
-
现在我们云服务器运维较多用的是SSH工具,其中常用的包括PUTTY、XSHELL等,其实大同小异界面UI稍微不同,但是都可以进入远程连接。这里有朋友提到如何查看服务器的日志文件,这个其实和是否使用XS...
- 使用 Fail Ban 日志分析 SSH 攻击行为
-
通过分析`fail2ban`日志可以识别和应对SSH暴力破解等攻击行为。以下是详细的操作流程和关键分析方法:---###**一、Fail2ban日志位置**Fail2ban的日志路径因系统配置...
- 如何高效读取Linux日志文件?这些命令要熟记于心!
-
在Linux系统中,日志文件通常存储在/var/log目录下。比如,/var/log/syslog(或/var/log/messages,视发行版而定)记录系统整体事件,/var/log/a...
- Windows服务器远程登录日志查询方法,linux查看登录日志方法
-
概述本文介绍Windows、Linux服务器查询系统的远程登录日志方法。根据服务器所使用的操作系统不同,有以下两种查询方法。Linux操作系统的登录日志查询通过远程连接登录Linux服务器,使用roo...
- iptables防火墙如何记录日志(防火墙日志查看)
-
例如:记录所有ssh服务的登录的日志首先,我们需要了解如何将所有的iptables的INPUT链数据包记录到/var/log/messages中。如果你已经有一些iptables规则了,那么将记录日志...
- 如何安全管理SSH密钥以防止服务器被入侵
-
SSH密钥安全管理实施指南(2025年更新版)一、密钥生成与存储规范高强度密钥生成bashCopyCodessh-keygen-ted25519-a100#生成ED25519算法密钥(比...
- 在CentOS上安装nginx服务器(centos搭建代理服务器)
-
一、环境描述1.虚拟机配置CPU:单核内存:2GB硬盘:120GBIP:10.24.17.1082.操作系统版本:CentOS6.6x86_64安装方式:Minimal3.虚拟化环境VM...
- CentOS7安全加固的一份整理规划建议
-
◆更新系统:及时更新CentOS7操作系统版本和安全补丁,确保系统以最新状态运行。◆关闭不必要的服务:在运行系统时,应关闭不需要的服务和端口,以减少系统暴露的攻击面。◆安装防火墙:使用iptables...
- 第四十七天-二叉树,centOS安装tomcat,Maven,vsftpd
-
学习笔记:1.Maven是Apache下的一个纯Java开发的开源项目。基于项目对象模型(缩写:POM)概念,Maven利用一个中央信息片断能管理一个项目的构建、报告和文档等步骤。Maven...
- Linux远程桌面连接使用教程 Widows终端远程连接Linux服务器
-
一、前言为什么不是远程连接Linux服务器?因为我不会,远程连接window我就用电脑自带的“远程桌面连接”。以下所述都是在CentOS操作系统下的。服务器刚换成Linux的时候很迷茫,感觉无从下手...
- CentOS 安全加固操作,保护你的操作系统
-
系统加固是保障系统安全的重要手段,对于维护企业数据安全、用户隐私以及系统稳定运行具有重要意义。加固后的系统更加健壮和稳定,能够有效减少因安全问题导致的系统故障和停机时间,提高系统的可用性和可靠性。通过...
- Dockerfile部署Java项目(docker如何部署java项目)
-
1、概述本文主要会简单介绍什么是Docker,什么是Dockerfile,如何安装Docker,Dockerfile如何编写,如何通过Dockerfile安装jar包并外置yaml文件以及如何通过do...
- CentOS7云主机部署Fail2ban阻断SSH暴力破解
-
关于Fail2banFail2ban可以监视你的系统日志,然后匹配日志的错误信息(正则式匹配)执行相应的屏蔽动作(一般情况下是调用防火墙屏蔽)例如:当有人在试探你的HTTP、SSH、SMTP、FTP密...
- 在CentOS7上用源码编译安装PostgreSQL
-
1、新建postgres用户#useraddpostgres&&passwdpostgres2、安装依赖包#yum-yinstallmakegccgcc-c++readline...
- pure-ftpd 使用(ftp prompt命令)
-
pure-ftpd是一个免费的ftp软件,其他介绍就不多说了。我们直接开始主题安装centosyuminstallepel-releaseyuminstallpure-ftpd配置备份原配置...
你 发表评论:
欢迎- 一周热门
-
-
如何在安装前及安装后修改黑群晖的Mac地址和Sn系列号
-
爱折腾的特斯拉车主必看!手把手教你TESLAMATE的备份和恢复
-
[常用工具] OpenCV_contrib库在windows下编译使用指南
-
Ubuntu系统Daphne + Nginx + supervisor部署Django项目
-
WindowsServer2022|配置NTP服务器的命令
-
WIN11 安装配置 linux 子系统 Ubuntu 图形界面 桌面系统
-
解决Linux终端中“-bash: nano: command not found”问题
-
NBA 2K25虚拟内存不足/爆内存/内存占用100% 一文速解
-
Linux 中的文件描述符是什么?(linux 打开文件表 文件描述符)
-
K3s禁用Service Load Balancer,解决获取浏览器IP不正确问题
-
- 最近发表
- 标签列表
-
- linux 查询端口号 (58)
- docker映射容器目录到宿主机 (66)
- 杀端口 (60)
- yum更换阿里源 (62)
- internet explorer 增强的安全配置已启用 (65)
- linux自动挂载 (56)
- 禁用selinux (55)
- sysv-rc-conf (69)
- ubuntu防火墙状态查看 (64)
- windows server 2022激活密钥 (56)
- 无法与服务器建立安全连接是什么意思 (74)
- 443/80端口被占用怎么解决 (56)
- ping无法访问目标主机怎么解决 (58)
- fdatasync (59)
- 405 not allowed (56)
- 免备案虚拟主机zxhost (55)
- linux根据pid查看进程 (60)
- dhcp工具 (62)
- mysql 1045 (57)
- 宝塔远程工具 (56)
- ssh服务器拒绝了密码 请再试一次 (56)
- ubuntu卸载docker (56)
- linux查看nginx状态 (63)
- tomcat 乱码 (76)
- 2008r2激活序列号 (65)