首页 > 运维 > linux运维 > 正文

Linux如何启动和停止系统服务

P粉602998670
发布: 2025-09-16 19:59:01
原创
674人浏览过
要启动和停止Linux服务,使用systemctl命令操作,如start、stop、restart、reload,并通过enable/disable设置开机自启,结合status和journalctl排查问题,确保服务正常运行。

linux如何启动和停止系统服务

Linux系统服务的启动与停止,核心在于理解其背后的初始化系统。在现代Linux发行版中,这主要依赖于

systemd
登录后复制
,它提供了一套统一且强大的工具来管理系统服务、守护进程以及其他系统资源。对于一些较老的系统或特定场景,可能还会遇到基于
SysVinit
登录后复制
Upstart
登录后复制
的服务管理方式,但无论哪种,其目的都是为了让用户能够精细控制后台进程的生命周期。掌握这些命令,是每个Linux用户和系统管理员的必备技能,它直接关系到系统稳定性和应用服务的可用性。

要启动和停止Linux系统服务,最常用且推荐的方式是使用

systemctl
登录后复制
命令。这是
systemd
登录后复制
初始化系统的主要控制接口,它几乎涵盖了所有服务管理的需求。

启动服务: 要启动一个服务,例如Apache Web服务器(通常服务名为

httpd
登录后复制
apache2
登录后复制
),你可以执行:

sudo systemctl start httpd
登录后复制

这条命令会尝试启动指定的服务。如果服务成功启动,通常不会有任何输出。

停止服务: 同样地,要停止一个正在运行的服务,比如刚才启动的

httpd
登录后复制

sudo systemctl stop httpd
登录后复制

服务停止后,相关的进程会被终止。

重启服务: 如果你修改了服务的配置文件,或者只是想重新加载服务以应用某些更改,可以使用

restart
登录后复制
命令。它会先停止服务,然后再启动它:

sudo systemctl restart httpd
登录后复制

重新加载服务配置: 有些服务支持“热重载”,这意味着它们可以在不完全停止和启动的情况下重新读取配置文件并应用更改,这对于避免服务中断非常有用。如果服务支持,使用

reload
登录后复制

sudo systemctl reload httpd
登录后复制

如果服务不支持

reload
登录后复制
,或者你只是不确定,
restart
登录后复制
通常是更安全的通用选项。

启用服务(开机自启): 仅仅启动服务并不意味着它会在系统重启后自动运行。要让服务在每次系统启动时都自动启动,你需要“启用”它:

sudo systemctl enable httpd
登录后复制

这条命令会创建必要的符号链接,确保

systemd
登录后复制
在启动时加载并运行该服务。

禁用服务(取消开机自启): 如果你不希望某个服务在开机时自动运行,可以禁用它:

sudo systemctl disable httpd
登录后复制

这会移除开机自启的符号链接。

检查服务状态: 随时查看服务的当前状态是排除故障和监控的关键:

systemctl status httpd
登录后复制

这个命令会显示服务是否正在运行、其进程ID、最近的日志消息以及其他有用的信息。

对于一些较老的Linux系统,或者当

systemctl
登录后复制
不可用时(这现在很少见了),你可能会遇到
service
登录后复制
命令,它通常是
SysVinit
登录后复制
Upstart
登录后复制
的接口:

sudo service httpd start
sudo service httpd stop
sudo service httpd restart
sudo service httpd status
登录后复制

不过,即便在一些现代系统中,

service
登录后复制
命令也常常只是
systemctl
登录后复制
的一个兼容性封装,最终还是会调用
systemctl
登录后复制
来执行操作。

如何查看Linux系统中所有可用的服务及其状态?

理解系统中有哪些服务在运行、哪些可以运行,以及它们的具体状态,是系统管理的基础。我个人觉得,这就像是给你的Linux系统做一次全面的体检。

systemd
登录后复制
在这方面提供了非常精细的控制和视图。

要列出所有已加载(无论是活动还是非活动)的服务单元,你可以使用:

systemctl list-units --type=service
登录后复制

这个命令会给你一个长长的列表,包括服务的名称(UNIT)、是否已加载(LOAD)、是否处于活动状态(ACTIVE)、以及更详细的运行状态(SUB)。

LOAD
登录后复制
列显示服务单元文件是否被
systemd
登录后复制
解析和加载。
ACTIVE
登录后复制
列则指示服务是否正在运行或处于停止状态。
SUB
登录后复制
列提供了更具体的子状态,比如
running
登录后复制
exited
登录后复制
dead
登录后复制
failed
登录后复制
等。通过这个列表,你可以快速概览当前系统上活跃的服务。

如果你只想看那些正在运行的服务,可以加上

--state=running
登录后复制
参数:

systemctl list-units --type=service --state=running
登录后复制

而如果想看看所有已安装的服务单元文件(包括那些没有被加载或启动的),以了解它们是否被设置为开机自启,则需要:

systemctl list-unit-files --type=service
登录后复制

这个命令会显示每个服务单元文件的

enabled
登录后复制
disabled
登录后复制
状态,这直接关系到它们是否会在系统启动时自动运行。我发现这个命令特别有用,因为有时候我只是想知道某个服务是否被配置为开机自启,而不是它当前是否在运行。

在实际操作中,我经常会将这些命令与

grep
登录后复制
结合起来,例如,要查找所有与“network”相关的服务:

systemctl list-units --type=service | grep network
登录后复制

这能帮助我快速定位到我感兴趣的服务,而不是在长长的列表中大海捞针。有时候,我也会用

systemctl status
登录后复制
不带任何参数,它会显示整个系统的概览,包括最近失败的服务,这对于快速诊断问题非常有帮助。

遇到服务启动失败或停止不了怎么办?

服务启动失败或停止不了,这是每个系统管理员都可能遇到的“头疼”问题。我记得有一次,一个关键的Web服务怎么都起不来,那感觉就像是心脏停跳了一样。解决这类问题,关键在于系统性地排查。

服务启动失败的排查步骤:

如知AI笔记
如知AI笔记

如知笔记——支持markdown的在线笔记,支持ai智能写作、AI搜索,支持DeepseekR1满血大模型

如知AI笔记 27
查看详情 如知AI笔记
  1. 检查服务状态和日志: 这是第一步,也是最重要的一步。

    systemctl status <service_name>
    登录后复制
    会显示服务的当前状态,通常会包含最近的错误信息。更深入的,你需要查看
    systemd
    登录后复制
    的日志:

    journalctl -xeu <service_name>
    登录后复制

    journalctl
    登录后复制
    systemd
    登录后复制
    的日志工具,
    -e
    登录后复制
    会跳到日志末尾,
    -x
    登录后复制
    会添加一些解释性信息,
    -u <service_name>
    登录后复制
    则只显示指定服务的日志。仔细阅读这些日志,它们会告诉你服务为什么启动失败,比如端口被占用、配置文件错误、权限问题、依赖服务未启动等等。我通常会从这里找到90%的问题根源。

  2. 检查配置文件: 很多服务启动失败是因为其配置文件存在语法错误、路径不正确或配置项冲突。服务的配置文件通常位于

    /etc/<service_name>/
    登录后复制
    /etc/
    登录后复制
    下的某个子目录。仔细检查你最近修改过的配置项。有些服务提供配置文件的语法检查工具,比如Apache的
    apachectl configtest
    登录后复制

  3. 检查端口占用: 如果服务是一个网络服务,它可能因为监听的端口被其他进程占用而无法启动。你可以使用

    ss -tulnp
    登录后复制
    netstat -tulnp
    登录后复制
    (如果
    ss
    登录后复制
    不可用)来查看当前哪些端口正在被监听,以及是哪个进程占用了它们。

  4. 检查依赖服务: 一个服务可能依赖于另一个服务。例如,一个数据库服务可能依赖于网络服务才能启动。如果依赖的服务没有运行,主服务也可能启动失败。

    systemctl status <service_name>
    登录后复制
    的输出中可能会提示依赖关系。

  5. 检查权限: 服务通常以特定的用户身份运行。如果该用户没有读取关键文件、写入日志目录或访问特定资源的权限,服务也可能失败。确保相关文件和目录的权限设置正确。

服务停止不了的排查步骤:

  1. 正常停止命令: 首先,再次尝试

    sudo systemctl stop <service_name>
    登录后复制
    。有时候服务只是需要一点时间来优雅地关闭。

  2. 查看进程: 如果服务仍然不响应,可能是其主进程或子进程陷入了僵局。使用

    ps aux | grep <service_name>
    登录后复制
    来查找与该服务相关的所有进程ID(PID)。

  3. 温柔地杀死进程: 找到主进程的PID后,尝试发送一个TERM信号来请求进程终止:

    sudo kill <PID>
    登录后复制

    给它几秒钟时间来响应。TERM信号允许进程在终止前进行清理工作。

  4. 强制杀死进程(万不得已): 如果

    kill <PID>
    登录后复制
    无效,那么你可能需要使用强制终止信号KILL:

    sudo kill -9 <PID>
    登录后复制

    请注意,

    kill -9
    登录后复制
    是“核弹”选项,它不会给进程任何清理的机会,可能导致数据损坏或不一致。所以,除非万不得已,否则不要轻易使用。在使用前,务必确认你正在杀死的是正确的进程。

  5. 检查服务单元文件: 有时候,服务停止不了是因为其

    .service
    登录后复制
    文件中定义了
    RemainAfterExit=yes
    登录后复制
    或其他阻止其正常退出的配置。检查
    /etc/systemd/system/
    登录后复制
    /usr/lib/systemd/system/
    登录后复制
    下的服务单元文件。

如何确保服务在系统重启后自动运行?

让服务在系统重启后自动运行,这是保证系统稳定性和服务可用性的关键一步。我个人觉得,如果你每次重启服务器后都得手动去启动一堆服务,那简直是噩梦。

systemd
登录后复制
enable
登录后复制
命令就是为此而生。

使用

systemctl enable
登录后复制

要确保一个服务在系统重启后自动运行,你需要使用

systemctl enable
登录后复制
命令。例如,要让Nginx Web服务器(服务名通常是
nginx
登录后复制
)在开机时自动启动:

sudo systemctl enable nginx
登录后复制

这个命令的本质是创建一个符号链接。它会将服务单元文件(例如

/usr/lib/systemd/system/nginx.service
登录后复制
)链接到
systemd
登录后复制
在启动时会扫描的目录(通常是
/etc/systemd/system/multi-user.target.wants/
登录后复制
)。当系统进入
multi-user.target
登录后复制
(多用户运行级别,大多数服务器的默认运行级别)时,
systemd
登录后复制
就会通过这个链接找到并启动
nginx
登录后复制
服务。

验证开机自启状态:

你可以随时检查一个服务是否已被启用:

systemctl is-enabled nginx
登录后复制

如果输出是

enabled
登录后复制
,那么它就会在开机时自动运行。如果是
disabled
登录后复制
,则不会。

禁用开机自启:

如果你想阻止某个服务在开机时自动启动,可以使用

disable
登录后复制
命令:

sudo systemctl disable nginx
登录后复制

这会移除之前创建的符号链接。

关于自定义服务:

对于你自己编写的应用程序或脚本,你也可以将其配置为

systemd
登录后复制
服务,从而实现开机自启。这需要你创建一个
.service
登录后复制
文件,通常放在
/etc/systemd/system/
登录后复制
目录下。一个简单的
my_app.service
登录后复制
文件可能看起来像这样:

[Unit]
Description=My Custom Application Service
After=network.target # 在网络服务启动后启动

[Service]
ExecStart=/usr/local/bin/my_app_script.sh # 你的应用程序或脚本的启动命令
Restart=always # 崩溃后自动重启
User=myuser # 以哪个用户身份运行

[Install]
WantedBy=multi-user.target # 在多用户模式下启用
登录后复制

创建或修改

.service
登录后复制
文件后,你需要让
systemd
登录后复制
重新加载其配置:

sudo systemctl daemon-reload
登录后复制

然后,你就可以像管理其他系统服务一样,使用

systemctl enable my_app
登录后复制
来设置开机自启,并用
systemctl start my_app
登录后复制
来启动它了。我发现这种方式管理自定义应用非常方便和规范,比那些手动添加到
/etc/rc.local
登录后复制
crontab
登录后复制
的旧方法要健壮得多。这种结构化的管理方式,不仅让系统更加整洁,也大大提升了服务的可靠性。

以上就是Linux如何启动和停止系统服务的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号