
在Linux系统里,想知道到底有哪些服务在跑,或者哪些服务准备开机启动,这其实是个很基础但又很关键的问题。简单来说,最直接的办法就是用
systemctl
systemctl list-units --type=service --all
systemctl list-unit-files --type=service
要查看Linux系统中所有已安装的服务列表,主要取决于你的Linux发行版使用的是哪种初始化系统。目前主流的是systemd,但也有一些老系统或特定场景还在用SysVinit或Upstart。
对于基于systemd的系统(绝大多数现代Linux发行版):
查看所有已加载的服务单元及其状态:
systemctl list-units --type=service --all
这个命令会列出所有当前systemd知道的服务单元,包括那些正在运行、已经停止、加载失败的,以及那些只是静态存在但未被激活的服务。输出会显示服务名称、加载状态、活动状态、子状态和简短描述。
查看所有已安装的服务文件及其启用/禁用状态:
systemctl list-unit-files --type=service
这个命令列出所有可用的服务单元文件,以及它们是否被配置为开机启动(
enabled
disabled
查看正在运行的进程,间接推断服务:
ps aux | grep -i 'daemon\|service'
虽然不是直接的服务列表,但很多服务都以守护进程(daemon)的形式运行。这个命令可以帮助你发现一些不一定通过systemd直接管理,但确实在后台运行的程序。当然,结果需要人工筛选。
查看监听端口,推断网络服务:
ss -tulnp # 或者对于老系统 netstat -tulnp
这个命令会列出所有正在监听TCP和UDP端口的进程。每个监听端口通常都对应着一个网络服务(如SSH、Web服务器、数据库等)。通过查看
PID/Program name
对于基于SysVinit或Upstart的系统(较旧的发行版或特定场景):
查看所有已知的服务及其状态:
service --status-all
这个命令会遍历
/etc/init.d/
[ + ]
[ - ]
[ ? ]
查看开机自启的服务(SysVinit):
chkconfig --list # 或者手动检查 /etc/rcX.d/ 目录 ls /etc/rc?.d/S*
chkconfig --list
/etc/rcX.d/
/etc/init.d/
S
K

这事儿说起来,其实是Linux初始化系统演进的结果。早期,几乎所有的Linux发行版都依赖于SysVinit。它的服务管理方式比较简单粗暴,主要就是一堆shell脚本放在
/etc/init.d/
/etc/rcX.d/
service
chkconfig
后来,为了解决SysVinit的这些痛点,一些新的初始化系统应运而生,其中比较有代表性的是Ubuntu引入的Upstart。Upstart尝试用事件驱动的方式来管理服务,理论上可以实现并行启动,并且更好地处理服务间的依赖关系。它有自己的配置文件格式,但通常也能兼容SysVinit的脚本,所以
service
再后来,systemd横空出世,并且迅速成为了主流。它被设计成一个高度并行、功能强大、且对服务依赖关系有精细控制的初始化系统。systemd不仅仅是初始化系统,它还集成了日志管理(journald)、设备管理、网络配置等诸多功能,形成了一个庞大的生态系统。它的服务单元文件(
.service
/etc/systemd/system/
/usr/lib/systemd/system/
systemctl
所以,当你从一个老旧的CentOS 6(SysVinit)跳到CentOS 7/8/9或任何现代Ubuntu(systemd)时,会发现以前用的
service httpd status
systemctl status httpd

判断服务状态和设置开机自启是日常系统管理中非常频繁的操作。
判断服务是否正在运行:
对于systemd系统,使用
systemctl status <服务名称>
systemctl status nginx
输出会非常详细,包括服务的加载状态(Loaded)、活动状态(Active: active (running)表示正在运行,active (exited)表示运行后退出,inactive (dead)表示未运行)、进程ID、内存占用、最近的日志片段等等。重点看
Active
active (running)
对于SysVinit/Upstart系统,使用
service <服务名称> status
service apache2 status
它通常会返回一个简单的状态信息,比如"Apache2 is running"或者"Apache2 is not running"。有时候,它也可能显示一个PID文件路径或进程ID。
设置服务开机自启:
对于systemd系统,设置开机自启非常直观:
启用服务(开机自启):
systemctl enable <服务名称>
这个命令会在
systemd
禁用服务(取消开机自启):
systemctl disable <服务名称>
这个命令会移除
enable
立即启动服务:
systemctl start <服务名称>
立即停止服务:
systemctl stop <服务名称>
立即重启服务:
systemctl restart <服务名称>
对于SysVinit系统,设置开机自启稍微复杂一些,因为它涉及到运行级别:
使用chkconfig
chkconfig <服务名称> on # 在所有默认运行级别下启用 chkconfig <服务名称> off # 在所有默认运行级别下禁用 chkconfig --level 35 <服务名称> on # 在运行级别3和5下启用
chkconfig
/etc/rcX.d/
手动管理(不推荐,但了解原理有用): 你可以手动在
/etc/rcX.d/
/etc/init.d/<服务名称>
S
K
S99myservice
myservice

当服务启动失败或者运行异常时,这可真是让人头疼。但别慌,大部分问题都有迹可循,关键在于知道去哪里找线索。我的经验是,遵循一套系统性的排查流程,能大大提高解决问题的效率。
查看服务状态及日志(Systemd是王道): 这是第一步,也是最关键的一步。
systemctl status <服务名称>
这条命令会给你一个服务的即时快照,包括它是否正在运行、失败的原因(如果失败了)、以及最近的日志片段。如果这里显示
Active: failed
Main PID
CGroup
更深入地,利用
journalctl
journalctl -u <服务名称> --since "1 hour ago" -e
-u
--since
-e
检查服务单元文件(Systemd): 服务单元文件(通常是
/etc/systemd/system/<服务名称>.service
/usr/lib/systemd/system/<服务名称>.service
systemctl cat <服务名称>
这个命令会显示服务单元文件的内容。你需要检查:
ExecStart
WorkingDirectory
User
Group
Environment
Requires
After
检查配置文件: 绝大多数服务都有自己的配置文件,比如Nginx的
/etc/nginx/nginx.conf
/etc/my.cnf
Configuration error
nginx -t
apachectl configtest
权限问题: 这是新手常犯的错误,也是老手偶尔疏忽的地方。服务需要读取文件、写入日志、创建PID文件等,这些操作都需要相应的权限。
/var/log/
/var/run/
/var/lib/
端口冲突: 如果服务是一个网络服务,它需要监听一个端口。如果这个端口已经被其他进程占用,服务就无法启动。
ss -tulnp | grep <端口号> # 或者 netstat -tulnp | grep <端口号>
这会显示哪个进程正在监听该端口。如果发现冲突,你需要停止占用端口的进程,或者修改服务的配置让它监听另一个端口。
资源限制: 虽然不常见,但有时候服务启动失败是因为系统资源不足,比如内存耗尽、文件描述符达到上限等。
dmesg
ulimit -a
LimitNOFILE
依赖服务未启动: 如果服务A依赖于服务B,而服务B没有启动,那么服务A自然也无法启动。日志中通常会明确指出依赖失败。
排查问题就像侦探破案,你需要从各种线索中找出真相。多看日志、多思考、多尝试,通常都能找到症结所在。
以上就是Linux怎么查看所有已安装的服务列表的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号