macOS Memory Dumping
Last updated
Last updated
学习与实践 AWS 黑客技术:HackTricks 培训 AWS 红队专家 (ARTE) 学习与实践 GCP 黑客技术:HackTricks 培训 GCP 红队专家 (GRTE)
交换文件,如 /private/var/vm/swapfile0
,在 物理内存满时 作为 缓存。当物理内存没有更多空间时,其数据会被转移到交换文件中,然后根据需要再带回物理内存。可能存在多个交换文件,名称如 swapfile0、swapfile1 等。
位于 /private/var/vm/sleepimage
的文件在 休眠模式 下至关重要。当 OS X 进入休眠时,内存中的数据会存储在此文件中。唤醒计算机时,系统会从此文件中检索内存数据,使用户能够继续之前的工作。
值得注意的是,在现代 MacOS 系统上,此文件通常出于安全原因被加密,恢复难度较大。
要检查 sleepimage 是否启用加密,可以运行命令 sysctl vm.swapusage
。这将显示文件是否被加密。
MacOS 系统中另一个重要的内存相关文件是 内存压力日志。这些日志位于 /var/log
中,包含有关系统内存使用情况和压力事件的详细信息。它们对于诊断内存相关问题或理解系统如何随时间管理内存特别有用。
为了在 MacOS 机器上转储内存,可以使用 osxpmem。
注意:以下说明仅适用于具有 Intel 架构的 Mac。此工具现已归档,最后一次发布是在 2017 年。根据以下说明下载的二进制文件针对 Intel 芯片,因为在 2017 年时 Apple Silicon 尚未出现。可能可以为 arm64 架构编译二进制文件,但您需要自己尝试。
如果您发现此错误:osxpmem.app/MacPmem.kext failed to load - (libkern/kext) authentication failure (file ownership/permissions); check the system/kernel logs for errors or try kextutil(8)
您可以通过以下方式修复它:
其他错误可能通过允许加载kext在“安全性与隐私 --> 常规”中修复,只需允许它。
您还可以使用此单行命令下载应用程序,加载kext并转储内存:
学习与实践 AWS 黑客技术:HackTricks 培训 AWS 红队专家 (ARTE) 学习与实践 GCP 黑客技术:HackTricks 培训 GCP 红队专家 (GRTE)