0

0

Linux系统维护周期规划_稳定运行策略说明【指导】

冷漠man

冷漠man

发布时间:2026-01-08 20:45:23

|

540人浏览过

|

来源于php中文网

原创

判断是否进入维护窗口期需人工确认:无活跃用户会话(w/who)、核心服务可控(systemctl list-units)、关键路径资源充足(df/shmmax);内核升级后须验证GRUB默认项、重建initramfs、保留旧内核;crontab需随机延时、限资源、加锁;systemd服务需检查Type与PIDFile,强制日志输出;维护前必查端口监听与deleted文件。

linux系统维护周期规划_稳定运行策略说明【指导】

如何判断当前系统是否已进入维护窗口期

Linux 系统没有内置的“维护窗口期”标记,是否处于可维护状态,取决于你是否已主动暂停关键服务、确认无活跃用户会话、且 uptime 显示负载可控。不要依赖系统自动提醒——它不会告诉你“现在可以重启了”。

  • wwho 检查是否有登录用户,特别是 root 或运维账号的交互式会话
  • 运行 systemctl list-units --type=service --state=active | grep -E "(nginx|httpd|postgresql|redis|mariadb)" 确认核心服务状态,避免在数据库写入高峰中 reload 配置
  • 检查 /proc/sys/kernel/shmmaxdf -h /var/log 等关键路径,磁盘满或共享内存溢出常导致维护失败但不报错

内核升级后必须执行的三件事

仅运行 apt upgrade linux-image-amd64(Debian/Ubuntu)或 yum update kernel(RHEL/CentOS)远远不够。新内核不会自动生效,且旧模块残留可能引发启动失败。

  • 确认新内核已写入 GRUB:检查 /boot/grub/grub.cfg 中最新条目是否含 linux /boot/vmlinuz-*,并用 grubby --default-kernel 验证默认启动项
  • 手动重建 initramfs:Debian 系用 update-initramfs -u -k all,RHEL 系用 dracut -f,缺失这步会导致新内核无法挂载根文件系统
  • 保留至少一个可用旧内核:修改 /etc/default/grubGRUB_DISABLE_OS_PROBER=false 并运行 update-grub(Debian)或确保 kernelopts 不被覆盖(RHEL),防止新内核 panic 后无法回退

crontab 维护任务与生产环境冲突的典型表现

很多团队把日志轮转、备份脚本全塞进 root 的 crontab,结果某天凌晨 2:03 系统响应变慢,排查发现是 logrotate 触发了 rsync 全量同步,同时另一 cron 正在跑 mysqldump,I/O 队列堆积到 200+。

CreBee
CreBee

短视频矩阵运营工具,跨平台多账号一站式管理

下载
  • 避免固定时间:用 sleep $((RANDOM % 300)) 在脚本开头随机延时,分散 I/O 峰值
  • 禁止无限制资源调用:mysqldump--single-transaction --skip-lock-tablestar 备份加 --use-compress-program="pigz -p2" 控制 CPU 占用
  • 所有 cron 任务必须带超时和锁机制:例如用 flock -n /tmp/backup.lock -c "mysqldump ... > /backup/db.sql",防止上一次未结束就触发下一轮

systemd 服务重启失败却无日志输出的原因

执行 systemctl restart nginx 返回 “OK”,但 curl -I localhost 超时,journalctl -u nginx 却空空如也——这不是服务没启,而是 systemd 认为它“启动成功”,因为主进程 fork 后立即退出(常见于配置错误的 ExecStart 或缺少 Type=forking 声明)。

  • 先查服务类型:systemctl show nginx | grep ^Type=,若为 Type=simple 但实际是传统 fork 进程,需改配 Type=forking 并设 PIDFile=
  • 临时绕过 unit 文件限制:用 systemctl start --no-block nginx + strace -f -e trace=clone,execve,exit_group /usr/sbin/nginx -t 直接观察进程行为
  • 强制日志捕获:在 service 文件中添加 StandardOutput=journal+consoleStandardError=journal+console,否则某些守护进程会静默关闭 stdout/stderr
cat /etc/systemd/system/nginx.service.d/override.conf
[Service]
Type=forking
PIDFile=/run/nginx.pid
StandardOutput=journal+console
StandardError=journal+console
真正卡住维护节奏的,往往不是技术动作本身,而是对“服务是否真就绪”的误判——比如 systemctl is-active 返回 active,不代表监听端口已 bind 完成;df -h 显示空间充足,不代表 /run/dev/shm 没满。每次维护前,花 30 秒盯一眼 ss -tlnpfind /proc/*/fd -ls 2>/dev/null | grep deleted | head -5

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

676

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

320

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

346

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1094

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

357

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

675

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

571

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

412

2024.04.29

php学习网站大全
php学习网站大全

精选多个优质PHP入门学习网站,涵盖教程、实战与文档,适合零基础到进阶开发者,助你高效掌握PHP编程。

0

2026.01.09

热门下载

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

精品课程

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

共48课时 | 1.7万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 785人学习

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

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