我正在使用 Ubuntu 14.04LTS 服务器(AWS EC2)进行自定义数据库转储,但发现了非常奇怪的内存行为。
我正在使用 PHP CLI 脚本循环遍历自定义转储查询,该查询输出到编号文件,然后cat
将该文件输出到输出文件。由于 mysql,内存使用量按预期上升。mysql 转储文件和输出文件都写入单独的已安装驱动器 (EBS)。
在启动脚本之前,内存使用率约为 20%。根据 中的图表,一旦进程完成,内存使用率约为 90%。htop
我已经用 验证了使用情况free -m
。mysql 重启会将内存使用率降至约 50%。
我曾经用来验证没有任何东西在使用该文件。我甚至在目录中lsof
也做过,但只得到了我的 bash 进程和 lsof。lsof
真正奇怪的是,一旦我删除该文件,内存使用量就会下降回 20%。
我尝试在不重新启动 mysql 的情况下删除该文件,使用率下降了上述数字所预期的 30%。
使用找到的内存查看器脚本这里没有显示相同的内存使用情况,所以我认为它不完全准确。它显示保留文件不会消耗任何内存。
还有其他方法可以让我了解什么保存着内存吗?
答案1
您实际看到的是系统的磁盘缓存使用情况。所有现代系统都会缓存磁盘操作,以便更快地重复访问同一磁盘区域。
这种缓存过程被认为消耗的资源很少,但之后可能会产生频繁的好处。由于系统知道缓存相对于其他内存需求而言并不重要,因此如果其他用途需要缓存,系统会立即转储缓存的一部分。
您还注意到 MySQL 服务器进程的内部缓存,其作用类似于操作系统的缓存,但操作系统不会将其识别为缓存,这就是为什么它只能根据通过服务器进程本身的操作(例如重新启动它)来释放。