0

0

Linux命令行关机重启计划任务at与cron

P粉602998670

P粉602998670

发布时间:2025-09-02 10:47:01

|

1014人浏览过

|

来源于php中文网

原创

linux命令行关机重启计划任务at与cron

在Linux命令行下,计划关机或重启主要依赖于两个强大的工具

at
cron
。简单来说,如果你需要执行一次性的、未来某个时刻的关机或重启操作,
at
是你的首选;而对于周期性的、重复的维护任务,比如每周重启一次服务器,那么
cron
就是不可或缺的。我个人觉得,理解并熟练运用这两个工具,是每个Linux系统管理员,甚至是高级用户,都应该掌握的基本功,它们能帮你省去不少手动操作的麻烦,尤其是在远程管理服务器时。

解决方案

使用

at
命令进行一次性关机/重启

at
命令允许你在指定的时间执行一次性任务。这对于那些临时的维护窗口或者需要特定时间点执行的关机操作非常有用。

  1. 确认

    atd
    服务正在运行:
    at
    命令依赖于
    atd
    服务。你可以通过以下命令检查其状态并启动它(如果需要):

    sudo systemctl status atd
    sudo systemctl start atd
    sudo systemctl enable atd # 确保开机自启动
  2. 调度关机任务: 假设你想在10分钟后关机:

    echo "sudo shutdown -h now" | at now + 10 minutes

    或者,如果你想在晚上10点关机:

    echo "sudo shutdown -h now" | at 22:00

    这里,

    shutdown -h now
    是立即关机的命令。你也可以使用
    reboot
    进行重启。

  3. 查看和取消任务: 查看当前所有待执行的

    at
    任务:

    atq

    你会看到任务的编号。例如,如果任务编号是

    1
    ,你可以这样取消它:

    atrm 1

使用

cron
命令进行周期性关机/重启

cron
是Linux下用于周期性任务调度的工具,非常适合那些需要定期执行的关机或重启操作。

  1. 编辑

    crontab
    文件: 每个用户都有自己的
    crontab
    文件,你可以通过以下命令编辑它:

    crontab -e

    这会打开一个文本编辑器(通常是

    vi
    nano
    ),你可以在其中添加你的调度任务。

  2. cron
    任务的语法:
    cron
    任务的格式是:

    分 时 日 月 周 命令
    • 分 (Minute): 0-59
    • 时 (Hour): 0-23
    • 日 (Day of Month): 1-31
    • 月 (Month): 1-12
    • 周 (Day of Week): 0-7 (0或7代表周日,1代表周一)
    • 命令 (Command): 要执行的命令

    特殊字符:

    • *
      : 匹配所有可能的值。
    • ,
      : 列出多个值。例如
      1,3,5
      表示1、3、5。
    • -
      : 指定一个范围。例如
      1-5
      表示1到5。
    • /
      : 指定步长。例如
      */5
      表示每5分钟。
  3. 调度关机/重启任务示例:

    • 每天凌晨3点重启:

      0 3 * * * /usr/sbin/reboot

      这里我特意使用了

      /usr/sbin/reboot
      的完整路径,这是一个好习惯,可以避免
      PATH
      环境变量问题。

    • 每周六晚上11点半关机:

      30 23 * * 6 /usr/sbin/shutdown -h now
    • 每月1号凌晨2点重启:

      0 2 1 * * /usr/sbin/reboot

    注意: 对于需要

    sudo
    权限的命令(如
    shutdown
    reboot
    ),最好是编辑
    root
    用户的
    crontab
    。你可以通过
    sudo crontab -e
    来做到这一点。

    问小白
    问小白

    免费使用DeepSeek满血版

    下载

为什么我们需要计划关机或重启?

在我看来,计划性的关机或重启不仅仅是为了省电或者让机器“休息一下”那么简单。它在系统维护和稳定性方面扮演着至关重要的角色。

一个主要原因是为了系统资源的优化和释放。长时间运行的系统,即使没有明显的内存泄漏,也可能因为各种应用程序的缓存、临时文件、或者一些不那么完美的程序行为,导致内存碎片化、文件句柄累积等问题,这最终会影响系统性能。定期重启就像给系统做了一次彻底的“大扫除”,清除了所有这些累积的负担,让系统回到一个干净、高效的状态。我曾经遇到过一些老旧的服务器,如果不是每周强制重启一次,运行几天就会变得异常缓慢,响应迟钝。

其次是安全更新和补丁的生效。很多Linux内核或核心服务的安全更新,都需要重启系统才能完全生效。如果你只是安装了补丁而不重启,那么这些漏洞可能依然存在。计划重启可以确保这些关键的安全更新能够及时、有效地应用,从而提高系统的安全性。当然,这需要配合自动化更新机制一起使用。

还有就是预防性维护。对于一些特定的应用场景,比如数据库服务器或者一些计算密集型服务,定期重启可以避免一些潜在的、难以追踪的稳定性问题,比如某个服务偶尔出现的死锁,或者某个驱动程序的微小内存泄漏。虽然这听起来有点像是“治标不治本”,但在某些情况下,它确实是最经济有效的解决方案。

最后,节约能源也是一个实际的考量。对于非24/7运行的服务器或者工作站,在非工作时间关机可以显著降低电费开支,也算是为环保出了一份力。

使用
at
命令进行一次性任务调度有哪些常见陷阱?

虽然

at
命令用起来很直接,但我在实际使用中也踩过一些坑,这些“陷阱”如果不注意,可能会让你以为任务没执行或者执行失败。

一个最常见的坑就是权限问题。比如你用普通用户身份调度了一个

sudo shutdown -h now
的任务。
at
任务在执行时,默认是以调度任务的用户身份运行的。如果你的命令需要
root
权限,但你没有在
at
任务中提供
sudo
密码(
at
任务无法交互式地获取密码),那么这个命令就会失败。正确的做法是,确保
sudo
命令已经被配置为不需要密码(通过
visudo
配置
NOPASSWD
),或者直接切换到
root
用户 (
sudo su -
) 来调度需要
root
权限的
at
任务。

另一个问题是环境差异

at
任务执行时的环境通常比你当前登录的Shell环境要“干净”得多,这意味着
PATH
环境变量可能不包含你所有常用命令的路径。我曾经遇到过一个脚本,在Shell里跑得好好的,放到
at
里就报错找不到命令。解决办法是,在
at
任务的脚本中,使用命令的完整路径,比如
echo "/usr/sbin/shutdown -h now" | at now + 5 minutes
,而不是仅仅
shutdown -h now

输出和错误处理也是一个需要注意的地方。

at
任务在后台运行,它的标准输出和标准错误默认会通过邮件发送给调度任务的用户(如果系统配置了邮件服务的话)。如果你的系统没有配置邮件服务,或者你没有检查邮件的习惯,那么任务执行失败的错误信息你可能就错过了。一个好的实践是,将
at
任务的输出重定向到文件,比如
echo "sudo /path/to/my_script.sh > /var/log/my_at_job.log 2>&1" | at now + 1 hour
,这样即使没有邮件,你也能从日志文件中找到线索。

最后,别忘了

atd
服务。如果
atd
服务没有运行,那么你调度再多的
at
任务也只是存在队列里,永远不会被执行。这是最基础也最容易被忽视的一点。

cron
任务调度在实际生产环境中应注意哪些细节?

cron
在生产环境中是核心工具,但要用好它,避免一些意想不到的麻烦,需要注意的细节可不少。

首先,命令的完整路径是重中之重。就像

at
任务一样,
cron
任务执行时的环境通常也很有限。我见过太多因为
crontab
里只写了
python myscript.py
而不是
/usr/bin/python /path/to/myscript.py
导致任务失败的案例。永远使用命令的绝对路径,包括脚本本身和脚本中调用的任何外部命令。这能有效避免
PATH
环境变量带来的问题。

其次是输出重定向和日志记录

cron
任务的任何标准输出和标准错误,默认都会尝试通过邮件发送给
crontab
的所有者。在生产环境中,这可能导致你的邮箱被大量的
cron
邮件塞满,或者更糟的是,如果邮件服务配置不当,你根本收不到任何错误通知。最佳实践是,将所有输出重定向到日志文件:

0 3 * * * /usr/sbin/reboot > /var/log/reboot_cron.log 2>&1

这样,所有的成功或失败信息都会被记录下来,方便你日后审计和排查问题。你也可以在

crontab
文件的开头设置
MAILTO=""
来禁用邮件通知,或者指定一个特定的邮箱地址。

并发和重叠任务是另一个需要仔细考虑的问题。如果你有一个任务需要运行很长时间,并且它被设置为每小时运行一次,那么有可能会出现上一个任务还没结束,下一个任务又开始了,导致资源争抢或者数据不一致。对于这类任务,可以考虑在脚本内部加入锁机制(比如使用

flock
命令或者简单的文件锁),确保同一时间只有一个实例在运行。

系统用户权限也需要明确。通常,涉及系统级别的关机或重启,最好是编辑

root
用户的
crontab
(
sudo crontab -e
)。如果你用普通用户调度了需要
root
权限的命令,它会失败,除非该命令在
sudoers
文件中被配置为允许该用户无密码执行。

错误处理和健壮性是衡量一个

cron
任务质量的关键。你的脚本是否能在遇到错误时优雅地退出?是否能记录下错误信息?例如,在重启服务之前,你可能想检查一下服务是否真的在运行,或者在关机前先确保所有关键数据都已经同步到磁盘。

最后,测试是必不可少的。不要在生产环境直接上线一个新的

cron
任务。先在一个测试环境或者通过手动执行的方式,验证你的命令或脚本是否能正常工作,并且在预期的结果下完成。对于
cron
任务,你可以通过将时间设置在几分钟之后,然后观察系统行为来测试。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

382

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2107

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

357

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

259

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

329

2023.10.09

数据库对象名无效怎么解决
数据库对象名无效怎么解决

数据库对象名无效解决办法:1、检查使用的对象名是否正确,确保没有拼写错误;2、检查数据库中是否已存在具有相同名称的对象,如果是,请更改对象名为一个不同的名称,然后重新创建;3、确保在连接数据库时使用了正确的用户名、密码和数据库名称;4、尝试重启数据库服务,然后再次尝试创建或使用对象;5、尝试更新驱动程序,然后再次尝试创建或使用对象。

419

2023.10.16

vb连接access数据库的方法
vb连接access数据库的方法

vb连接access数据库方法:1、使用ADO连接,首先导入System.Data.OleDb模块,然后定义一个连接字符串,接着创建一个OleDbConnection对象并使用Open() 方法打开连接;2、使用DAO连接,首先导入 Microsoft.Jet.OLEDB模块,然后定义一个连接字符串,接着创建一个JetConnection对象并使用Open()方法打开连接即可。

463

2023.10.16

vb连接数据库的方法
vb连接数据库的方法

vb连接数据库的方法有使用ADO对象库、使用OLEDB数据提供程序、使用ODBC数据源等。详细介绍:1、使用ADO对象库方法,ADO是一种用于访问数据库的COM组件,可以通过ADO连接数据库并执行SQL语句。可以使用ADODB.Connection对象来建立与数据库的连接,然后使用ADODB.Recordset对象来执行查询和操作数据;2、使用OLEDB数据提供程序方法等等。

231

2023.10.19

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

4

2026.03.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 10.2万人学习

Git 教程
Git 教程

共21课时 | 4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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