0

0

MacOS系统系统日志文件过大自动清理脚本编写

舞姬之光

舞姬之光

发布时间:2026-03-15 15:26:03

|

863人浏览过

|

来源于php中文网

原创

macOS日志清理应优先使用系统原生工具:用log erase按时间清理统一日志,find清理/var/log旧归档,谨慎处理~/Library/Logs;推荐配置log config限制磁盘用量,而非盲目脚本清理。

macos系统系统日志文件过大自动清理脚本编写

macOS 系统日志(尤其是 /var/log/~/Library/Logs/ 下的日志)长期积累确实容易占用大量磁盘空间,但 macOS 本身已内置了基于 log 命令和 asl(旧式)或 unified logging(10.12+)的自动轮转与清理机制。真正需要手动干预的,通常是第三方应用日志、调试日志、或某些未遵循系统规范的日志目录。编写“自动清理脚本”前,建议先确认是否真有必要——盲目清理可能影响问题排查,甚至误删关键诊断信息。

明确清理目标:哪些日志可安全清理?

不是所有日志都适合一概而论地删除。需区分以下几类:

  • 系统统一日志(/var/db/diagnostics/、/var/db/uuidtext/):由 log 命令管理,不建议直接 rm。应使用 log collect 导出后,用 log erase --all 或按时间范围清理(如 log erase --since "2024-01-01"
  • /var/log/ 下的传统日志(system.log、install.log 等):受 newsyslog 管理,默认已压缩轮转(如 system.log.0.gz)。可安全清理 .gz 归档或超过 N 天的旧轮转文件
  • 用户级日志(~/Library/Logs/):多数为 App 自建日志,无统一策略。可按目录名、修改时间、大小筛选,例如清理 Console.app 导出的临时日志、Xcode 构建日志、或某崩溃报告缓存目录
  • 第三方服务日志(如 Homebrew 服务、Docker Desktop、Nginx、MySQL):需单独配置其自身日志轮转(如 logrotate),或在脚本中显式指定路径

推荐方案:用 log 命令 + find 组合清理(安全可控)

以下是一个轻量、可定时执行的 Bash 脚本示例(保存为 cleanup-logs.sh),兼顾系统规范与实际需求:

#!/bin/bash
# macOS 日志清理脚本(建议配合 launchd 定时运行)
<h1>=== 清理 Unified Logging(仅保留最近7天)===</h1><p>echo "【Unified Logging】清理 7 天前日志..."
sudo log erase --since "7 days ago" 2>/dev/null</p><h1>=== 清理 /var/log/ 轮转归档(保留最近5个 .gz 文件)===</h1><p>echo "【/var/log/】清理旧归档..."
sudo find /var/log -name "<em>.gz" -type f -mtime +30 -delete
sudo find /var/log -name "</em>.old" -type f -delete</p><h1>=== 清理用户日志(~/.log 目录及常见大日志子目录)===</h1><p>echo "【用户日志】清理 >100MB 的旧日志..."
find "$HOME/Library/Logs" -type f ( -name "<em>.log" -o -name "</em>.out" -o -name "*.err" ) -size +100M -mtime +14 -delete 2>/dev/null</p><h1>=== 可选:清理 Console.app 导出缓存(易被忽略的大头)===</h1><p>echo "【Console 缓存】清理导出日志..."
rm -rf "$HOME/Library/Logs/Console/Exports/"*</p><h1>=== 输出剩余空间提示 ===</h1><p>echo "清理完成。当前根分区可用空间:"
df -h / | awk 'NR==2 {print $4}'

✅ 注意事项:
- 需要 sudo 执行部分命令(如 log erase、清理 /var/log
- 使用 -mtime +N-atime 更可靠(基于修改时间而非访问时间)
- 2>/dev/null 抑制权限不足等非关键报错,避免干扰 cron 输出

让脚本自动运行:用 launchd 替代 cron(macOS 推荐)

将脚本设为每日凌晨 2 点运行,创建 ~/Library/LaunchAgents/com.user.cleanup-logs.plist

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
  <key>Label</key>
  <string>com.user.cleanup-logs</string>
  <key>ProgramArguments</key>
  <array>
    <string>/bin/bash</string>
    <string>/path/to/cleanup-logs.sh</string>
  </array>
  <key>StartCalendarInterval</key>
  <dict>
    <key>Hour</key>
    <integer>2</integer>
    <key>Minute</key>
    <integer>0</integer>
  </dict>
  <key>RunAtLoad</key>
  <false/>
</dict>
</plist>

然后加载:
launchctl load ~/Library/LaunchAgents/com.user.cleanup-logs.plist
launchctl start com.user.cleanup-logs

Winston AI
Winston AI

强大的AI内容检测解决方案

下载

替代思路:优先启用系统原生日志限制(更省心)

其实 macOS 已提供配置接口,无需脚本即可控制日志保留策略:

  • 查看当前 unified logging 保留策略:log config --status
  • 限制日志最大磁盘用量(例如 2GB):sudo log config --mode "level:default, persist:default, keep-ascii:1, max-size:2G"
  • 禁用某类日志(如 Kernel):sudo log config --mode "level:default, persist:default, subsystem:kernel, category:*" --mode "level:none"

这些设置重启后仍生效,且与系统日志架构深度集成,比外部脚本更稳定可靠。

不复杂但容易忽略的是:日志膨胀往往源于某个异常进程持续输出(比如卡死的后台服务、无限重试的脚本)。定期用 log show --predicate 'eventMessage contains "error"' --last 24h 快速筛查源头,比单纯清日志更有治本效果。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

686

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

534

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

287

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

520

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

267

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

392

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

542

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

668

2023.08.14

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

69

2026.03.13

热门下载

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

精品课程

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

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